tracdap-runtime 0.9.2.dev1__tar.gz → 0.9.3.dev1__tar.gz
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- {tracdap_runtime-0.9.2.dev1/tracdap_runtime.egg-info → tracdap_runtime-0.9.3.dev1}/PKG-INFO +13 -13
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/README.md +10 -10
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/setup.cfg +3 -3
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_version.py +1 -1
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1/tracdap_runtime.egg-info}/PKG-INFO +13 -13
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/LICENSE +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/pyproject.toml +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/__init__.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/__init__.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/core/__init__.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/core/config_parser.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/core/data.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/core/guard_rails.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/core/logging.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/core/models.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/core/repos.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/core/schemas.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/core/shim.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/core/storage.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/core/struct.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/core/type_system.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/core/util.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/core/validation.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/exec/__init__.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/exec/actors.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/exec/context.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/exec/dev_mode.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/exec/engine.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/exec/functions.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/exec/graph.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/exec/graph_builder.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/ext/__init__.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/ext/sql.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/ext/storage.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/grpc/__init__.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/grpc/codec.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/grpc/server.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/grpc/tracdap/api/internal/runtime_pb2.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/grpc/tracdap/api/internal/runtime_pb2.pyi +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/grpc/tracdap/api/internal/runtime_pb2_grpc.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/grpc/tracdap/metadata/common_pb2.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/grpc/tracdap/metadata/common_pb2.pyi +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/grpc/tracdap/metadata/config_pb2.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/grpc/tracdap/metadata/config_pb2.pyi +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/grpc/tracdap/metadata/custom_pb2.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/grpc/tracdap/metadata/custom_pb2.pyi +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/grpc/tracdap/metadata/data_pb2.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/grpc/tracdap/metadata/data_pb2.pyi +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/grpc/tracdap/metadata/file_pb2.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/grpc/tracdap/metadata/file_pb2.pyi +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/grpc/tracdap/metadata/flow_pb2.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/grpc/tracdap/metadata/flow_pb2.pyi +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/grpc/tracdap/metadata/job_pb2.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/grpc/tracdap/metadata/job_pb2.pyi +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/grpc/tracdap/metadata/model_pb2.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/grpc/tracdap/metadata/model_pb2.pyi +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/grpc/tracdap/metadata/object_id_pb2.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/grpc/tracdap/metadata/object_id_pb2.pyi +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/grpc/tracdap/metadata/object_pb2.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/grpc/tracdap/metadata/object_pb2.pyi +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/grpc/tracdap/metadata/resource_pb2.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/grpc/tracdap/metadata/resource_pb2.pyi +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/grpc/tracdap/metadata/search_pb2.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/grpc/tracdap/metadata/search_pb2.pyi +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/grpc/tracdap/metadata/storage_pb2.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/grpc/tracdap/metadata/storage_pb2.pyi +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/grpc/tracdap/metadata/tag_pb2.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/grpc/tracdap/metadata/tag_pb2.pyi +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/grpc/tracdap/metadata/tag_update_pb2.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/grpc/tracdap/metadata/tag_update_pb2.pyi +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/grpc/tracdap/metadata/type_pb2.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/grpc/tracdap/metadata/type_pb2.pyi +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/runtime.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/static_api.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_plugins/__init__.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_plugins/_helpers.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_plugins/config_local.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_plugins/format_arrow.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_plugins/format_csv.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_plugins/format_parquet.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_plugins/repo_git.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_plugins/repo_local.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_plugins/repo_pypi.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_plugins/storage_aws.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_plugins/storage_azure.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_plugins/storage_gcp.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_plugins/storage_local.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_plugins/storage_sql.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_plugins/storage_sql_dialects.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/api/__init__.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/api/constants.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/api/experimental.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/api/hook.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/api/model_api.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/api/static_api.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/config/__init__.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/config/common.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/config/dynamic.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/config/job.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/config/platform.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/config/result.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/config/runtime.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/config/tenant.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/exceptions.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/ext/__init__.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/ext/config.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/ext/embed.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/ext/plugins.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/ext/repos.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/ext/storage.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/launch/__init__.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/launch/__main__.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/launch/cli.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/launch/launch.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/metadata/__init__.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/metadata/common.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/metadata/config.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/metadata/custom.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/metadata/data.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/metadata/file.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/metadata/flow.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/metadata/job.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/metadata/model.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/metadata/object.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/metadata/object_id.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/metadata/resource.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/metadata/search.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/metadata/storage.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/metadata/tag.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/metadata/tag_update.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/metadata/type.py +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/tracdap_runtime.egg-info/SOURCES.txt +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/tracdap_runtime.egg-info/dependency_links.txt +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/tracdap_runtime.egg-info/requires.txt +0 -0
- {tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/tracdap_runtime.egg-info/top_level.txt +0 -0
|
@@ -1,14 +1,14 @@
|
|
|
1
1
|
Metadata-Version: 2.4
|
|
2
2
|
Name: tracdap-runtime
|
|
3
|
-
Version: 0.9.
|
|
3
|
+
Version: 0.9.3.dev1
|
|
4
4
|
Summary: Portable, production-grade models in Python
|
|
5
5
|
Home-page: https://www.fintrac.co.uk/
|
|
6
6
|
Author: Martin Traverse
|
|
7
7
|
Author-email: martin@fintrac.co.uk
|
|
8
8
|
License: Apache-2.0
|
|
9
9
|
Project-URL: Documentation, https://docs.fintrac.co.uk/versions/latest/modelling
|
|
10
|
-
Project-URL: Source Code, https://github.com/
|
|
11
|
-
Project-URL: Issue Tracker, https://github.com/
|
|
10
|
+
Project-URL: Source Code, https://github.com/finos/tracdap
|
|
11
|
+
Project-URL: Issue Tracker, https://github.com/finos/tracdap/issues
|
|
12
12
|
Platform: any
|
|
13
13
|
Classifier: Operating System :: OS Independent
|
|
14
14
|
Classifier: Programming Language :: Python :: 3
|
|
@@ -107,7 +107,7 @@ For a complete guide to writing models in the TRAC framework, see the
|
|
|
107
107
|
|
|
108
108
|
## 📦 Requirements
|
|
109
109
|
|
|
110
|
-
* **Python :** 3.
|
|
110
|
+
* **Python :** 3.9 or later
|
|
111
111
|
* **Tools :** Any popular IDE (PyCharm, VS Code, etc.)
|
|
112
112
|
* **Pandas :** Version 1.2 and later are supported
|
|
113
113
|
* **Polars :** Version 1.0 and later are supported
|
|
@@ -134,35 +134,35 @@ import tracdap.rt.api as trac
|
|
|
134
134
|
class QuickStartModel(trac.TracModel):
|
|
135
135
|
|
|
136
136
|
def define_parameters(self):
|
|
137
|
-
|
|
137
|
+
|
|
138
138
|
# Define any parameters the model will use
|
|
139
139
|
return trac.define_parameters(
|
|
140
140
|
trac.P("exchange_rate", trac.FLOAT, "EUR / GBP exchange rate")
|
|
141
141
|
)
|
|
142
142
|
|
|
143
143
|
def define_inputs(self):
|
|
144
|
-
|
|
144
|
+
|
|
145
145
|
# Define an input table with the columns and data types that the model needs
|
|
146
146
|
customer_loans = trac.define_input_table(
|
|
147
147
|
trac.F("id", trac.STRING, label="Customer account ID", business_key=True),
|
|
148
148
|
trac.F("region", trac.STRING, label="Customer home region", categorical=True),
|
|
149
|
-
trac.F("loan_amount", trac.FLOAT, label="Principal loan amount"),
|
|
149
|
+
trac.F("loan_amount", trac.FLOAT, label="Principal loan amount (EUR)"),
|
|
150
150
|
label="Customer loans data")
|
|
151
151
|
|
|
152
152
|
return {"customer_loans": customer_loans}
|
|
153
153
|
|
|
154
154
|
def define_outputs(self):
|
|
155
|
-
|
|
155
|
+
|
|
156
156
|
# Define an output table with the columns and data types that the model will produce
|
|
157
157
|
loans_by_region = trac.define_output_table(
|
|
158
158
|
trac.F("region", trac.STRING, label="Customer home region", categorical=True),
|
|
159
|
-
trac.F("
|
|
159
|
+
trac.F("total_lending", trac.FLOAT, label="Total lending (GBP)"),
|
|
160
160
|
label="Loans by region")
|
|
161
161
|
|
|
162
162
|
return {"loans_by_region": loans_by_region}
|
|
163
163
|
|
|
164
164
|
def run_model(self, ctx: trac.TracContext):
|
|
165
|
-
|
|
165
|
+
|
|
166
166
|
# Parameters and inputs are loaded and validated by TRAC
|
|
167
167
|
exchange_rate = ctx.get_parameter("exchange_rate")
|
|
168
168
|
customer_loans = ctx.get_pandas_table("customer_loans")
|
|
@@ -171,11 +171,11 @@ class QuickStartModel(trac.TracModel):
|
|
|
171
171
|
customer_loans["loan_amount_gbp"] = customer_loans["loan_amount"] * exchange_rate
|
|
172
172
|
|
|
173
173
|
loans_by_region = customer_loans \
|
|
174
|
-
.groupby("region", as_index=False) \
|
|
175
|
-
.aggregate(
|
|
174
|
+
.groupby("region", observed=True, as_index=False) \
|
|
175
|
+
.aggregate(total_lending=("loan_amount_gbp", "sum"))
|
|
176
176
|
|
|
177
177
|
# Logs written to ctx.log are captured by the platform
|
|
178
|
-
ctx.log().info("Aggregated loans for
|
|
178
|
+
ctx.log().info("Aggregated loans for %d regions", len(loans_by_region))
|
|
179
179
|
|
|
180
180
|
# Outputs are handed back to TRAC for validation and saving
|
|
181
181
|
ctx.put_pandas_table("loans_by_region", loans_by_region)
|
|
@@ -45,7 +45,7 @@ For a complete guide to writing models in the TRAC framework, see the
|
|
|
45
45
|
|
|
46
46
|
## 📦 Requirements
|
|
47
47
|
|
|
48
|
-
* **Python :** 3.
|
|
48
|
+
* **Python :** 3.9 or later
|
|
49
49
|
* **Tools :** Any popular IDE (PyCharm, VS Code, etc.)
|
|
50
50
|
* **Pandas :** Version 1.2 and later are supported
|
|
51
51
|
* **Polars :** Version 1.0 and later are supported
|
|
@@ -72,35 +72,35 @@ import tracdap.rt.api as trac
|
|
|
72
72
|
class QuickStartModel(trac.TracModel):
|
|
73
73
|
|
|
74
74
|
def define_parameters(self):
|
|
75
|
-
|
|
75
|
+
|
|
76
76
|
# Define any parameters the model will use
|
|
77
77
|
return trac.define_parameters(
|
|
78
78
|
trac.P("exchange_rate", trac.FLOAT, "EUR / GBP exchange rate")
|
|
79
79
|
)
|
|
80
80
|
|
|
81
81
|
def define_inputs(self):
|
|
82
|
-
|
|
82
|
+
|
|
83
83
|
# Define an input table with the columns and data types that the model needs
|
|
84
84
|
customer_loans = trac.define_input_table(
|
|
85
85
|
trac.F("id", trac.STRING, label="Customer account ID", business_key=True),
|
|
86
86
|
trac.F("region", trac.STRING, label="Customer home region", categorical=True),
|
|
87
|
-
trac.F("loan_amount", trac.FLOAT, label="Principal loan amount"),
|
|
87
|
+
trac.F("loan_amount", trac.FLOAT, label="Principal loan amount (EUR)"),
|
|
88
88
|
label="Customer loans data")
|
|
89
89
|
|
|
90
90
|
return {"customer_loans": customer_loans}
|
|
91
91
|
|
|
92
92
|
def define_outputs(self):
|
|
93
|
-
|
|
93
|
+
|
|
94
94
|
# Define an output table with the columns and data types that the model will produce
|
|
95
95
|
loans_by_region = trac.define_output_table(
|
|
96
96
|
trac.F("region", trac.STRING, label="Customer home region", categorical=True),
|
|
97
|
-
trac.F("
|
|
97
|
+
trac.F("total_lending", trac.FLOAT, label="Total lending (GBP)"),
|
|
98
98
|
label="Loans by region")
|
|
99
99
|
|
|
100
100
|
return {"loans_by_region": loans_by_region}
|
|
101
101
|
|
|
102
102
|
def run_model(self, ctx: trac.TracContext):
|
|
103
|
-
|
|
103
|
+
|
|
104
104
|
# Parameters and inputs are loaded and validated by TRAC
|
|
105
105
|
exchange_rate = ctx.get_parameter("exchange_rate")
|
|
106
106
|
customer_loans = ctx.get_pandas_table("customer_loans")
|
|
@@ -109,11 +109,11 @@ class QuickStartModel(trac.TracModel):
|
|
|
109
109
|
customer_loans["loan_amount_gbp"] = customer_loans["loan_amount"] * exchange_rate
|
|
110
110
|
|
|
111
111
|
loans_by_region = customer_loans \
|
|
112
|
-
.groupby("region", as_index=False) \
|
|
113
|
-
.aggregate(
|
|
112
|
+
.groupby("region", observed=True, as_index=False) \
|
|
113
|
+
.aggregate(total_lending=("loan_amount_gbp", "sum"))
|
|
114
114
|
|
|
115
115
|
# Logs written to ctx.log are captured by the platform
|
|
116
|
-
ctx.log().info("Aggregated loans for
|
|
116
|
+
ctx.log().info("Aggregated loans for %d regions", len(loans_by_region))
|
|
117
117
|
|
|
118
118
|
# Outputs are handed back to TRAC for validation and saving
|
|
119
119
|
ctx.put_pandas_table("loans_by_region", loans_by_region)
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
[metadata]
|
|
2
2
|
name = tracdap-runtime
|
|
3
|
-
version = 0.9.
|
|
3
|
+
version = 0.9.3.dev1
|
|
4
4
|
license = Apache-2.0
|
|
5
5
|
platform = any
|
|
6
6
|
description = Portable, production-grade models in Python
|
|
@@ -9,8 +9,8 @@ long_description_content_type = text/markdown
|
|
|
9
9
|
url = https://www.fintrac.co.uk/
|
|
10
10
|
project_urls =
|
|
11
11
|
Documentation = https://docs.fintrac.co.uk/versions/latest/modelling
|
|
12
|
-
Source Code = https://github.com/
|
|
13
|
-
Issue Tracker = https://github.com/
|
|
12
|
+
Source Code = https://github.com/finos/tracdap
|
|
13
|
+
Issue Tracker = https://github.com/finos/tracdap/issues
|
|
14
14
|
classifiers =
|
|
15
15
|
Operating System :: OS Independent
|
|
16
16
|
Programming Language :: Python :: 3
|
|
@@ -1,14 +1,14 @@
|
|
|
1
1
|
Metadata-Version: 2.4
|
|
2
2
|
Name: tracdap-runtime
|
|
3
|
-
Version: 0.9.
|
|
3
|
+
Version: 0.9.3.dev1
|
|
4
4
|
Summary: Portable, production-grade models in Python
|
|
5
5
|
Home-page: https://www.fintrac.co.uk/
|
|
6
6
|
Author: Martin Traverse
|
|
7
7
|
Author-email: martin@fintrac.co.uk
|
|
8
8
|
License: Apache-2.0
|
|
9
9
|
Project-URL: Documentation, https://docs.fintrac.co.uk/versions/latest/modelling
|
|
10
|
-
Project-URL: Source Code, https://github.com/
|
|
11
|
-
Project-URL: Issue Tracker, https://github.com/
|
|
10
|
+
Project-URL: Source Code, https://github.com/finos/tracdap
|
|
11
|
+
Project-URL: Issue Tracker, https://github.com/finos/tracdap/issues
|
|
12
12
|
Platform: any
|
|
13
13
|
Classifier: Operating System :: OS Independent
|
|
14
14
|
Classifier: Programming Language :: Python :: 3
|
|
@@ -107,7 +107,7 @@ For a complete guide to writing models in the TRAC framework, see the
|
|
|
107
107
|
|
|
108
108
|
## 📦 Requirements
|
|
109
109
|
|
|
110
|
-
* **Python :** 3.
|
|
110
|
+
* **Python :** 3.9 or later
|
|
111
111
|
* **Tools :** Any popular IDE (PyCharm, VS Code, etc.)
|
|
112
112
|
* **Pandas :** Version 1.2 and later are supported
|
|
113
113
|
* **Polars :** Version 1.0 and later are supported
|
|
@@ -134,35 +134,35 @@ import tracdap.rt.api as trac
|
|
|
134
134
|
class QuickStartModel(trac.TracModel):
|
|
135
135
|
|
|
136
136
|
def define_parameters(self):
|
|
137
|
-
|
|
137
|
+
|
|
138
138
|
# Define any parameters the model will use
|
|
139
139
|
return trac.define_parameters(
|
|
140
140
|
trac.P("exchange_rate", trac.FLOAT, "EUR / GBP exchange rate")
|
|
141
141
|
)
|
|
142
142
|
|
|
143
143
|
def define_inputs(self):
|
|
144
|
-
|
|
144
|
+
|
|
145
145
|
# Define an input table with the columns and data types that the model needs
|
|
146
146
|
customer_loans = trac.define_input_table(
|
|
147
147
|
trac.F("id", trac.STRING, label="Customer account ID", business_key=True),
|
|
148
148
|
trac.F("region", trac.STRING, label="Customer home region", categorical=True),
|
|
149
|
-
trac.F("loan_amount", trac.FLOAT, label="Principal loan amount"),
|
|
149
|
+
trac.F("loan_amount", trac.FLOAT, label="Principal loan amount (EUR)"),
|
|
150
150
|
label="Customer loans data")
|
|
151
151
|
|
|
152
152
|
return {"customer_loans": customer_loans}
|
|
153
153
|
|
|
154
154
|
def define_outputs(self):
|
|
155
|
-
|
|
155
|
+
|
|
156
156
|
# Define an output table with the columns and data types that the model will produce
|
|
157
157
|
loans_by_region = trac.define_output_table(
|
|
158
158
|
trac.F("region", trac.STRING, label="Customer home region", categorical=True),
|
|
159
|
-
trac.F("
|
|
159
|
+
trac.F("total_lending", trac.FLOAT, label="Total lending (GBP)"),
|
|
160
160
|
label="Loans by region")
|
|
161
161
|
|
|
162
162
|
return {"loans_by_region": loans_by_region}
|
|
163
163
|
|
|
164
164
|
def run_model(self, ctx: trac.TracContext):
|
|
165
|
-
|
|
165
|
+
|
|
166
166
|
# Parameters and inputs are loaded and validated by TRAC
|
|
167
167
|
exchange_rate = ctx.get_parameter("exchange_rate")
|
|
168
168
|
customer_loans = ctx.get_pandas_table("customer_loans")
|
|
@@ -171,11 +171,11 @@ class QuickStartModel(trac.TracModel):
|
|
|
171
171
|
customer_loans["loan_amount_gbp"] = customer_loans["loan_amount"] * exchange_rate
|
|
172
172
|
|
|
173
173
|
loans_by_region = customer_loans \
|
|
174
|
-
.groupby("region", as_index=False) \
|
|
175
|
-
.aggregate(
|
|
174
|
+
.groupby("region", observed=True, as_index=False) \
|
|
175
|
+
.aggregate(total_lending=("loan_amount_gbp", "sum"))
|
|
176
176
|
|
|
177
177
|
# Logs written to ctx.log are captured by the platform
|
|
178
|
-
ctx.log().info("Aggregated loans for
|
|
178
|
+
ctx.log().info("Aggregated loans for %d regions", len(loans_by_region))
|
|
179
179
|
|
|
180
180
|
# Outputs are handed back to TRAC for validation and saving
|
|
181
181
|
ctx.put_pandas_table("loans_by_region", loans_by_region)
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/core/__init__.py
RENAMED
|
File without changes
|
{tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/core/config_parser.py
RENAMED
|
File without changes
|
|
File without changes
|
{tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/core/guard_rails.py
RENAMED
|
File without changes
|
{tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/core/logging.py
RENAMED
|
File without changes
|
{tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/core/models.py
RENAMED
|
File without changes
|
{tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/core/repos.py
RENAMED
|
File without changes
|
{tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/core/schemas.py
RENAMED
|
File without changes
|
|
File without changes
|
{tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/core/storage.py
RENAMED
|
File without changes
|
{tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/core/struct.py
RENAMED
|
File without changes
|
{tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/core/type_system.py
RENAMED
|
File without changes
|
|
File without changes
|
{tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/core/validation.py
RENAMED
|
File without changes
|
{tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/exec/__init__.py
RENAMED
|
File without changes
|
{tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/exec/actors.py
RENAMED
|
File without changes
|
{tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/exec/context.py
RENAMED
|
File without changes
|
{tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/exec/dev_mode.py
RENAMED
|
File without changes
|
{tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/exec/engine.py
RENAMED
|
File without changes
|
{tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/exec/functions.py
RENAMED
|
File without changes
|
{tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/exec/graph.py
RENAMED
|
File without changes
|
{tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/exec/graph_builder.py
RENAMED
|
File without changes
|
{tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/ext/__init__.py
RENAMED
|
File without changes
|
|
File without changes
|
{tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/ext/storage.py
RENAMED
|
File without changes
|
{tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/grpc/__init__.py
RENAMED
|
File without changes
|
{tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/grpc/codec.py
RENAMED
|
File without changes
|
{tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/grpc/server.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_impl/static_api.py
RENAMED
|
File without changes
|
{tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_plugins/__init__.py
RENAMED
|
File without changes
|
{tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_plugins/_helpers.py
RENAMED
|
File without changes
|
{tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_plugins/config_local.py
RENAMED
|
File without changes
|
{tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_plugins/format_arrow.py
RENAMED
|
File without changes
|
{tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_plugins/format_csv.py
RENAMED
|
File without changes
|
{tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_plugins/format_parquet.py
RENAMED
|
File without changes
|
{tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_plugins/repo_git.py
RENAMED
|
File without changes
|
{tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_plugins/repo_local.py
RENAMED
|
File without changes
|
{tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_plugins/repo_pypi.py
RENAMED
|
File without changes
|
{tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_plugins/storage_aws.py
RENAMED
|
File without changes
|
{tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_plugins/storage_azure.py
RENAMED
|
File without changes
|
{tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_plugins/storage_gcp.py
RENAMED
|
File without changes
|
{tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_plugins/storage_local.py
RENAMED
|
File without changes
|
{tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/_plugins/storage_sql.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/api/experimental.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/metadata/__init__.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/metadata/object_id.py
RENAMED
|
File without changes
|
{tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/metadata/resource.py
RENAMED
|
File without changes
|
|
File without changes
|
{tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/metadata/storage.py
RENAMED
|
File without changes
|
|
File without changes
|
{tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/src/tracdap/rt/metadata/tag_update.py
RENAMED
|
File without changes
|
|
File without changes
|
{tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/tracdap_runtime.egg-info/SOURCES.txt
RENAMED
|
File without changes
|
|
File without changes
|
{tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/tracdap_runtime.egg-info/requires.txt
RENAMED
|
File without changes
|
{tracdap_runtime-0.9.2.dev1 → tracdap_runtime-0.9.3.dev1}/tracdap_runtime.egg-info/top_level.txt
RENAMED
|
File without changes
|