relationalai 0.13.5__py3-none-any.whl → 1.0.0a2__py3-none-any.whl

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.
Files changed (856) hide show
  1. relationalai/__init__.py +1 -256
  2. relationalai/config/__init__.py +56 -0
  3. relationalai/config/config.py +289 -0
  4. relationalai/config/config_fields.py +86 -0
  5. relationalai/config/connections/__init__.py +46 -0
  6. relationalai/config/connections/base.py +23 -0
  7. relationalai/config/connections/duckdb.py +29 -0
  8. relationalai/config/connections/snowflake.py +243 -0
  9. relationalai/config/external/__init__.py +17 -0
  10. relationalai/config/external/dbt_converter.py +101 -0
  11. relationalai/config/external/dbt_models.py +93 -0
  12. relationalai/config/external/snowflake_converter.py +41 -0
  13. relationalai/config/external/snowflake_models.py +85 -0
  14. relationalai/config/external/utils.py +19 -0
  15. relationalai/config/shims.py +1 -0
  16. relationalai/semantics/__init__.py +146 -22
  17. relationalai/semantics/backends/lqp/annotations.py +11 -0
  18. relationalai/semantics/backends/sql/sql_compiler.py +327 -0
  19. relationalai/semantics/frontend/base.py +1719 -0
  20. relationalai/semantics/frontend/core.py +179 -0
  21. relationalai/semantics/frontend/front_compiler.py +1316 -0
  22. relationalai/semantics/frontend/pprint.py +408 -0
  23. relationalai/semantics/metamodel/__init__.py +6 -40
  24. relationalai/semantics/metamodel/builtins.py +206 -772
  25. relationalai/semantics/metamodel/metamodel.py +465 -0
  26. relationalai/semantics/metamodel/metamodel_analyzer.py +519 -0
  27. relationalai/semantics/metamodel/pprint.py +414 -0
  28. relationalai/semantics/metamodel/rewriter.py +266 -0
  29. relationalai/semantics/metamodel/typer.py +1213 -0
  30. relationalai/semantics/std/__init__.py +60 -40
  31. relationalai/semantics/std/aggregates.py +148 -0
  32. relationalai/semantics/std/common.py +44 -0
  33. relationalai/semantics/std/constraints.py +37 -43
  34. relationalai/semantics/std/datetime.py +249 -135
  35. relationalai/semantics/std/decimals.py +45 -52
  36. relationalai/semantics/std/floats.py +13 -5
  37. relationalai/semantics/std/integers.py +26 -11
  38. relationalai/semantics/std/math.py +183 -112
  39. relationalai/semantics/std/numbers.py +86 -0
  40. relationalai/semantics/std/re.py +80 -62
  41. relationalai/semantics/std/strings.py +101 -46
  42. relationalai/shims/executor.py +179 -0
  43. relationalai/shims/helpers.py +126 -0
  44. relationalai/shims/hoister.py +221 -0
  45. relationalai/shims/mm2v0.py +1394 -0
  46. relationalai/tools/cli/__init__.py +6 -0
  47. relationalai/tools/cli/cli.py +90 -0
  48. relationalai/tools/cli/components/__init__.py +5 -0
  49. relationalai/tools/cli/components/progress_reader.py +1524 -0
  50. relationalai/tools/cli/components/utils.py +58 -0
  51. relationalai/tools/cli/config_template.py +45 -0
  52. relationalai/tools/cli/dev.py +19 -0
  53. relationalai/tools/debugger.py +289 -183
  54. relationalai/tools/typer_debugger.py +93 -0
  55. relationalai/util/dataclasses.py +43 -0
  56. relationalai/util/docutils.py +40 -0
  57. relationalai/util/error.py +199 -0
  58. relationalai/util/format.py +48 -109
  59. relationalai/util/naming.py +145 -0
  60. relationalai/util/python.py +35 -0
  61. relationalai/util/runtime.py +156 -0
  62. relationalai/util/schema.py +197 -0
  63. relationalai/util/source.py +185 -0
  64. relationalai/util/structures.py +163 -0
  65. relationalai/util/tracing.py +261 -0
  66. relationalai-1.0.0a2.dist-info/METADATA +44 -0
  67. relationalai-1.0.0a2.dist-info/RECORD +489 -0
  68. relationalai-1.0.0a2.dist-info/WHEEL +5 -0
  69. relationalai-1.0.0a2.dist-info/entry_points.txt +3 -0
  70. relationalai-1.0.0a2.dist-info/top_level.txt +2 -0
  71. v0/relationalai/__init__.py +216 -0
  72. v0/relationalai/clients/__init__.py +5 -0
  73. v0/relationalai/clients/azure.py +477 -0
  74. v0/relationalai/clients/client.py +912 -0
  75. v0/relationalai/clients/config.py +673 -0
  76. v0/relationalai/clients/direct_access_client.py +118 -0
  77. v0/relationalai/clients/hash_util.py +31 -0
  78. v0/relationalai/clients/local.py +571 -0
  79. v0/relationalai/clients/profile_polling.py +73 -0
  80. v0/relationalai/clients/result_helpers.py +420 -0
  81. v0/relationalai/clients/snowflake.py +3869 -0
  82. v0/relationalai/clients/types.py +113 -0
  83. v0/relationalai/clients/use_index_poller.py +980 -0
  84. v0/relationalai/clients/util.py +356 -0
  85. v0/relationalai/debugging.py +389 -0
  86. v0/relationalai/dsl.py +1749 -0
  87. v0/relationalai/early_access/builder/__init__.py +30 -0
  88. v0/relationalai/early_access/builder/builder/__init__.py +35 -0
  89. v0/relationalai/early_access/builder/snowflake/__init__.py +12 -0
  90. v0/relationalai/early_access/builder/std/__init__.py +25 -0
  91. v0/relationalai/early_access/builder/std/decimals/__init__.py +12 -0
  92. v0/relationalai/early_access/builder/std/integers/__init__.py +12 -0
  93. v0/relationalai/early_access/builder/std/math/__init__.py +12 -0
  94. v0/relationalai/early_access/builder/std/strings/__init__.py +14 -0
  95. v0/relationalai/early_access/devtools/__init__.py +12 -0
  96. v0/relationalai/early_access/devtools/benchmark_lqp/__init__.py +12 -0
  97. v0/relationalai/early_access/devtools/extract_lqp/__init__.py +12 -0
  98. v0/relationalai/early_access/dsl/adapters/orm/adapter_qb.py +427 -0
  99. v0/relationalai/early_access/dsl/adapters/orm/parser.py +636 -0
  100. v0/relationalai/early_access/dsl/adapters/owl/adapter.py +176 -0
  101. v0/relationalai/early_access/dsl/adapters/owl/parser.py +160 -0
  102. v0/relationalai/early_access/dsl/bindings/common.py +402 -0
  103. v0/relationalai/early_access/dsl/bindings/csv.py +170 -0
  104. v0/relationalai/early_access/dsl/bindings/legacy/binding_models.py +143 -0
  105. v0/relationalai/early_access/dsl/bindings/snowflake.py +64 -0
  106. v0/relationalai/early_access/dsl/codegen/binder.py +411 -0
  107. v0/relationalai/early_access/dsl/codegen/common.py +79 -0
  108. v0/relationalai/early_access/dsl/codegen/helpers.py +23 -0
  109. v0/relationalai/early_access/dsl/codegen/relations.py +700 -0
  110. v0/relationalai/early_access/dsl/codegen/weaver.py +417 -0
  111. v0/relationalai/early_access/dsl/core/builders/__init__.py +47 -0
  112. v0/relationalai/early_access/dsl/core/builders/logic.py +19 -0
  113. v0/relationalai/early_access/dsl/core/builders/scalar_constraint.py +11 -0
  114. v0/relationalai/early_access/dsl/core/constraints/predicate/atomic.py +455 -0
  115. v0/relationalai/early_access/dsl/core/constraints/predicate/universal.py +73 -0
  116. v0/relationalai/early_access/dsl/core/constraints/scalar.py +310 -0
  117. v0/relationalai/early_access/dsl/core/context.py +13 -0
  118. v0/relationalai/early_access/dsl/core/cset.py +132 -0
  119. v0/relationalai/early_access/dsl/core/exprs/__init__.py +116 -0
  120. v0/relationalai/early_access/dsl/core/exprs/relational.py +18 -0
  121. v0/relationalai/early_access/dsl/core/exprs/scalar.py +412 -0
  122. v0/relationalai/early_access/dsl/core/instances.py +44 -0
  123. v0/relationalai/early_access/dsl/core/logic/__init__.py +193 -0
  124. v0/relationalai/early_access/dsl/core/logic/aggregation.py +98 -0
  125. v0/relationalai/early_access/dsl/core/logic/exists.py +223 -0
  126. v0/relationalai/early_access/dsl/core/logic/helper.py +163 -0
  127. v0/relationalai/early_access/dsl/core/namespaces.py +32 -0
  128. v0/relationalai/early_access/dsl/core/relations.py +276 -0
  129. v0/relationalai/early_access/dsl/core/rules.py +112 -0
  130. v0/relationalai/early_access/dsl/core/std/__init__.py +45 -0
  131. v0/relationalai/early_access/dsl/core/temporal/recall.py +6 -0
  132. v0/relationalai/early_access/dsl/core/types/__init__.py +270 -0
  133. v0/relationalai/early_access/dsl/core/types/concepts.py +128 -0
  134. v0/relationalai/early_access/dsl/core/types/constrained/__init__.py +267 -0
  135. v0/relationalai/early_access/dsl/core/types/constrained/nominal.py +143 -0
  136. v0/relationalai/early_access/dsl/core/types/constrained/subtype.py +124 -0
  137. v0/relationalai/early_access/dsl/core/types/standard.py +92 -0
  138. v0/relationalai/early_access/dsl/core/types/unconstrained.py +50 -0
  139. v0/relationalai/early_access/dsl/core/types/variables.py +203 -0
  140. v0/relationalai/early_access/dsl/ir/compiler.py +318 -0
  141. v0/relationalai/early_access/dsl/ir/executor.py +260 -0
  142. v0/relationalai/early_access/dsl/ontologies/constraints.py +88 -0
  143. v0/relationalai/early_access/dsl/ontologies/export.py +30 -0
  144. v0/relationalai/early_access/dsl/ontologies/models.py +453 -0
  145. v0/relationalai/early_access/dsl/ontologies/python_printer.py +303 -0
  146. v0/relationalai/early_access/dsl/ontologies/readings.py +60 -0
  147. v0/relationalai/early_access/dsl/ontologies/relationships.py +322 -0
  148. v0/relationalai/early_access/dsl/ontologies/roles.py +87 -0
  149. v0/relationalai/early_access/dsl/ontologies/subtyping.py +55 -0
  150. v0/relationalai/early_access/dsl/orm/constraints.py +438 -0
  151. v0/relationalai/early_access/dsl/orm/measures/dimensions.py +200 -0
  152. v0/relationalai/early_access/dsl/orm/measures/initializer.py +16 -0
  153. v0/relationalai/early_access/dsl/orm/measures/measure_rules.py +275 -0
  154. v0/relationalai/early_access/dsl/orm/measures/measures.py +299 -0
  155. v0/relationalai/early_access/dsl/orm/measures/role_exprs.py +268 -0
  156. v0/relationalai/early_access/dsl/orm/models.py +256 -0
  157. v0/relationalai/early_access/dsl/orm/object_oriented_printer.py +344 -0
  158. v0/relationalai/early_access/dsl/orm/printer.py +469 -0
  159. v0/relationalai/early_access/dsl/orm/reasoners.py +480 -0
  160. v0/relationalai/early_access/dsl/orm/relations.py +19 -0
  161. v0/relationalai/early_access/dsl/orm/relationships.py +251 -0
  162. v0/relationalai/early_access/dsl/orm/types.py +42 -0
  163. v0/relationalai/early_access/dsl/orm/utils.py +79 -0
  164. v0/relationalai/early_access/dsl/orm/verb.py +204 -0
  165. v0/relationalai/early_access/dsl/physical_metadata/tables.py +133 -0
  166. v0/relationalai/early_access/dsl/relations.py +170 -0
  167. v0/relationalai/early_access/dsl/rulesets.py +69 -0
  168. v0/relationalai/early_access/dsl/schemas/__init__.py +450 -0
  169. v0/relationalai/early_access/dsl/schemas/builder.py +48 -0
  170. v0/relationalai/early_access/dsl/schemas/comp_names.py +51 -0
  171. v0/relationalai/early_access/dsl/schemas/components.py +203 -0
  172. v0/relationalai/early_access/dsl/schemas/contexts.py +156 -0
  173. v0/relationalai/early_access/dsl/schemas/exprs.py +89 -0
  174. v0/relationalai/early_access/dsl/schemas/fragments.py +464 -0
  175. v0/relationalai/early_access/dsl/serialization.py +79 -0
  176. v0/relationalai/early_access/dsl/serialize/exporter.py +163 -0
  177. v0/relationalai/early_access/dsl/snow/api.py +104 -0
  178. v0/relationalai/early_access/dsl/snow/common.py +76 -0
  179. v0/relationalai/early_access/dsl/state_mgmt/__init__.py +129 -0
  180. v0/relationalai/early_access/dsl/state_mgmt/state_charts.py +125 -0
  181. v0/relationalai/early_access/dsl/state_mgmt/transitions.py +130 -0
  182. v0/relationalai/early_access/dsl/types/__init__.py +40 -0
  183. v0/relationalai/early_access/dsl/types/concepts.py +12 -0
  184. v0/relationalai/early_access/dsl/types/entities.py +135 -0
  185. v0/relationalai/early_access/dsl/types/values.py +17 -0
  186. v0/relationalai/early_access/dsl/utils.py +102 -0
  187. v0/relationalai/early_access/graphs/__init__.py +13 -0
  188. v0/relationalai/early_access/lqp/__init__.py +12 -0
  189. v0/relationalai/early_access/lqp/compiler/__init__.py +12 -0
  190. v0/relationalai/early_access/lqp/constructors/__init__.py +18 -0
  191. v0/relationalai/early_access/lqp/executor/__init__.py +12 -0
  192. v0/relationalai/early_access/lqp/ir/__init__.py +12 -0
  193. v0/relationalai/early_access/lqp/passes/__init__.py +12 -0
  194. v0/relationalai/early_access/lqp/pragmas/__init__.py +12 -0
  195. v0/relationalai/early_access/lqp/primitives/__init__.py +12 -0
  196. v0/relationalai/early_access/lqp/types/__init__.py +12 -0
  197. v0/relationalai/early_access/lqp/utils/__init__.py +12 -0
  198. v0/relationalai/early_access/lqp/validators/__init__.py +12 -0
  199. v0/relationalai/early_access/metamodel/__init__.py +58 -0
  200. v0/relationalai/early_access/metamodel/builtins/__init__.py +12 -0
  201. v0/relationalai/early_access/metamodel/compiler/__init__.py +12 -0
  202. v0/relationalai/early_access/metamodel/dependency/__init__.py +12 -0
  203. v0/relationalai/early_access/metamodel/factory/__init__.py +17 -0
  204. v0/relationalai/early_access/metamodel/helpers/__init__.py +12 -0
  205. v0/relationalai/early_access/metamodel/ir/__init__.py +14 -0
  206. v0/relationalai/early_access/metamodel/rewrite/__init__.py +7 -0
  207. v0/relationalai/early_access/metamodel/typer/__init__.py +3 -0
  208. v0/relationalai/early_access/metamodel/typer/typer/__init__.py +12 -0
  209. v0/relationalai/early_access/metamodel/types/__init__.py +15 -0
  210. v0/relationalai/early_access/metamodel/util/__init__.py +15 -0
  211. v0/relationalai/early_access/metamodel/visitor/__init__.py +12 -0
  212. v0/relationalai/early_access/rel/__init__.py +12 -0
  213. v0/relationalai/early_access/rel/executor/__init__.py +12 -0
  214. v0/relationalai/early_access/rel/rel_utils/__init__.py +12 -0
  215. v0/relationalai/early_access/rel/rewrite/__init__.py +7 -0
  216. v0/relationalai/early_access/solvers/__init__.py +19 -0
  217. v0/relationalai/early_access/sql/__init__.py +11 -0
  218. v0/relationalai/early_access/sql/executor/__init__.py +3 -0
  219. v0/relationalai/early_access/sql/rewrite/__init__.py +3 -0
  220. v0/relationalai/early_access/tests/logging/__init__.py +12 -0
  221. v0/relationalai/early_access/tests/test_snapshot_base/__init__.py +12 -0
  222. v0/relationalai/early_access/tests/utils/__init__.py +12 -0
  223. v0/relationalai/environments/__init__.py +35 -0
  224. v0/relationalai/environments/base.py +381 -0
  225. v0/relationalai/environments/colab.py +14 -0
  226. v0/relationalai/environments/generic.py +71 -0
  227. v0/relationalai/environments/ipython.py +68 -0
  228. v0/relationalai/environments/jupyter.py +9 -0
  229. v0/relationalai/environments/snowbook.py +169 -0
  230. v0/relationalai/errors.py +2478 -0
  231. v0/relationalai/experimental/SF.py +38 -0
  232. v0/relationalai/experimental/inspect.py +47 -0
  233. v0/relationalai/experimental/pathfinder/__init__.py +158 -0
  234. v0/relationalai/experimental/pathfinder/api.py +160 -0
  235. v0/relationalai/experimental/pathfinder/automaton.py +584 -0
  236. v0/relationalai/experimental/pathfinder/bridge.py +226 -0
  237. v0/relationalai/experimental/pathfinder/compiler.py +416 -0
  238. v0/relationalai/experimental/pathfinder/datalog.py +214 -0
  239. v0/relationalai/experimental/pathfinder/diagnostics.py +56 -0
  240. v0/relationalai/experimental/pathfinder/filter.py +236 -0
  241. v0/relationalai/experimental/pathfinder/glushkov.py +439 -0
  242. v0/relationalai/experimental/pathfinder/options.py +265 -0
  243. v0/relationalai/experimental/pathfinder/rpq.py +344 -0
  244. v0/relationalai/experimental/pathfinder/transition.py +200 -0
  245. v0/relationalai/experimental/pathfinder/utils.py +26 -0
  246. v0/relationalai/experimental/paths/api.py +143 -0
  247. v0/relationalai/experimental/paths/benchmarks/grid_graph.py +37 -0
  248. v0/relationalai/experimental/paths/examples/basic_example.py +40 -0
  249. v0/relationalai/experimental/paths/examples/minimal_engine_warmup.py +3 -0
  250. v0/relationalai/experimental/paths/examples/movie_example.py +77 -0
  251. v0/relationalai/experimental/paths/examples/paths_benchmark.py +115 -0
  252. v0/relationalai/experimental/paths/examples/paths_example.py +116 -0
  253. v0/relationalai/experimental/paths/examples/pattern_to_automaton.py +28 -0
  254. v0/relationalai/experimental/paths/find_paths_via_automaton.py +85 -0
  255. v0/relationalai/experimental/paths/graph.py +185 -0
  256. v0/relationalai/experimental/paths/path_algorithms/find_paths.py +280 -0
  257. v0/relationalai/experimental/paths/path_algorithms/one_sided_ball_repetition.py +26 -0
  258. v0/relationalai/experimental/paths/path_algorithms/one_sided_ball_upto.py +111 -0
  259. v0/relationalai/experimental/paths/path_algorithms/single.py +59 -0
  260. v0/relationalai/experimental/paths/path_algorithms/two_sided_balls_repetition.py +39 -0
  261. v0/relationalai/experimental/paths/path_algorithms/two_sided_balls_upto.py +103 -0
  262. v0/relationalai/experimental/paths/path_algorithms/usp-old.py +130 -0
  263. v0/relationalai/experimental/paths/path_algorithms/usp-tuple.py +183 -0
  264. v0/relationalai/experimental/paths/path_algorithms/usp.py +150 -0
  265. v0/relationalai/experimental/paths/product_graph.py +93 -0
  266. v0/relationalai/experimental/paths/rpq/automaton.py +584 -0
  267. v0/relationalai/experimental/paths/rpq/diagnostics.py +56 -0
  268. v0/relationalai/experimental/paths/rpq/rpq.py +378 -0
  269. v0/relationalai/experimental/paths/tests/tests_limit_sp_max_length.py +90 -0
  270. v0/relationalai/experimental/paths/tests/tests_limit_sp_multiple.py +119 -0
  271. v0/relationalai/experimental/paths/tests/tests_limit_sp_single.py +104 -0
  272. v0/relationalai/experimental/paths/tests/tests_limit_walks_multiple.py +113 -0
  273. v0/relationalai/experimental/paths/tests/tests_limit_walks_single.py +149 -0
  274. v0/relationalai/experimental/paths/tests/tests_one_sided_ball_repetition_multiple.py +70 -0
  275. v0/relationalai/experimental/paths/tests/tests_one_sided_ball_repetition_single.py +64 -0
  276. v0/relationalai/experimental/paths/tests/tests_one_sided_ball_upto_multiple.py +115 -0
  277. v0/relationalai/experimental/paths/tests/tests_one_sided_ball_upto_single.py +75 -0
  278. v0/relationalai/experimental/paths/tests/tests_single_paths.py +152 -0
  279. v0/relationalai/experimental/paths/tests/tests_single_walks.py +208 -0
  280. v0/relationalai/experimental/paths/tests/tests_single_walks_undirected.py +297 -0
  281. v0/relationalai/experimental/paths/tests/tests_two_sided_balls_repetition_multiple.py +107 -0
  282. v0/relationalai/experimental/paths/tests/tests_two_sided_balls_repetition_single.py +76 -0
  283. v0/relationalai/experimental/paths/tests/tests_two_sided_balls_upto_multiple.py +76 -0
  284. v0/relationalai/experimental/paths/tests/tests_two_sided_balls_upto_single.py +110 -0
  285. v0/relationalai/experimental/paths/tests/tests_usp_nsp_multiple.py +229 -0
  286. v0/relationalai/experimental/paths/tests/tests_usp_nsp_single.py +108 -0
  287. v0/relationalai/experimental/paths/tree_agg.py +168 -0
  288. v0/relationalai/experimental/paths/utilities/iterators.py +27 -0
  289. v0/relationalai/experimental/paths/utilities/prefix_sum.py +91 -0
  290. v0/relationalai/experimental/solvers.py +1087 -0
  291. v0/relationalai/loaders/csv.py +195 -0
  292. v0/relationalai/loaders/loader.py +177 -0
  293. v0/relationalai/loaders/types.py +23 -0
  294. v0/relationalai/rel_emitter.py +373 -0
  295. v0/relationalai/rel_utils.py +185 -0
  296. v0/relationalai/semantics/__init__.py +29 -0
  297. v0/relationalai/semantics/devtools/benchmark_lqp.py +536 -0
  298. v0/relationalai/semantics/devtools/compilation_manager.py +294 -0
  299. v0/relationalai/semantics/devtools/extract_lqp.py +110 -0
  300. v0/relationalai/semantics/internal/internal.py +3785 -0
  301. v0/relationalai/semantics/internal/snowflake.py +325 -0
  302. v0/relationalai/semantics/lqp/builtins.py +16 -0
  303. v0/relationalai/semantics/lqp/compiler.py +22 -0
  304. v0/relationalai/semantics/lqp/constructors.py +68 -0
  305. v0/relationalai/semantics/lqp/executor.py +474 -0
  306. v0/relationalai/semantics/lqp/intrinsics.py +24 -0
  307. v0/relationalai/semantics/lqp/ir.py +124 -0
  308. v0/relationalai/semantics/lqp/model2lqp.py +877 -0
  309. v0/relationalai/semantics/lqp/passes.py +680 -0
  310. v0/relationalai/semantics/lqp/primitives.py +252 -0
  311. v0/relationalai/semantics/lqp/result_helpers.py +202 -0
  312. v0/relationalai/semantics/lqp/rewrite/__init__.py +18 -0
  313. v0/relationalai/semantics/lqp/rewrite/annotate_constraints.py +57 -0
  314. v0/relationalai/semantics/lqp/rewrite/cdc.py +216 -0
  315. v0/relationalai/semantics/lqp/rewrite/extract_common.py +338 -0
  316. v0/relationalai/semantics/lqp/rewrite/extract_keys.py +490 -0
  317. v0/relationalai/semantics/lqp/rewrite/function_annotations.py +114 -0
  318. v0/relationalai/semantics/lqp/rewrite/functional_dependencies.py +314 -0
  319. v0/relationalai/semantics/lqp/rewrite/quantify_vars.py +296 -0
  320. v0/relationalai/semantics/lqp/rewrite/splinter.py +76 -0
  321. v0/relationalai/semantics/lqp/types.py +101 -0
  322. v0/relationalai/semantics/lqp/utils.py +160 -0
  323. v0/relationalai/semantics/lqp/validators.py +57 -0
  324. v0/relationalai/semantics/metamodel/__init__.py +40 -0
  325. v0/relationalai/semantics/metamodel/builtins.py +776 -0
  326. v0/relationalai/semantics/metamodel/compiler.py +133 -0
  327. v0/relationalai/semantics/metamodel/dependency.py +862 -0
  328. v0/relationalai/semantics/metamodel/executor.py +61 -0
  329. v0/relationalai/semantics/metamodel/factory.py +287 -0
  330. v0/relationalai/semantics/metamodel/helpers.py +361 -0
  331. v0/relationalai/semantics/metamodel/ir.py +923 -0
  332. v0/relationalai/semantics/metamodel/rewrite/__init__.py +7 -0
  333. v0/relationalai/semantics/metamodel/rewrite/discharge_constraints.py +39 -0
  334. v0/relationalai/semantics/metamodel/rewrite/dnf_union_splitter.py +210 -0
  335. v0/relationalai/semantics/metamodel/rewrite/extract_nested_logicals.py +78 -0
  336. v0/relationalai/semantics/metamodel/rewrite/flatten.py +554 -0
  337. v0/relationalai/semantics/metamodel/rewrite/format_outputs.py +165 -0
  338. v0/relationalai/semantics/metamodel/typer/checker.py +353 -0
  339. v0/relationalai/semantics/metamodel/typer/typer.py +1395 -0
  340. v0/relationalai/semantics/metamodel/util.py +505 -0
  341. v0/relationalai/semantics/metamodel/visitor.py +944 -0
  342. v0/relationalai/semantics/reasoners/__init__.py +10 -0
  343. v0/relationalai/semantics/reasoners/graph/__init__.py +37 -0
  344. v0/relationalai/semantics/reasoners/graph/core.py +9019 -0
  345. v0/relationalai/semantics/reasoners/optimization/__init__.py +68 -0
  346. v0/relationalai/semantics/reasoners/optimization/common.py +88 -0
  347. v0/relationalai/semantics/reasoners/optimization/solvers_dev.py +568 -0
  348. v0/relationalai/semantics/reasoners/optimization/solvers_pb.py +1163 -0
  349. v0/relationalai/semantics/rel/builtins.py +40 -0
  350. v0/relationalai/semantics/rel/compiler.py +989 -0
  351. v0/relationalai/semantics/rel/executor.py +359 -0
  352. v0/relationalai/semantics/rel/rel.py +482 -0
  353. v0/relationalai/semantics/rel/rel_utils.py +276 -0
  354. v0/relationalai/semantics/snowflake/__init__.py +3 -0
  355. v0/relationalai/semantics/sql/compiler.py +2503 -0
  356. v0/relationalai/semantics/sql/executor/duck_db.py +52 -0
  357. v0/relationalai/semantics/sql/executor/result_helpers.py +64 -0
  358. v0/relationalai/semantics/sql/executor/snowflake.py +145 -0
  359. v0/relationalai/semantics/sql/rewrite/denormalize.py +222 -0
  360. v0/relationalai/semantics/sql/rewrite/double_negation.py +49 -0
  361. v0/relationalai/semantics/sql/rewrite/recursive_union.py +127 -0
  362. v0/relationalai/semantics/sql/rewrite/sort_output_query.py +246 -0
  363. v0/relationalai/semantics/sql/sql.py +504 -0
  364. v0/relationalai/semantics/std/__init__.py +54 -0
  365. v0/relationalai/semantics/std/constraints.py +43 -0
  366. v0/relationalai/semantics/std/datetime.py +363 -0
  367. v0/relationalai/semantics/std/decimals.py +62 -0
  368. v0/relationalai/semantics/std/floats.py +7 -0
  369. v0/relationalai/semantics/std/integers.py +22 -0
  370. v0/relationalai/semantics/std/math.py +141 -0
  371. v0/relationalai/semantics/std/pragmas.py +11 -0
  372. v0/relationalai/semantics/std/re.py +83 -0
  373. v0/relationalai/semantics/std/std.py +14 -0
  374. v0/relationalai/semantics/std/strings.py +63 -0
  375. v0/relationalai/semantics/tests/__init__.py +0 -0
  376. v0/relationalai/semantics/tests/test_snapshot_abstract.py +143 -0
  377. v0/relationalai/semantics/tests/test_snapshot_base.py +9 -0
  378. v0/relationalai/semantics/tests/utils.py +46 -0
  379. v0/relationalai/std/__init__.py +70 -0
  380. v0/relationalai/tools/__init__.py +0 -0
  381. v0/relationalai/tools/cli.py +1940 -0
  382. v0/relationalai/tools/cli_controls.py +1826 -0
  383. v0/relationalai/tools/cli_helpers.py +390 -0
  384. v0/relationalai/tools/debugger.py +183 -0
  385. v0/relationalai/tools/debugger_client.py +109 -0
  386. v0/relationalai/tools/debugger_server.py +302 -0
  387. v0/relationalai/tools/dev.py +685 -0
  388. v0/relationalai/tools/qb_debugger.py +425 -0
  389. v0/relationalai/util/clean_up_databases.py +95 -0
  390. v0/relationalai/util/format.py +123 -0
  391. v0/relationalai/util/list_databases.py +9 -0
  392. v0/relationalai/util/otel_configuration.py +25 -0
  393. v0/relationalai/util/otel_handler.py +484 -0
  394. v0/relationalai/util/snowflake_handler.py +88 -0
  395. v0/relationalai/util/span_format_test.py +43 -0
  396. v0/relationalai/util/span_tracker.py +207 -0
  397. v0/relationalai/util/spans_file_handler.py +72 -0
  398. v0/relationalai/util/tracing_handler.py +34 -0
  399. frontend/debugger/dist/.gitignore +0 -2
  400. frontend/debugger/dist/assets/favicon-Dy0ZgA6N.png +0 -0
  401. frontend/debugger/dist/assets/index-Cssla-O7.js +0 -208
  402. frontend/debugger/dist/assets/index-DlHsYx1V.css +0 -9
  403. frontend/debugger/dist/index.html +0 -17
  404. relationalai/clients/__init__.py +0 -18
  405. relationalai/clients/client.py +0 -946
  406. relationalai/clients/config.py +0 -673
  407. relationalai/clients/direct_access_client.py +0 -118
  408. relationalai/clients/exec_txn_poller.py +0 -153
  409. relationalai/clients/hash_util.py +0 -31
  410. relationalai/clients/local.py +0 -594
  411. relationalai/clients/profile_polling.py +0 -73
  412. relationalai/clients/resources/__init__.py +0 -8
  413. relationalai/clients/resources/azure/azure.py +0 -502
  414. relationalai/clients/resources/snowflake/__init__.py +0 -20
  415. relationalai/clients/resources/snowflake/cli_resources.py +0 -98
  416. relationalai/clients/resources/snowflake/direct_access_resources.py +0 -739
  417. relationalai/clients/resources/snowflake/engine_service.py +0 -381
  418. relationalai/clients/resources/snowflake/engine_state_handlers.py +0 -315
  419. relationalai/clients/resources/snowflake/error_handlers.py +0 -240
  420. relationalai/clients/resources/snowflake/export_procedure.py.jinja +0 -249
  421. relationalai/clients/resources/snowflake/resources_factory.py +0 -99
  422. relationalai/clients/resources/snowflake/snowflake.py +0 -3193
  423. relationalai/clients/resources/snowflake/use_index_poller.py +0 -1019
  424. relationalai/clients/resources/snowflake/use_index_resources.py +0 -188
  425. relationalai/clients/resources/snowflake/util.py +0 -387
  426. relationalai/clients/result_helpers.py +0 -420
  427. relationalai/clients/types.py +0 -118
  428. relationalai/clients/util.py +0 -356
  429. relationalai/debugging.py +0 -389
  430. relationalai/dsl.py +0 -1749
  431. relationalai/early_access/builder/__init__.py +0 -30
  432. relationalai/early_access/builder/builder/__init__.py +0 -35
  433. relationalai/early_access/builder/snowflake/__init__.py +0 -12
  434. relationalai/early_access/builder/std/__init__.py +0 -25
  435. relationalai/early_access/builder/std/decimals/__init__.py +0 -12
  436. relationalai/early_access/builder/std/integers/__init__.py +0 -12
  437. relationalai/early_access/builder/std/math/__init__.py +0 -12
  438. relationalai/early_access/builder/std/strings/__init__.py +0 -14
  439. relationalai/early_access/devtools/__init__.py +0 -12
  440. relationalai/early_access/devtools/benchmark_lqp/__init__.py +0 -12
  441. relationalai/early_access/devtools/extract_lqp/__init__.py +0 -12
  442. relationalai/early_access/dsl/adapters/orm/adapter_qb.py +0 -427
  443. relationalai/early_access/dsl/adapters/orm/parser.py +0 -636
  444. relationalai/early_access/dsl/adapters/owl/adapter.py +0 -176
  445. relationalai/early_access/dsl/adapters/owl/parser.py +0 -160
  446. relationalai/early_access/dsl/bindings/common.py +0 -402
  447. relationalai/early_access/dsl/bindings/csv.py +0 -170
  448. relationalai/early_access/dsl/bindings/legacy/binding_models.py +0 -143
  449. relationalai/early_access/dsl/bindings/snowflake.py +0 -64
  450. relationalai/early_access/dsl/codegen/binder.py +0 -411
  451. relationalai/early_access/dsl/codegen/common.py +0 -79
  452. relationalai/early_access/dsl/codegen/helpers.py +0 -23
  453. relationalai/early_access/dsl/codegen/relations.py +0 -700
  454. relationalai/early_access/dsl/codegen/weaver.py +0 -417
  455. relationalai/early_access/dsl/core/builders/__init__.py +0 -47
  456. relationalai/early_access/dsl/core/builders/logic.py +0 -19
  457. relationalai/early_access/dsl/core/builders/scalar_constraint.py +0 -11
  458. relationalai/early_access/dsl/core/constraints/predicate/atomic.py +0 -455
  459. relationalai/early_access/dsl/core/constraints/predicate/universal.py +0 -73
  460. relationalai/early_access/dsl/core/constraints/scalar.py +0 -310
  461. relationalai/early_access/dsl/core/context.py +0 -13
  462. relationalai/early_access/dsl/core/cset.py +0 -132
  463. relationalai/early_access/dsl/core/exprs/__init__.py +0 -116
  464. relationalai/early_access/dsl/core/exprs/relational.py +0 -18
  465. relationalai/early_access/dsl/core/exprs/scalar.py +0 -412
  466. relationalai/early_access/dsl/core/instances.py +0 -44
  467. relationalai/early_access/dsl/core/logic/__init__.py +0 -193
  468. relationalai/early_access/dsl/core/logic/aggregation.py +0 -98
  469. relationalai/early_access/dsl/core/logic/exists.py +0 -223
  470. relationalai/early_access/dsl/core/logic/helper.py +0 -163
  471. relationalai/early_access/dsl/core/namespaces.py +0 -32
  472. relationalai/early_access/dsl/core/relations.py +0 -276
  473. relationalai/early_access/dsl/core/rules.py +0 -112
  474. relationalai/early_access/dsl/core/std/__init__.py +0 -45
  475. relationalai/early_access/dsl/core/temporal/recall.py +0 -6
  476. relationalai/early_access/dsl/core/types/__init__.py +0 -270
  477. relationalai/early_access/dsl/core/types/concepts.py +0 -128
  478. relationalai/early_access/dsl/core/types/constrained/__init__.py +0 -267
  479. relationalai/early_access/dsl/core/types/constrained/nominal.py +0 -143
  480. relationalai/early_access/dsl/core/types/constrained/subtype.py +0 -124
  481. relationalai/early_access/dsl/core/types/standard.py +0 -92
  482. relationalai/early_access/dsl/core/types/unconstrained.py +0 -50
  483. relationalai/early_access/dsl/core/types/variables.py +0 -203
  484. relationalai/early_access/dsl/ir/compiler.py +0 -318
  485. relationalai/early_access/dsl/ir/executor.py +0 -260
  486. relationalai/early_access/dsl/ontologies/constraints.py +0 -88
  487. relationalai/early_access/dsl/ontologies/export.py +0 -30
  488. relationalai/early_access/dsl/ontologies/models.py +0 -453
  489. relationalai/early_access/dsl/ontologies/python_printer.py +0 -303
  490. relationalai/early_access/dsl/ontologies/readings.py +0 -60
  491. relationalai/early_access/dsl/ontologies/relationships.py +0 -322
  492. relationalai/early_access/dsl/ontologies/roles.py +0 -87
  493. relationalai/early_access/dsl/ontologies/subtyping.py +0 -55
  494. relationalai/early_access/dsl/orm/constraints.py +0 -438
  495. relationalai/early_access/dsl/orm/measures/dimensions.py +0 -200
  496. relationalai/early_access/dsl/orm/measures/initializer.py +0 -16
  497. relationalai/early_access/dsl/orm/measures/measure_rules.py +0 -275
  498. relationalai/early_access/dsl/orm/measures/measures.py +0 -299
  499. relationalai/early_access/dsl/orm/measures/role_exprs.py +0 -268
  500. relationalai/early_access/dsl/orm/models.py +0 -256
  501. relationalai/early_access/dsl/orm/object_oriented_printer.py +0 -344
  502. relationalai/early_access/dsl/orm/printer.py +0 -469
  503. relationalai/early_access/dsl/orm/reasoners.py +0 -480
  504. relationalai/early_access/dsl/orm/relations.py +0 -19
  505. relationalai/early_access/dsl/orm/relationships.py +0 -251
  506. relationalai/early_access/dsl/orm/types.py +0 -42
  507. relationalai/early_access/dsl/orm/utils.py +0 -79
  508. relationalai/early_access/dsl/orm/verb.py +0 -204
  509. relationalai/early_access/dsl/physical_metadata/tables.py +0 -133
  510. relationalai/early_access/dsl/relations.py +0 -170
  511. relationalai/early_access/dsl/rulesets.py +0 -69
  512. relationalai/early_access/dsl/schemas/__init__.py +0 -450
  513. relationalai/early_access/dsl/schemas/builder.py +0 -48
  514. relationalai/early_access/dsl/schemas/comp_names.py +0 -51
  515. relationalai/early_access/dsl/schemas/components.py +0 -203
  516. relationalai/early_access/dsl/schemas/contexts.py +0 -156
  517. relationalai/early_access/dsl/schemas/exprs.py +0 -89
  518. relationalai/early_access/dsl/schemas/fragments.py +0 -464
  519. relationalai/early_access/dsl/serialization.py +0 -79
  520. relationalai/early_access/dsl/serialize/exporter.py +0 -163
  521. relationalai/early_access/dsl/snow/api.py +0 -105
  522. relationalai/early_access/dsl/snow/common.py +0 -76
  523. relationalai/early_access/dsl/state_mgmt/__init__.py +0 -129
  524. relationalai/early_access/dsl/state_mgmt/state_charts.py +0 -125
  525. relationalai/early_access/dsl/state_mgmt/transitions.py +0 -130
  526. relationalai/early_access/dsl/types/__init__.py +0 -40
  527. relationalai/early_access/dsl/types/concepts.py +0 -12
  528. relationalai/early_access/dsl/types/entities.py +0 -135
  529. relationalai/early_access/dsl/types/values.py +0 -17
  530. relationalai/early_access/dsl/utils.py +0 -102
  531. relationalai/early_access/graphs/__init__.py +0 -13
  532. relationalai/early_access/lqp/__init__.py +0 -12
  533. relationalai/early_access/lqp/compiler/__init__.py +0 -12
  534. relationalai/early_access/lqp/constructors/__init__.py +0 -18
  535. relationalai/early_access/lqp/executor/__init__.py +0 -12
  536. relationalai/early_access/lqp/ir/__init__.py +0 -12
  537. relationalai/early_access/lqp/passes/__init__.py +0 -12
  538. relationalai/early_access/lqp/pragmas/__init__.py +0 -12
  539. relationalai/early_access/lqp/primitives/__init__.py +0 -12
  540. relationalai/early_access/lqp/types/__init__.py +0 -12
  541. relationalai/early_access/lqp/utils/__init__.py +0 -12
  542. relationalai/early_access/lqp/validators/__init__.py +0 -12
  543. relationalai/early_access/metamodel/__init__.py +0 -58
  544. relationalai/early_access/metamodel/builtins/__init__.py +0 -12
  545. relationalai/early_access/metamodel/compiler/__init__.py +0 -12
  546. relationalai/early_access/metamodel/dependency/__init__.py +0 -12
  547. relationalai/early_access/metamodel/factory/__init__.py +0 -17
  548. relationalai/early_access/metamodel/helpers/__init__.py +0 -12
  549. relationalai/early_access/metamodel/ir/__init__.py +0 -14
  550. relationalai/early_access/metamodel/rewrite/__init__.py +0 -7
  551. relationalai/early_access/metamodel/typer/__init__.py +0 -3
  552. relationalai/early_access/metamodel/typer/typer/__init__.py +0 -12
  553. relationalai/early_access/metamodel/types/__init__.py +0 -15
  554. relationalai/early_access/metamodel/util/__init__.py +0 -15
  555. relationalai/early_access/metamodel/visitor/__init__.py +0 -12
  556. relationalai/early_access/rel/__init__.py +0 -12
  557. relationalai/early_access/rel/executor/__init__.py +0 -12
  558. relationalai/early_access/rel/rel_utils/__init__.py +0 -12
  559. relationalai/early_access/rel/rewrite/__init__.py +0 -7
  560. relationalai/early_access/solvers/__init__.py +0 -19
  561. relationalai/early_access/sql/__init__.py +0 -11
  562. relationalai/early_access/sql/executor/__init__.py +0 -3
  563. relationalai/early_access/sql/rewrite/__init__.py +0 -3
  564. relationalai/early_access/tests/logging/__init__.py +0 -12
  565. relationalai/early_access/tests/test_snapshot_base/__init__.py +0 -12
  566. relationalai/early_access/tests/utils/__init__.py +0 -12
  567. relationalai/environments/__init__.py +0 -35
  568. relationalai/environments/base.py +0 -381
  569. relationalai/environments/colab.py +0 -14
  570. relationalai/environments/generic.py +0 -71
  571. relationalai/environments/ipython.py +0 -68
  572. relationalai/environments/jupyter.py +0 -9
  573. relationalai/environments/snowbook.py +0 -169
  574. relationalai/errors.py +0 -2496
  575. relationalai/experimental/SF.py +0 -38
  576. relationalai/experimental/inspect.py +0 -47
  577. relationalai/experimental/pathfinder/__init__.py +0 -158
  578. relationalai/experimental/pathfinder/api.py +0 -160
  579. relationalai/experimental/pathfinder/automaton.py +0 -584
  580. relationalai/experimental/pathfinder/bridge.py +0 -226
  581. relationalai/experimental/pathfinder/compiler.py +0 -416
  582. relationalai/experimental/pathfinder/datalog.py +0 -214
  583. relationalai/experimental/pathfinder/diagnostics.py +0 -56
  584. relationalai/experimental/pathfinder/filter.py +0 -236
  585. relationalai/experimental/pathfinder/glushkov.py +0 -439
  586. relationalai/experimental/pathfinder/options.py +0 -265
  587. relationalai/experimental/pathfinder/pathfinder-v0.7.0.rel +0 -1951
  588. relationalai/experimental/pathfinder/rpq.py +0 -344
  589. relationalai/experimental/pathfinder/transition.py +0 -200
  590. relationalai/experimental/pathfinder/utils.py +0 -26
  591. relationalai/experimental/paths/README.md +0 -107
  592. relationalai/experimental/paths/api.py +0 -143
  593. relationalai/experimental/paths/benchmarks/grid_graph.py +0 -37
  594. relationalai/experimental/paths/code_organization.md +0 -2
  595. relationalai/experimental/paths/examples/Movies.ipynb +0 -16328
  596. relationalai/experimental/paths/examples/basic_example.py +0 -40
  597. relationalai/experimental/paths/examples/minimal_engine_warmup.py +0 -3
  598. relationalai/experimental/paths/examples/movie_example.py +0 -77
  599. relationalai/experimental/paths/examples/movies_data/actedin.csv +0 -193
  600. relationalai/experimental/paths/examples/movies_data/directed.csv +0 -45
  601. relationalai/experimental/paths/examples/movies_data/follows.csv +0 -7
  602. relationalai/experimental/paths/examples/movies_data/movies.csv +0 -39
  603. relationalai/experimental/paths/examples/movies_data/person.csv +0 -134
  604. relationalai/experimental/paths/examples/movies_data/produced.csv +0 -16
  605. relationalai/experimental/paths/examples/movies_data/ratings.csv +0 -10
  606. relationalai/experimental/paths/examples/movies_data/wrote.csv +0 -11
  607. relationalai/experimental/paths/examples/paths_benchmark.py +0 -115
  608. relationalai/experimental/paths/examples/paths_example.py +0 -116
  609. relationalai/experimental/paths/examples/pattern_to_automaton.py +0 -28
  610. relationalai/experimental/paths/find_paths_via_automaton.py +0 -85
  611. relationalai/experimental/paths/graph.py +0 -185
  612. relationalai/experimental/paths/path_algorithms/find_paths.py +0 -280
  613. relationalai/experimental/paths/path_algorithms/one_sided_ball_repetition.py +0 -26
  614. relationalai/experimental/paths/path_algorithms/one_sided_ball_upto.py +0 -111
  615. relationalai/experimental/paths/path_algorithms/single.py +0 -59
  616. relationalai/experimental/paths/path_algorithms/two_sided_balls_repetition.py +0 -39
  617. relationalai/experimental/paths/path_algorithms/two_sided_balls_upto.py +0 -103
  618. relationalai/experimental/paths/path_algorithms/usp-old.py +0 -130
  619. relationalai/experimental/paths/path_algorithms/usp-tuple.py +0 -183
  620. relationalai/experimental/paths/path_algorithms/usp.py +0 -150
  621. relationalai/experimental/paths/product_graph.py +0 -93
  622. relationalai/experimental/paths/rpq/automaton.py +0 -584
  623. relationalai/experimental/paths/rpq/diagnostics.py +0 -56
  624. relationalai/experimental/paths/rpq/rpq.py +0 -378
  625. relationalai/experimental/paths/tests/tests_limit_sp_max_length.py +0 -90
  626. relationalai/experimental/paths/tests/tests_limit_sp_multiple.py +0 -119
  627. relationalai/experimental/paths/tests/tests_limit_sp_single.py +0 -104
  628. relationalai/experimental/paths/tests/tests_limit_walks_multiple.py +0 -113
  629. relationalai/experimental/paths/tests/tests_limit_walks_single.py +0 -149
  630. relationalai/experimental/paths/tests/tests_one_sided_ball_repetition_multiple.py +0 -70
  631. relationalai/experimental/paths/tests/tests_one_sided_ball_repetition_single.py +0 -64
  632. relationalai/experimental/paths/tests/tests_one_sided_ball_upto_multiple.py +0 -115
  633. relationalai/experimental/paths/tests/tests_one_sided_ball_upto_single.py +0 -75
  634. relationalai/experimental/paths/tests/tests_single_paths.py +0 -152
  635. relationalai/experimental/paths/tests/tests_single_walks.py +0 -208
  636. relationalai/experimental/paths/tests/tests_single_walks_undirected.py +0 -297
  637. relationalai/experimental/paths/tests/tests_two_sided_balls_repetition_multiple.py +0 -107
  638. relationalai/experimental/paths/tests/tests_two_sided_balls_repetition_single.py +0 -76
  639. relationalai/experimental/paths/tests/tests_two_sided_balls_upto_multiple.py +0 -76
  640. relationalai/experimental/paths/tests/tests_two_sided_balls_upto_single.py +0 -110
  641. relationalai/experimental/paths/tests/tests_usp_nsp_multiple.py +0 -229
  642. relationalai/experimental/paths/tests/tests_usp_nsp_single.py +0 -108
  643. relationalai/experimental/paths/tree_agg.py +0 -168
  644. relationalai/experimental/paths/utilities/iterators.py +0 -27
  645. relationalai/experimental/paths/utilities/prefix_sum.py +0 -91
  646. relationalai/experimental/solvers.py +0 -1095
  647. relationalai/loaders/csv.py +0 -195
  648. relationalai/loaders/loader.py +0 -177
  649. relationalai/loaders/types.py +0 -23
  650. relationalai/rel_emitter.py +0 -373
  651. relationalai/rel_utils.py +0 -185
  652. relationalai/semantics/designs/query_builder/identify_by.md +0 -106
  653. relationalai/semantics/devtools/benchmark_lqp.py +0 -535
  654. relationalai/semantics/devtools/compilation_manager.py +0 -294
  655. relationalai/semantics/devtools/extract_lqp.py +0 -110
  656. relationalai/semantics/internal/internal.py +0 -3785
  657. relationalai/semantics/internal/snowflake.py +0 -329
  658. relationalai/semantics/lqp/README.md +0 -34
  659. relationalai/semantics/lqp/algorithms.py +0 -173
  660. relationalai/semantics/lqp/builtins.py +0 -213
  661. relationalai/semantics/lqp/compiler.py +0 -22
  662. relationalai/semantics/lqp/constructors.py +0 -68
  663. relationalai/semantics/lqp/executor.py +0 -518
  664. relationalai/semantics/lqp/export_rewriter.py +0 -40
  665. relationalai/semantics/lqp/intrinsics.py +0 -24
  666. relationalai/semantics/lqp/ir.py +0 -150
  667. relationalai/semantics/lqp/model2lqp.py +0 -1056
  668. relationalai/semantics/lqp/passes.py +0 -38
  669. relationalai/semantics/lqp/primitives.py +0 -252
  670. relationalai/semantics/lqp/result_helpers.py +0 -266
  671. relationalai/semantics/lqp/rewrite/__init__.py +0 -32
  672. relationalai/semantics/lqp/rewrite/algorithm.py +0 -385
  673. relationalai/semantics/lqp/rewrite/annotate_constraints.py +0 -69
  674. relationalai/semantics/lqp/rewrite/cdc.py +0 -216
  675. relationalai/semantics/lqp/rewrite/constants_to_vars.py +0 -70
  676. relationalai/semantics/lqp/rewrite/deduplicate_vars.py +0 -104
  677. relationalai/semantics/lqp/rewrite/eliminate_data.py +0 -108
  678. relationalai/semantics/lqp/rewrite/extract_common.py +0 -340
  679. relationalai/semantics/lqp/rewrite/extract_keys.py +0 -577
  680. relationalai/semantics/lqp/rewrite/flatten_script.py +0 -301
  681. relationalai/semantics/lqp/rewrite/function_annotations.py +0 -114
  682. relationalai/semantics/lqp/rewrite/functional_dependencies.py +0 -348
  683. relationalai/semantics/lqp/rewrite/period_math.py +0 -77
  684. relationalai/semantics/lqp/rewrite/quantify_vars.py +0 -339
  685. relationalai/semantics/lqp/rewrite/splinter.py +0 -76
  686. relationalai/semantics/lqp/rewrite/unify_definitions.py +0 -323
  687. relationalai/semantics/lqp/types.py +0 -101
  688. relationalai/semantics/lqp/utils.py +0 -170
  689. relationalai/semantics/lqp/validators.py +0 -70
  690. relationalai/semantics/metamodel/compiler.py +0 -134
  691. relationalai/semantics/metamodel/dependency.py +0 -880
  692. relationalai/semantics/metamodel/executor.py +0 -78
  693. relationalai/semantics/metamodel/factory.py +0 -287
  694. relationalai/semantics/metamodel/helpers.py +0 -368
  695. relationalai/semantics/metamodel/ir.py +0 -924
  696. relationalai/semantics/metamodel/rewrite/__init__.py +0 -8
  697. relationalai/semantics/metamodel/rewrite/discharge_constraints.py +0 -39
  698. relationalai/semantics/metamodel/rewrite/dnf_union_splitter.py +0 -220
  699. relationalai/semantics/metamodel/rewrite/extract_nested_logicals.py +0 -78
  700. relationalai/semantics/metamodel/rewrite/flatten.py +0 -590
  701. relationalai/semantics/metamodel/rewrite/format_outputs.py +0 -256
  702. relationalai/semantics/metamodel/rewrite/handle_aggregations_and_ranks.py +0 -237
  703. relationalai/semantics/metamodel/typer/checker.py +0 -355
  704. relationalai/semantics/metamodel/typer/typer.py +0 -1396
  705. relationalai/semantics/metamodel/util.py +0 -506
  706. relationalai/semantics/metamodel/visitor.py +0 -945
  707. relationalai/semantics/reasoners/__init__.py +0 -10
  708. relationalai/semantics/reasoners/graph/README.md +0 -620
  709. relationalai/semantics/reasoners/graph/__init__.py +0 -37
  710. relationalai/semantics/reasoners/graph/core.py +0 -9019
  711. relationalai/semantics/reasoners/graph/design/beyond_demand_transform.md +0 -797
  712. relationalai/semantics/reasoners/graph/tests/README.md +0 -21
  713. relationalai/semantics/reasoners/optimization/__init__.py +0 -68
  714. relationalai/semantics/reasoners/optimization/common.py +0 -88
  715. relationalai/semantics/reasoners/optimization/solvers_dev.py +0 -568
  716. relationalai/semantics/reasoners/optimization/solvers_pb.py +0 -1407
  717. relationalai/semantics/rel/builtins.py +0 -40
  718. relationalai/semantics/rel/compiler.py +0 -994
  719. relationalai/semantics/rel/executor.py +0 -363
  720. relationalai/semantics/rel/rel.py +0 -482
  721. relationalai/semantics/rel/rel_utils.py +0 -276
  722. relationalai/semantics/snowflake/__init__.py +0 -3
  723. relationalai/semantics/sql/compiler.py +0 -2503
  724. relationalai/semantics/sql/executor/duck_db.py +0 -52
  725. relationalai/semantics/sql/executor/result_helpers.py +0 -64
  726. relationalai/semantics/sql/executor/snowflake.py +0 -149
  727. relationalai/semantics/sql/rewrite/denormalize.py +0 -222
  728. relationalai/semantics/sql/rewrite/double_negation.py +0 -49
  729. relationalai/semantics/sql/rewrite/recursive_union.py +0 -127
  730. relationalai/semantics/sql/rewrite/sort_output_query.py +0 -246
  731. relationalai/semantics/sql/sql.py +0 -504
  732. relationalai/semantics/std/pragmas.py +0 -11
  733. relationalai/semantics/std/std.py +0 -14
  734. relationalai/semantics/tests/lqp/algorithms.py +0 -345
  735. relationalai/semantics/tests/test_snapshot_abstract.py +0 -144
  736. relationalai/semantics/tests/test_snapshot_base.py +0 -9
  737. relationalai/semantics/tests/utils.py +0 -46
  738. relationalai/std/__init__.py +0 -70
  739. relationalai/tools/cli.py +0 -2089
  740. relationalai/tools/cli_controls.py +0 -1975
  741. relationalai/tools/cli_helpers.py +0 -802
  742. relationalai/tools/debugger_client.py +0 -109
  743. relationalai/tools/debugger_server.py +0 -302
  744. relationalai/tools/dev.py +0 -685
  745. relationalai/tools/notes +0 -7
  746. relationalai/tools/qb_debugger.py +0 -425
  747. relationalai/tools/txn_progress.py +0 -188
  748. relationalai/util/clean_up_databases.py +0 -95
  749. relationalai/util/list_databases.py +0 -9
  750. relationalai/util/otel_configuration.py +0 -26
  751. relationalai/util/otel_handler.py +0 -484
  752. relationalai/util/snowflake_handler.py +0 -88
  753. relationalai/util/span_format_test.py +0 -43
  754. relationalai/util/span_tracker.py +0 -207
  755. relationalai/util/spans_file_handler.py +0 -72
  756. relationalai/util/tracing_handler.py +0 -34
  757. relationalai-0.13.5.dist-info/METADATA +0 -74
  758. relationalai-0.13.5.dist-info/RECORD +0 -473
  759. relationalai-0.13.5.dist-info/WHEEL +0 -4
  760. relationalai-0.13.5.dist-info/entry_points.txt +0 -3
  761. relationalai-0.13.5.dist-info/licenses/LICENSE +0 -202
  762. relationalai_test_util/__init__.py +0 -4
  763. relationalai_test_util/fixtures.py +0 -233
  764. relationalai_test_util/snapshot.py +0 -252
  765. relationalai_test_util/traceback.py +0 -118
  766. /relationalai/{analysis → semantics/frontend}/__init__.py +0 -0
  767. /relationalai/{auth/__init__.py → semantics/metamodel/metamodel_compiler.py} +0 -0
  768. /relationalai/{early_access → shims}/__init__.py +0 -0
  769. {relationalai/early_access/dsl/adapters → v0/relationalai/analysis}/__init__.py +0 -0
  770. {relationalai → v0/relationalai}/analysis/mechanistic.py +0 -0
  771. {relationalai → v0/relationalai}/analysis/whynot.py +0 -0
  772. {relationalai/early_access/dsl/adapters/orm → v0/relationalai/auth}/__init__.py +0 -0
  773. {relationalai → v0/relationalai}/auth/jwt_generator.py +0 -0
  774. {relationalai → v0/relationalai}/auth/oauth_callback_server.py +0 -0
  775. {relationalai → v0/relationalai}/auth/token_handler.py +0 -0
  776. {relationalai → v0/relationalai}/auth/util.py +0 -0
  777. {relationalai/clients/resources/snowflake → v0/relationalai/clients}/cache_store.py +0 -0
  778. {relationalai → v0/relationalai}/compiler.py +0 -0
  779. {relationalai → v0/relationalai}/dependencies.py +0 -0
  780. {relationalai → v0/relationalai}/docutils.py +0 -0
  781. {relationalai/early_access/dsl/adapters/owl → v0/relationalai/early_access}/__init__.py +0 -0
  782. {relationalai → v0/relationalai}/early_access/dsl/__init__.py +0 -0
  783. {relationalai/early_access/dsl/bindings → v0/relationalai/early_access/dsl/adapters}/__init__.py +0 -0
  784. {relationalai/early_access/dsl/bindings/legacy → v0/relationalai/early_access/dsl/adapters/orm}/__init__.py +0 -0
  785. {relationalai → v0/relationalai}/early_access/dsl/adapters/orm/model.py +0 -0
  786. {relationalai/early_access/dsl/codegen → v0/relationalai/early_access/dsl/adapters/owl}/__init__.py +0 -0
  787. {relationalai → v0/relationalai}/early_access/dsl/adapters/owl/model.py +0 -0
  788. {relationalai/early_access/dsl/core/temporal → v0/relationalai/early_access/dsl/bindings}/__init__.py +0 -0
  789. {relationalai/early_access/dsl/ir → v0/relationalai/early_access/dsl/bindings/legacy}/__init__.py +0 -0
  790. {relationalai/early_access/dsl/ontologies → v0/relationalai/early_access/dsl/codegen}/__init__.py +0 -0
  791. {relationalai → v0/relationalai}/early_access/dsl/constants.py +0 -0
  792. {relationalai → v0/relationalai}/early_access/dsl/core/__init__.py +0 -0
  793. {relationalai → v0/relationalai}/early_access/dsl/core/constraints/__init__.py +0 -0
  794. {relationalai → v0/relationalai}/early_access/dsl/core/constraints/predicate/__init__.py +0 -0
  795. {relationalai → v0/relationalai}/early_access/dsl/core/stack.py +0 -0
  796. {relationalai/early_access/dsl/orm → v0/relationalai/early_access/dsl/core/temporal}/__init__.py +0 -0
  797. {relationalai → v0/relationalai}/early_access/dsl/core/utils.py +0 -0
  798. {relationalai/early_access/dsl/orm/measures → v0/relationalai/early_access/dsl/ir}/__init__.py +0 -0
  799. {relationalai/early_access/dsl/physical_metadata → v0/relationalai/early_access/dsl/ontologies}/__init__.py +0 -0
  800. {relationalai → v0/relationalai}/early_access/dsl/ontologies/raw_source.py +0 -0
  801. {relationalai/early_access/dsl/serialize → v0/relationalai/early_access/dsl/orm}/__init__.py +0 -0
  802. {relationalai/early_access/dsl/snow → v0/relationalai/early_access/dsl/orm/measures}/__init__.py +0 -0
  803. {relationalai → v0/relationalai}/early_access/dsl/orm/reasoner_errors.py +0 -0
  804. {relationalai/loaders → v0/relationalai/early_access/dsl/physical_metadata}/__init__.py +0 -0
  805. {relationalai/semantics/tests → v0/relationalai/early_access/dsl/serialize}/__init__.py +0 -0
  806. {relationalai → v0/relationalai}/early_access/dsl/serialize/binding_model.py +0 -0
  807. {relationalai → v0/relationalai}/early_access/dsl/serialize/model.py +0 -0
  808. {relationalai/semantics/tests/lqp → v0/relationalai/early_access/dsl/snow}/__init__.py +0 -0
  809. {relationalai → v0/relationalai}/early_access/tests/__init__.py +0 -0
  810. {relationalai → v0/relationalai}/environments/ci.py +0 -0
  811. {relationalai → v0/relationalai}/environments/hex.py +0 -0
  812. {relationalai → v0/relationalai}/environments/terminal.py +0 -0
  813. {relationalai → v0/relationalai}/experimental/__init__.py +0 -0
  814. {relationalai → v0/relationalai}/experimental/graphs.py +0 -0
  815. {relationalai → v0/relationalai}/experimental/paths/__init__.py +0 -0
  816. {relationalai → v0/relationalai}/experimental/paths/benchmarks/__init__.py +0 -0
  817. {relationalai → v0/relationalai}/experimental/paths/path_algorithms/__init__.py +0 -0
  818. {relationalai → v0/relationalai}/experimental/paths/rpq/__init__.py +0 -0
  819. {relationalai → v0/relationalai}/experimental/paths/rpq/filter.py +0 -0
  820. {relationalai → v0/relationalai}/experimental/paths/rpq/glushkov.py +0 -0
  821. {relationalai → v0/relationalai}/experimental/paths/rpq/transition.py +0 -0
  822. {relationalai → v0/relationalai}/experimental/paths/utilities/__init__.py +0 -0
  823. {relationalai → v0/relationalai}/experimental/paths/utilities/utilities.py +0 -0
  824. {relationalai/tools → v0/relationalai/loaders}/__init__.py +0 -0
  825. {relationalai → v0/relationalai}/metagen.py +0 -0
  826. {relationalai → v0/relationalai}/metamodel.py +0 -0
  827. {relationalai → v0/relationalai}/rel.py +0 -0
  828. {relationalai → v0/relationalai}/semantics/devtools/__init__.py +0 -0
  829. {relationalai → v0/relationalai}/semantics/internal/__init__.py +0 -0
  830. {relationalai → v0/relationalai}/semantics/internal/annotations.py +0 -0
  831. {relationalai → v0/relationalai}/semantics/lqp/__init__.py +0 -0
  832. {relationalai → v0/relationalai}/semantics/lqp/pragmas.py +0 -0
  833. {relationalai → v0/relationalai}/semantics/metamodel/dataflow.py +0 -0
  834. {relationalai → v0/relationalai}/semantics/metamodel/typer/__init__.py +0 -0
  835. {relationalai → v0/relationalai}/semantics/metamodel/types.py +0 -0
  836. {relationalai → v0/relationalai}/semantics/reasoners/experimental/__init__.py +0 -0
  837. {relationalai → v0/relationalai}/semantics/rel/__init__.py +0 -0
  838. {relationalai → v0/relationalai}/semantics/sql/__init__.py +0 -0
  839. {relationalai → v0/relationalai}/semantics/sql/executor/__init__.py +0 -0
  840. {relationalai → v0/relationalai}/semantics/sql/rewrite/__init__.py +0 -0
  841. {relationalai → v0/relationalai}/semantics/tests/logging.py +0 -0
  842. {relationalai → v0/relationalai}/std/aggregates.py +0 -0
  843. {relationalai → v0/relationalai}/std/dates.py +0 -0
  844. {relationalai → v0/relationalai}/std/graphs.py +0 -0
  845. {relationalai → v0/relationalai}/std/inspect.py +0 -0
  846. {relationalai → v0/relationalai}/std/math.py +0 -0
  847. {relationalai → v0/relationalai}/std/re.py +0 -0
  848. {relationalai → v0/relationalai}/std/strings.py +0 -0
  849. {relationalai → v0/relationalai}/tools/cleanup_snapshots.py +0 -0
  850. {relationalai → v0/relationalai}/tools/constants.py +0 -0
  851. {relationalai → v0/relationalai}/tools/query_utils.py +0 -0
  852. {relationalai → v0/relationalai}/tools/snapshot_viewer.py +0 -0
  853. {relationalai → v0/relationalai}/util/__init__.py +0 -0
  854. {relationalai → v0/relationalai}/util/constants.py +0 -0
  855. {relationalai → v0/relationalai}/util/graph.py +0 -0
  856. {relationalai → v0/relationalai}/util/timeout.py +0 -0
@@ -1,777 +1,211 @@
1
- """
2
- Elementary IR relations.
3
- """
4
- import sys
5
-
6
- from . import ir, factory as f
7
- from . import types
8
-
1
+ from __future__ import annotations
9
2
  from typing import Optional
10
3
 
11
- #
12
- # Relations
13
- #
14
-
15
- # Comparators
16
- def _comparator(name: str, input=True):
17
- overloads = [
18
- f.relation(name, [f.field("a", type, input), f.field("b", type, input)])
19
- for type in [types.Bool, types.Int64, types.Int128, types.Float, types.GenericDecimal, types.String, types.Date, types.DateTime, types.Hash, types.EntityTypeVar]
20
- ]
21
- return f.relation(name, [f.field("a", types.Any, input), f.field("b", types.Any, input)], overloads=overloads)
22
-
23
- gt = _comparator(">")
24
- gte = _comparator(">=")
25
- lt = _comparator("<")
26
- lte = _comparator("<=")
27
- neq = _comparator("!=")
28
- eq = _comparator("=", False)
29
-
30
- def is_eq(other: ir.Relation) -> bool:
31
- return other == eq or other in eq.overloads
32
-
33
- # Arithmetic operators
34
- def _binary_op(name: str, with_string=False, result_type: Optional[ir.Type]=None):
35
- overload_types = [types.Int64, types.Int128, types.Float, types.GenericDecimal]
36
- if with_string:
37
- overload_types.append(types.String)
38
- overloads = [
39
- f.relation(name, [
40
- f.input_field("a", type),
41
- f.input_field("b", type),
42
- f.field("c", result_type if result_type is not None else type)])
43
- for type in overload_types
44
- ]
45
-
46
- if with_string:
47
- return f.relation(name, [f.input_field("a", types.Any), f.input_field("b", types.Any), f.field("c", types.Any)], overloads=overloads)
48
- else:
49
- # If strings isn't added, then we're guaranteed to only have number overloads
50
- result_type = result_type if result_type is not None else types.Number
51
- return f.relation(name, [f.input_field("a", types.Number), f.input_field("b", types.Number), f.field("c", result_type)], overloads=overloads)
52
-
53
- plus = _binary_op("+", with_string=True)
54
- minus = _binary_op("-")
55
- mul = _binary_op("*")
56
- div = f.relation(
57
- "/",
58
- [f.input_field("a", types.Number), f.input_field("b", types.Number), f.field("c", types.Number)],
59
- overloads=[
60
- f.relation("/", [f.input_field("a", types.Int64), f.input_field("b", types.Int64), f.field("c", types.Float)]),
61
- f.relation("/", [f.input_field("a", types.Int128), f.input_field("b", types.Int128), f.field("c", types.Float)]),
62
- f.relation("/", [f.input_field("a", types.Float), f.input_field("b", types.Float), f.field("c", types.Float)]),
63
- f.relation("/", [f.input_field("a", types.GenericDecimal), f.input_field("b", types.GenericDecimal), f.field("c", types.GenericDecimal)]),
64
- ],
65
- )
66
- mod = _binary_op("%")
67
- power = _binary_op("^")
68
-
69
- trunc_div = f.relation(
70
- "//",
71
- [f.input_field("a", types.Number), f.input_field("b", types.Number), f.field("c", types.Number)],
72
- overloads=[
73
- f.relation("//", [f.input_field("a", types.Int64), f.input_field("b", types.Int64), f.field("c", types.Int64)]),
74
- f.relation("//", [f.input_field("a", types.Int128), f.input_field("b", types.Int128), f.field("c", types.Int128)]),
75
- ],
76
- )
77
-
78
- abs = f.relation(
79
- "abs",
80
- [f.input_field("a", types.Number), f.field("b", types.Number)],
81
- overloads=[
82
- f.relation("abs", [f.input_field("a", types.Int64), f.field("b", types.Int64)]),
83
- f.relation("abs", [f.input_field("a", types.Int128), f.field("b", types.Int128)]),
84
- f.relation("abs", [f.input_field("a", types.Float), f.field("b", types.Float)]),
85
- f.relation("abs", [f.input_field("a", types.GenericDecimal), f.field("b", types.GenericDecimal)]),
86
- ],
87
- )
88
-
89
- natural_log = f.relation(
90
- "natural_log",
91
- [f.input_field("a", types.Number), f.field("b", types.Float)],
92
- overloads=[
93
- f.relation("natural_log", [f.input_field("a", types.Int64), f.field("b", types.Float)]),
94
- f.relation("natural_log", [f.input_field("a", types.Int128), f.field("b", types.Float)]),
95
- f.relation("natural_log", [f.input_field("a", types.Float), f.field("b", types.Float)]),
96
- f.relation("natural_log", [f.input_field("a", types.GenericDecimal), f.field("b", types.Float)]),
97
-
98
- ],
99
- )
100
-
101
- log10 = f.relation(
102
- "log10",
103
- [f.input_field("a", types.Number), f.field("b", types.Float)],
104
- overloads=[
105
- f.relation("log10", [f.input_field("a", types.Int64), f.field("b", types.Float)]),
106
- f.relation("log10", [f.input_field("a", types.Int128), f.field("b", types.Float)]),
107
- f.relation("log10", [f.input_field("a", types.Float), f.field("b", types.Float)]),
108
- f.relation("log10", [f.input_field("a", types.GenericDecimal), f.field("b", types.Float)]),
109
-
110
- ],
111
- )
112
-
113
- log = f.relation(
114
- "log",
115
- [f.input_field("base", types.Number), f.input_field("value", types.Number), f.field("result", types.Float)],
116
- overloads=[
117
- f.relation("log", [f.input_field("base", types.Int64), f.input_field("value", types.Int64), f.field("result", types.Float)]),
118
- f.relation("log", [f.input_field("base", types.Int128), f.input_field("value", types.Int128), f.field("result", types.Float)]),
119
- f.relation("log", [f.input_field("base", types.Float), f.input_field("value", types.Float), f.field("result", types.Float)]),
120
- f.relation("log", [f.input_field("base", types.GenericDecimal), f.input_field("value", types.GenericDecimal), f.field("result", types.Float)]),
121
-
122
- ],
123
- )
124
-
125
- sqrt = f.relation(
126
- "sqrt",
127
- [f.input_field("a", types.Number), f.field("b", types.Float)],
128
- overloads=[
129
- f.relation("sqrt", [f.input_field("a", types.Int64), f.field("b", types.Float)]),
130
- f.relation("sqrt", [f.input_field("a", types.Int128), f.field("b", types.Float)]),
131
- f.relation("sqrt", [f.input_field("a", types.Float), f.field("b", types.Float)]),
132
- f.relation("sqrt", [f.input_field("a", types.GenericDecimal), f.field("b", types.Float)]),
133
- ],
134
- )
135
-
136
- maximum = f.relation(
137
- "maximum",
138
- [f.input_field("a", types.Number), f.input_field("b", types.Number), f.field("c", types.Number)],
139
- overloads=[
140
- f.relation("maximum", [f.input_field("a", types.Int64), f.input_field("b", types.Int64), f.field("c", types.Int64)]),
141
- f.relation("maximum", [f.input_field("a", types.Int128), f.input_field("b", types.Int128), f.field("c", types.Int128)]),
142
- f.relation("maximum", [f.input_field("a", types.Float), f.input_field("b", types.Float), f.field("c", types.Float)]),
143
- f.relation("maximum", [f.input_field("a", types.GenericDecimal), f.input_field("b", types.GenericDecimal), f.field("c", types.GenericDecimal)]),
144
- ],
145
- )
146
-
147
- minimum = f.relation(
148
- "minimum",
149
- [f.input_field("a", types.Number), f.input_field("b", types.Number), f.field("c", types.Number)],
150
- overloads=[
151
- f.relation("minimum", [f.input_field("a", types.Int64), f.input_field("b", types.Int64), f.field("c", types.Int64)]),
152
- f.relation("minimum", [f.input_field("a", types.Int128), f.input_field("b", types.Int128), f.field("c", types.Int128)]),
153
- f.relation("minimum", [f.input_field("a", types.Float), f.input_field("b", types.Float), f.field("c", types.Float)]),
154
- f.relation("minimum", [f.input_field("a", types.GenericDecimal), f.input_field("b", types.GenericDecimal), f.field("c", types.GenericDecimal)]),
155
- ],
156
- )
157
-
158
- ceil = f.relation(
159
- "ceil",
160
- [f.input_field("a", types.Number), f.field("b", types.Number)],
161
- overloads=[
162
- f.relation("ceil", [f.input_field("a", types.Int64), f.field("b", types.Int64)]),
163
- f.relation("ceil", [f.input_field("a", types.Int128), f.field("b", types.Int128)]),
164
- f.relation("ceil", [f.input_field("a", types.Float), f.field("b", types.Float)]),
165
- f.relation("ceil", [f.input_field("a", types.GenericDecimal), f.field("b", types.GenericDecimal)]),
166
- ],
167
- )
168
-
169
- floor = f.relation(
170
- "floor",
171
- [f.input_field("a", types.Number), f.field("b", types.Number)],
172
- overloads=[
173
- f.relation("floor", [f.input_field("a", types.Int64), f.field("b", types.Int64)]),
174
- f.relation("floor", [f.input_field("a", types.Int128), f.field("b", types.Int128)]),
175
- f.relation("floor", [f.input_field("a", types.Float), f.field("b", types.Float)]),
176
- f.relation("floor", [f.input_field("a", types.GenericDecimal), f.field("b", types.GenericDecimal)]),
177
- ],
178
- )
179
-
180
- isinf = f.relation("isinf", [f.input_field("a", types.Float)])
181
- isnan = f.relation("isnan", [f.input_field("a", types.Float)])
182
-
183
- pow = f.relation(
184
- "pow",
185
- [f.input_field("a", types.Number), f.input_field("b", types.Number), f.field("c", types.Float)],
186
- # Everything will be converted to float to avoid NaN results with other types
187
- overloads=[
188
- f.relation("pow", [f.input_field("a", types.Float), f.input_field("b", types.Float), f.field("c", types.Float)]),
189
- ],
190
- )
191
-
192
- cbrt = f.relation(
193
- "cbrt",
194
- [f.input_field("a", types.Number), f.field("b", types.Float)],
195
- overloads=[
196
- f.relation("cbrt", [f.input_field("a", types.Int64), f.field("b", types.Float)]),
197
- f.relation("cbrt", [f.input_field("a", types.Int128), f.field("b", types.Float)]),
198
- f.relation("cbrt", [f.input_field("a", types.Float), f.field("b", types.Float)]),
199
- f.relation("cbrt", [f.input_field("a", types.GenericDecimal), f.field("b", types.Float)])
200
- ],
201
- )
202
-
203
- factorial = f.relation(
204
- "factorial",
205
- [f.input_field("a", types.Number), f.field("b", types.Number)],
206
- overloads=[
207
- f.relation("factorial", [f.input_field("a", types.Int64), f.field("b", types.Int64)]),
208
- f.relation("factorial", [f.input_field("a", types.Int128), f.field("b", types.Int128)]),
209
- f.relation("factorial", [f.input_field("a", types.UInt128), f.field("b", types.UInt128)])
210
- ],
211
- )
212
-
213
- cos = f.relation(
214
- "cos",
215
- [f.input_field("a", types.Number), f.field("b", types.Float)],
216
- overloads=[
217
- f.relation("cos", [f.input_field("a", types.Int64), f.field("b", types.Float)]),
218
- f.relation("cos", [f.input_field("a", types.Int128), f.field("b", types.Float)]),
219
- f.relation("cos", [f.input_field("a", types.Float), f.field("b", types.Float)]),
220
- f.relation("cos", [f.input_field("a", types.GenericDecimal), f.field("b", types.Float)])
221
- ],
222
- )
223
-
224
- cosh = f.relation(
225
- "cosh",
226
- [f.input_field("a", types.Number), f.field("b", types.Float)],
227
- overloads=[
228
- f.relation("cosh", [f.input_field("a", types.Int64), f.field("b", types.Float)]),
229
- f.relation("cosh", [f.input_field("a", types.Int128), f.field("b", types.Float)]),
230
- f.relation("cosh", [f.input_field("a", types.Float), f.field("b", types.Float)]),
231
- f.relation("cosh", [f.input_field("a", types.GenericDecimal), f.field("b", types.Float)])
232
- ],
233
- )
234
-
235
- acos = f.relation(
236
- "acos",
237
- [f.input_field("a", types.Number), f.field("b", types.Float)],
238
- overloads=[
239
- f.relation("acos", [f.input_field("a", types.Int64), f.field("b", types.Float)]),
240
- f.relation("acos", [f.input_field("a", types.Int128), f.field("b", types.Float)]),
241
- f.relation("acos", [f.input_field("a", types.Float), f.field("b", types.Float)]),
242
- f.relation("acos", [f.input_field("a", types.GenericDecimal), f.field("b", types.Float)])
243
- ],
244
- )
245
-
246
- acosh = f.relation(
247
- "acosh",
248
- [f.input_field("a", types.Number), f.field("b", types.Float)],
249
- overloads=[
250
- f.relation("acosh", [f.input_field("a", types.Int64), f.field("b", types.Float)]),
251
- f.relation("acosh", [f.input_field("a", types.Int128), f.field("b", types.Float)]),
252
- f.relation("acosh", [f.input_field("a", types.Float), f.field("b", types.Float)]),
253
- f.relation("acosh", [f.input_field("a", types.GenericDecimal), f.field("b", types.Float)])
254
- ],
255
- )
256
-
257
- sin = f.relation(
258
- "sin",
259
- [f.input_field("a", types.Number), f.field("b", types.Float)],
260
- overloads=[
261
- f.relation("sin", [f.input_field("a", types.Int64), f.field("b", types.Float)]),
262
- f.relation("sin", [f.input_field("a", types.Int128), f.field("b", types.Float)]),
263
- f.relation("sin", [f.input_field("a", types.Float), f.field("b", types.Float)]),
264
- f.relation("sin", [f.input_field("a", types.GenericDecimal), f.field("b", types.Float)])
265
- ],
266
- )
267
-
268
- sinh = f.relation(
269
- "sinh",
270
- [f.input_field("a", types.Number), f.field("b", types.Float)],
271
- overloads=[
272
- f.relation("sinh", [f.input_field("a", types.Int64), f.field("b", types.Float)]),
273
- f.relation("sinh", [f.input_field("a", types.Int128), f.field("b", types.Float)]),
274
- f.relation("sinh", [f.input_field("a", types.Float), f.field("b", types.Float)]),
275
- f.relation("sinh", [f.input_field("a", types.GenericDecimal), f.field("b", types.Float)])
276
- ],
277
- )
278
-
279
- asin = f.relation(
280
- "asin",
281
- [f.input_field("a", types.Number), f.field("b", types.Float)],
282
- overloads=[
283
- f.relation("asin", [f.input_field("a", types.Int64), f.field("b", types.Float)]),
284
- f.relation("asin", [f.input_field("a", types.Int128), f.field("b", types.Float)]),
285
- f.relation("asin", [f.input_field("a", types.Float), f.field("b", types.Float)]),
286
- f.relation("asin", [f.input_field("a", types.GenericDecimal), f.field("b", types.Float)])
287
- ],
288
- )
289
-
290
- asinh = f.relation(
291
- "asinh",
292
- [f.input_field("a", types.Number), f.field("b", types.Float)],
293
- overloads=[
294
- f.relation("asinh", [f.input_field("a", types.Int64), f.field("b", types.Float)]),
295
- f.relation("asinh", [f.input_field("a", types.Int128), f.field("b", types.Float)]),
296
- f.relation("asinh", [f.input_field("a", types.Float), f.field("b", types.Float)]),
297
- f.relation("asinh", [f.input_field("a", types.GenericDecimal), f.field("b", types.Float)])
298
- ],
299
- )
300
-
301
- tan = f.relation(
302
- "tan",
303
- [f.input_field("a", types.Number), f.field("b", types.Float)],
304
- overloads=[
305
- f.relation("tan", [f.input_field("a", types.Int64), f.field("b", types.Float)]),
306
- f.relation("tan", [f.input_field("a", types.Int128), f.field("b", types.Float)]),
307
- f.relation("tan", [f.input_field("a", types.Float), f.field("b", types.Float)]),
308
- f.relation("tan", [f.input_field("a", types.GenericDecimal), f.field("b", types.Float)])
309
- ],
310
- )
311
-
312
- tanh = f.relation(
313
- "tanh",
314
- [f.input_field("a", types.Number), f.field("b", types.Float)],
315
- overloads=[
316
- f.relation("tanh", [f.input_field("a", types.Int64), f.field("b", types.Float)]),
317
- f.relation("tanh", [f.input_field("a", types.Int128), f.field("b", types.Float)]),
318
- f.relation("tanh", [f.input_field("a", types.Float), f.field("b", types.Float)]),
319
- f.relation("tanh", [f.input_field("a", types.GenericDecimal), f.field("b", types.Float)])
320
- ],
321
- )
322
-
323
- atan = f.relation(
324
- "atan",
325
- [f.input_field("a", types.Number), f.field("b", types.Float)],
326
- overloads=[
327
- f.relation("atan", [f.input_field("a", types.Int64), f.field("b", types.Float)]),
328
- f.relation("atan", [f.input_field("a", types.Int128), f.field("b", types.Float)]),
329
- f.relation("atan", [f.input_field("a", types.Float), f.field("b", types.Float)]),
330
- f.relation("atan", [f.input_field("a", types.GenericDecimal), f.field("b", types.Float)])
331
- ],
332
- )
333
-
334
- atanh = f.relation(
335
- "atanh",
336
- [f.input_field("a", types.Number), f.field("b", types.Float)],
337
- overloads=[
338
- f.relation("atanh", [f.input_field("a", types.Int64), f.field("b", types.Float)]),
339
- f.relation("atanh", [f.input_field("a", types.Int128), f.field("b", types.Float)]),
340
- f.relation("atanh", [f.input_field("a", types.Float), f.field("b", types.Float)]),
341
- f.relation("atanh", [f.input_field("a", types.GenericDecimal), f.field("b", types.Float)])
342
- ],
343
- )
344
- cot = f.relation(
345
- "cot",
346
- [f.input_field("a", types.Number), f.field("b", types.Float)],
347
- # Everything will be converted to float to avoid NaN results with other types
348
- overloads=[
349
- f.relation("cot", [f.input_field("a", types.Float), f.field("b", types.Float)])
350
- ],
351
- )
352
-
353
- acot = f.relation(
354
- "acot",
355
- [f.input_field("a", types.Number), f.field("b", types.Float)],
356
- # Everything will be converted to float to avoid NaN results with other types
357
- overloads=[
358
- f.relation("acot", [f.input_field("a", types.Float), f.field("b", types.Float)])
359
- ],
360
- )
361
-
362
- exp = f.relation(
363
- "exp",
364
- [f.input_field("a", types.Number), f.field("b", types.Float)],
365
- overloads=[
366
- f.relation("exp", [f.input_field("a", types.Int64), f.field("b", types.Float)]),
367
- f.relation("exp", [f.input_field("a", types.Int128), f.field("b", types.Float)]),
368
- f.relation("exp", [f.input_field("a", types.Float), f.field("b", types.Float)]),
369
- f.relation("exp", [f.input_field("a", types.GenericDecimal), f.field("b", types.Float)])
370
- ],
371
- )
372
-
373
- erf = f.relation(
374
- "erf",
375
- [f.input_field("a", types.Number), f.field("b", types.Float)],
376
- overloads=[
377
- # Everything will be converted to float to avoid NaN results with other types
378
- f.relation("erf", [f.input_field("a", types.Float), f.field("b", types.Float)]),
379
- ],
380
- )
381
-
382
- erfinv = f.relation(
383
- "erfinv",
384
- [f.input_field("a", types.Number), f.field("b", types.Float)],
385
- overloads=[
386
- # Everything will be converted to float to avoid NaN results with other types
387
- f.relation("erfinv", [f.input_field("a", types.Float), f.field("b", types.Float)]),
388
- ],
389
- )
390
-
391
-
392
- # Strings
393
- concat = f.relation("concat", [f.input_field("a", types.String), f.input_field("b", types.String), f.field("c", types.String)])
394
- num_chars = f.relation("num_chars", [f.input_field("a", types.String), f.field("b", types.Int64)])
395
- starts_with = f.relation("starts_with", [f.input_field("a", types.String), f.input_field("b", types.String)])
396
- ends_with = f.relation("ends_with", [f.input_field("a", types.String), f.input_field("b", types.String)])
397
- contains = f.relation("contains", [f.input_field("a", types.String), f.input_field("b", types.String)])
398
- substring = f.relation("substring", [f.input_field("a", types.String), f.input_field("b", types.Int64), f.input_field("c", types.Int64), f.field("d", types.String)])
399
- like_match = f.relation("like_match", [f.input_field("a", types.String), f.field("b", types.String)])
400
- lower = f.relation("lower", [f.input_field("a", types.String), f.field("b", types.String)])
401
- upper = f.relation("upper", [f.input_field("a", types.String), f.field("b", types.String)])
402
- strip = f.relation("strip", [f.input_field("a", types.String), f.field("b", types.String)])
403
- levenshtein = f.relation("levenshtein", [f.input_field("a", types.String), f.input_field("b", types.String), f.field("c", types.Int64)])
404
- join = f.relation("join", [f.input_field("a", types.AnyList), f.input_field("b", types.String), f.field("c", types.String)])
405
- replace = f.relation("replace", [f.input_field("a", types.String), f.input_field("b", types.String), f.input_field("c", types.String), f.field("d", types.String)])
406
- split = f.relation("split", [f.input_field("a", types.String), f.input_field("b", types.String), f.field("c", types.Int64), f.field("d", types.String)])
407
- # should be a separate builtin. SQL emitter compiles it differently
408
- split_part = f.relation("split_part", [f.input_field("a", types.String), f.input_field("b", types.String), f.field("c", types.Int64), f.field("d", types.String)])
409
-
410
- # regex
411
- regex_match = f.relation("regex_match", [f.input_field("a", types.String), f.input_field("b", types.String)])
412
- regex_match_all = f.relation("regex_match_all", [f.input_field("a", types.String), f.input_field("b", types.String), f.input_field("c", types.Int64), f.field("d", types.String)])
413
- capture_group_by_index = f.relation("capture_group_by_index", [f.input_field("a", types.String), f.input_field("b", types.String), f.input_field("c", types.Int64), f.input_field("d", types.Int64), f.field("e", types.String)])
414
- capture_group_by_name = f.relation("capture_group_by_name", [f.input_field("a", types.String), f.input_field("b", types.String), f.input_field("c", types.Int64), f.input_field("d", types.String), f.field("e", types.String)])
415
- escape_regex_metachars = f.relation("escape_regex_metachars", [f.input_field("a", types.String), f.field("b", types.String)])
416
-
417
- # Dates
418
- date_format = f.relation("date_format", [f.input_field("a", types.Date), f.input_field("b", types.String), f.field("c", types.String)])
419
- datetime_format = f.relation("datetime_format", [f.input_field("a", types.DateTime), f.input_field("b", types.String), f.input_field("c", types.String), f.field("d", types.String)])
420
- date_year = f.relation("date_year", [f.input_field("a", types.Date), f.field("b", types.Int64)])
421
- date_quarter = f.relation("date_quarter", [f.input_field("a", types.Date), f.field("b", types.Int64)])
422
- date_month = f.relation("date_month", [f.input_field("a", types.Date), f.field("b", types.Int64)])
423
- date_week = f.relation("date_week", [f.input_field("a", types.Date), f.field("b", types.Int64)])
424
- date_day = f.relation("date_day", [f.input_field("a", types.Date), f.field("b", types.Int64)])
425
- date_dayofyear = f.relation("date_dayofyear", [f.input_field("a", types.Date), f.field("b", types.Int64)])
426
- date_weekday = f.relation("date_weekday", [f.input_field("a", types.Date), f.field("b", types.Int64)])
427
- date_add = f.relation("date_add", [f.input_field("a", types.Date), f.input_field("b", types.Int64), f.field("c", types.Date)])
428
- dates_period_days = f.relation("dates_period_days", [f.input_field("a", types.Date), f.input_field("b", types.Date), f.field("c", types.Int64)])
429
- datetimes_period_milliseconds = f.relation("datetimes_period_milliseconds", [f.input_field("a", types.DateTime), f.input_field("b", types.DateTime), f.field("c", types.Int64)])
430
- date_subtract = f.relation("date_subtract", [f.input_field("a", types.Date), f.input_field("b", types.Int64), f.field("c", types.Date)])
431
- datetime_now = f.relation("datetime_now", [f.field("a", types.DateTime)])
432
- datetime_add = f.relation("datetime_add", [f.input_field("a", types.DateTime), f.input_field("b", types.Int64), f.field("c", types.DateTime)])
433
- datetime_subtract = f.relation("datetime_subtract", [f.input_field("a", types.DateTime), f.input_field("b", types.Int64), f.field("c", types.DateTime)])
434
- datetime_year = f.relation("datetime_year", [f.input_field("a", types.DateTime), f.input_field("b", types.String), f.field("c", types.Int64)])
435
- datetime_quarter = f.relation("datetime_quarter", [f.input_field("a", types.DateTime), f.input_field("b", types.String), f.field("c", types.Int64)])
436
- datetime_month = f.relation("datetime_month", [f.input_field("a", types.DateTime), f.input_field("b", types.String), f.field("c", types.Int64)])
437
- datetime_week = f.relation("datetime_week", [f.input_field("a", types.DateTime), f.input_field("b", types.String), f.field("c", types.Int64)])
438
- datetime_day = f.relation("datetime_day", [f.input_field("a", types.DateTime), f.input_field("b", types.String), f.field("c", types.Int64)])
439
- datetime_dayofyear = f.relation("datetime_dayofyear", [f.input_field("a", types.DateTime), f.input_field("b", types.String), f.field("c", types.Int64)])
440
- datetime_hour = f.relation("datetime_hour", [f.input_field("a", types.DateTime), f.input_field("b", types.String), f.field("c", types.Int64)])
441
- datetime_minute = f.relation("datetime_minute", [f.input_field("a", types.DateTime), f.input_field("b", types.String), f.field("c", types.Int64)])
442
- datetime_second = f.relation("datetime_second", [f.input_field("a", types.DateTime), f.field("c", types.Int64)])
443
- datetime_weekday = f.relation("datetime_weekday", [f.input_field("a", types.DateTime), f.input_field("b", types.String), f.field("c", types.Int64)])
444
-
445
- # Other
446
- range = f.relation(
447
- "range",
448
- [f.input_field("start", types.Number), f.input_field("stop", types.Number), f.input_field("step", types.Number), f.field("result", types.Number)],
449
- overloads=[
450
- f.relation("range", [f.input_field("start", types.Int64), f.input_field("stop", types.Int64), f.input_field("step", types.Int64), f.field("result", types.Int64)]),
451
- f.relation("range", [f.input_field("start", types.Int128), f.input_field("stop", types.Int128), f.input_field("step", types.Int128), f.field("result", types.Int128)]),
452
- ],
453
- )
454
-
455
- hash = f.relation("hash", [f.input_field("args", types.AnyList), f.field("hash", types.Hash)])
456
-
457
- uuid_to_string = f.relation("uuid_to_string", [f.input_field("a", types.Hash), f.field("b", types.String)])
458
- parse_uuid = f.relation("parse_uuid", [f.input_field("a", types.String), f.field("b", types.Hash)])
459
-
460
- # Raw source code to be attached to the transaction, when the backend understands this language
461
- raw_source = f.relation("raw_source", [f.input_field("lang", types.String), f.input_field("source", types.String)])
462
-
463
- unique = f.relation("unique", [f.input_field("args", types.AnyList)])
464
- exclusive = f.relation("exclusive", [f.input_field("args", types.AnyList)])
465
- anyof = f.relation("anyof", [f.input_field("args", types.AnyList)])
466
-
467
- #
468
- # Annotations
469
- #
470
-
471
- # indicates a relation is external to the system and, thus, backends should not rename or
472
- # otherwise modify it
473
- external = f.relation("external", [])
474
- external_annotation = f.annotation(external, [])
475
-
476
- # indicates an output is meant to be exported
477
- export = f.relation("export", [f.input_field("fqn", types.String)])
478
- # convenience for when there are no arguments (this is deprecated as fqn should always be used)
479
- export_annotation = f.annotation(export, [])
480
-
481
- # indicates this relation is a concept population
482
- concept_population = f.relation("concept_population", [])
483
- concept_relation_annotation = f.annotation(concept_population, [])
484
-
485
- # indicates this relation came in from CDC and will need to be shredded in Rel
486
- from_cdc = f.relation("from_cdc", [])
487
- from_cdc_annotation = f.annotation(from_cdc, [])
488
-
489
- # indicates an = lookup that is from a cast operation for value types
490
- from_cast = f.relation("from_cast", [])
491
- from_cast_annotation = f.annotation(from_cast, [])
492
-
493
- # indicates the original keys of an output (before they were replaced by a compound key)
494
- output_keys = f.relation("output_keys", [])
495
- output_keys_annotation = f.annotation(output_keys, [])
496
-
497
- # indicates this relation has a functional dependency
498
- function = f.relation("function", [f.input_field("code", types.Symbol)])
499
- function_checked_annotation = f.annotation(function, [f.lit("checked")])
500
- function_annotation = f.annotation(function, [])
501
- function_ranked = f.relation("function", [f.input_field("code", types.Symbol), f.input_field("rank", types.Int64)])
502
- def function_ranked_checked_annotation(k:int) -> ir.Annotation:
503
- return f.annotation(function_ranked, [f.lit("checked"), f.lit(k)])
504
- def function_ranked_annotation(k:int) -> ir.Annotation:
505
- return f.annotation(function_ranked, [f.lit(k)])
506
-
507
- # Indicates this relation should be tracked in telemetry. Supported for Relationships and Concepts.
508
- # `RAI_BackIR.with_relation_tracking` produces log messages at the start and end of each
509
- # SCC evaluation, if any declarations bear the `track` annotation.
510
- track = f.relation("track", [
511
- # BackIR evaluation expects 2 parameters on the track annotation: the tracking
512
- # library name and tracking relation name, which appear as log metadata fields.
513
- f.input_field("library", types.Symbol),
514
- f.input_field("relation", types.Symbol)
515
- ])
516
- track_annotation = f.annotation(track, [])
517
-
518
- # Enables config used by raicode/src/Recursion. Supported for Relationships and queries.
519
- recursion_config = f.relation("recursion_config", [
520
- f.input_field("config_key", types.Symbol),
521
- f.input_field("config_value", types.Int64)
522
- ])
523
- recursion_config_annotation = f.annotation(recursion_config, [])
524
-
525
- # All ir nodes marked by this annotation will be removed from the final metamodel before compilation.
526
- # Specifically it happens in `Flatten` pass when rewrites for `require` happen
527
- discharged = f.relation("discharged", [])
528
- discharged_annotation = f.annotation(discharged, [])
529
-
530
- # Require nodes with this annotation will be kept in the final metamodel to be emitted as
531
- # constraint declarations (LQP)
532
- declare_constraint = f.relation("declare_constraint", [])
533
- declare_constraint_annotation = f.annotation(declare_constraint, [])
534
-
535
- #
536
- # Aggregations
537
- #
538
- def aggregation(name: str, params: list[ir.Field], overload_types: Optional[list[tuple[ir.Type, ...]]] = None):
539
- """Defines an aggregation, which is a Relation whose first 2 fields are a projection
540
- and a group, followed by the params."""
541
- fields = params
542
- overloads = []
543
- if overload_types:
544
- param_sets = []
545
- for ts in overload_types:
546
- param_sets.append([ir.Field(param.name, t, param.input) for param, t in zip(params, ts)])
547
- overloads = [
548
- aggregation(name, typed_params, overload_types=None)
549
- for typed_params in param_sets
4
+ from . import metamodel as mm
5
+
6
+ class Relations:
7
+ """ Container for built-in relations in a library. """
8
+ def __init__(self):
9
+ self.data = dict[str, mm.Relation]()
10
+
11
+ def __getattr__(self, attr: str) -> mm.Relation:
12
+ return self.data[attr]
13
+
14
+ def __getitem__(self, attr: str) -> mm.Relation|None:
15
+ return self.data.get(attr)
16
+
17
+ class CoreLibrary:
18
+ """ Declare some core types and relations as class attributes for performant access. """
19
+ # abstract types
20
+ Any: mm.ScalarType
21
+ AnyEntity: mm.ScalarType
22
+ Numeric: mm.ScalarType
23
+ TypeVar: mm.ScalarType
24
+ EntityTypeVar: mm.ScalarType
25
+ Number: mm.ScalarType
26
+ ScaledNumber: mm.ScalarType
27
+ # meta types
28
+ Field: mm.ScalarType
29
+ Relation: mm.ScalarType
30
+ Type: mm.ScalarType
31
+ Enum: mm.ScalarType
32
+ # concrete primitive types
33
+ Boolean: mm.ScalarType
34
+ String: mm.ScalarType
35
+ Date: mm.ScalarType
36
+ DateTime: mm.ScalarType
37
+ Float: mm.ScalarType
38
+ Hash: mm.ScalarType
39
+ # type aliases
40
+ Integer: mm.NumberType
41
+ DefaultNumber: mm.NumberType
42
+ # binary operators
43
+ plus: mm.Relation
44
+ minus: mm.Relation
45
+ mul: mm.Relation
46
+ div: mm.Relation
47
+ trunc_div: mm.Relation
48
+ power: mm.Relation
49
+ mod: mm.Relation
50
+ # comparison operators
51
+ eq: mm.Relation
52
+ lt: mm.Relation
53
+ lte: mm.Relation
54
+ gt: mm.Relation
55
+ gte: mm.Relation
56
+ neq: mm.Relation
57
+ # typer relations
58
+ cast: mm.Relation
59
+
60
+ def __getitem__(self, attr: str) -> mm.Relation:
61
+ if attr in builtins._libraries["core"].data:
62
+ return builtins._libraries["core"].data[attr]
63
+ raise AttributeError(f"No built-in core attribute named '{attr}'.")
64
+
65
+ def __iter__(self):
66
+ yield from builtins._libraries["core"].data.values()
67
+
68
+ class Builtins:
69
+ # Registered libraries by name
70
+ _libraries = dict[str, Relations]()
71
+ # Special case the core library for more performant access
72
+ core = CoreLibrary()
73
+
74
+ def register(self, library_name: str, relation: mm.Relation):
75
+ """
76
+ Register a built-in relation under the given library name.
77
+ """
78
+ if library_name not in self._libraries:
79
+ self._libraries[library_name] = Relations()
80
+ self._libraries[library_name].data[relation.name] = relation
81
+ if library_name == "core":
82
+ setattr(CoreLibrary, relation.name, relation)
83
+
84
+ # Dynamic access to libraries (e.g., builtins.math.abs)
85
+ def __getattr__(self, attr: str) -> Relations:
86
+ if attr in self._libraries:
87
+ return self._libraries[attr]
88
+ raise AttributeError(f"No built-in library named '{attr}'.")
89
+
90
+
91
+ # Singleton instance of the builtins container
92
+ builtins = Builtins()
93
+
94
+ #------------------------------------------------------
95
+ # Helpers
96
+ #------------------------------------------------------
97
+ def is_function(r: mm.Relation) -> bool:
98
+ """ True if the relation is a function (i.e., it has inputs and has a single output). """
99
+ if len(r.fields) <= 1:
100
+ return False
101
+ # at least 2 fields, only 1 can be output
102
+ output_fields = [f for f in r.fields if not f.input]
103
+ return len(output_fields) == 1
104
+
105
+ def is_monotyped(r: mm.Relation) -> bool:
106
+ if len(r.fields) == 0:
107
+ return True
108
+
109
+ # all types must be the same
110
+ first = r.fields[0].type
111
+ if any(f.type != first for f in r.fields):
112
+ return False
113
+
114
+ if r.overloads:
115
+ # every overload must have all fields of the same type
116
+ for overload in r.overloads:
117
+ first = overload.types[0]
118
+ if any(f_type != first for f_type in overload.types):
119
+ return False
120
+ return True
121
+
122
+ def is_placeholder(relation: mm.Relation) -> bool:
123
+ """ Whether this relation is an unresolved placeholder that needs to be resolved. """
124
+ return isinstance(relation, mm.UnresolvedRelation)
125
+
126
+ def is_abstract(t: mm.Type) -> bool:
127
+ """ True if the type is abstract, or a collection or union containing an abstract type.
128
+ """
129
+ if isinstance(t, mm.ScalarType):
130
+ return t in [
131
+ builtins.core.Any,
132
+ builtins.core.AnyEntity,
133
+ builtins.core.Number,
134
+ builtins.core.ScaledNumber,
135
+ builtins.core.Numeric,
136
+ builtins.core.TypeVar,
137
+ builtins.core.EntityTypeVar
550
138
  ]
551
- return f.relation(name, fields, overloads=overloads)
552
-
553
- # concat = aggregation("concat", [
554
- # f.input_field("sep", types.String),
555
- # f.input_field("over", types.StringSet),
556
- # f.field("result", types.String)
557
- # ])
558
- # note that count does not need "over" because it counts the projection
559
- count = aggregation("count", [
560
- f.field("result", types.Int128)
561
- ])
562
- stats = aggregation("stats", [
563
- f.input_field("over", types.Number),
564
- f.field("std_dev", types.Number),
565
- f.field("mean", types.Number),
566
- f.field("median", types.Number),
567
- ])
568
- sum = aggregation("sum", [
569
- f.input_field("over", types.Number),
570
- f.field("result", types.Number)
571
- ], overload_types=[
572
- (types.Int64, types.Int64),
573
- (types.Int128, types.Int128),
574
- (types.Float, types.Float),
575
- (types.GenericDecimal, types.GenericDecimal),
576
- ])
577
- avg = aggregation("avg", [
578
- f.input_field("over", types.Number),
579
- f.field("result", types.Number)
580
- ], overload_types=[
581
- (types.Int64, types.Float), # nb. Float because Int / Int is Float
582
- (types.Int128, types.Float), # nb. Float because Int / Int is Float
583
- (types.Float, types.Float),
584
- (types.GenericDecimal, types.GenericDecimal),
585
- ])
586
- max = aggregation("max", [
587
- f.input_field("over", types.Any),
588
- f.field("result", types.Any)
589
- ], overload_types=[
590
- (types.Int64, types.Int64),
591
- (types.Int128, types.Int128),
592
- (types.Float, types.Float),
593
- (types.GenericDecimal, types.GenericDecimal),
594
- (types.String, types.String),
595
- (types.Date, types.Date),
596
- (types.DateTime, types.DateTime),
597
- (types.EntityTypeVar, types.EntityTypeVar),
598
- ])
599
- min = aggregation("min", [
600
- f.input_field("over", types.Any),
601
- f.field("result", types.Any)
602
- ], overload_types=[
603
- (types.Int64, types.Int64),
604
- (types.Int128, types.Int128),
605
- (types.Float, types.Float),
606
- (types.GenericDecimal, types.GenericDecimal),
607
- (types.String, types.String),
608
- (types.Date, types.Date),
609
- (types.DateTime, types.DateTime),
610
- (types.EntityTypeVar, types.EntityTypeVar),
611
- ])
612
-
613
-
614
- #
615
- # Pragmas
616
- #
617
- rule_reasoner_sem_vo = f.relation("rule_reasoner_sem_vo", [f.input_field("args", types.AnyList)])
618
- rule_reasoner_phys_vo = f.relation("rule_reasoner_phys_vo", [f.input_field("args", types.AnyList)])
619
-
620
-
621
- # TODO: these are Rel specific, should be moved from here
622
- # Conversions
623
- string = f.relation("string", [f.input_field("a", types.Any), f.field("b", types.String)])
624
- parse_date = f.relation("parse_date", [f.input_field("a", types.String), f.input_field("b", types.String), f.field("c", types.Date)])
625
- parse_datetime = f.relation("parse_datetime", [f.input_field("a", types.String), f.input_field("b", types.String), f.field("c", types.DateTime)])
626
- parse_decimal = f.relation("parse_decimal", [f.input_field("a", types.String), f.field("b", types.GenericDecimal)])
627
- parse_int64 = f.relation("parse_int64", [f.input_field("a", types.String), f.field("b", types.Int64)])
628
- parse_int128 = f.relation("parse_int128", [f.input_field("a", types.String), f.field("b", types.Int128)])
629
- parse_float = f.relation("parse_float", [f.input_field("a", types.String), f.field("b", types.Float)])
630
-
631
- nanosecond = f.relation("nanosecond", [f.input_field("a", types.Int64), f.field("b", types.Int64)])
632
- microsecond = f.relation("microsecond", [f.input_field("a", types.Int64), f.field("b", types.Int64)])
633
- millisecond = f.relation("millisecond", [f.input_field("a", types.Int64), f.field("b", types.Int64)])
634
- second = f.relation("second", [f.input_field("a", types.Int64), f.field("b", types.Int64)])
635
- minute = f.relation("minute", [f.input_field("a", types.Int64), f.field("b", types.Int64)])
636
- hour = f.relation("hour", [f.input_field("a", types.Int64), f.field("b", types.Int64)])
637
- day = f.relation("day", [f.input_field("a", types.Int64), f.field("b", types.Int64)])
638
- week = f.relation("week", [f.input_field("a", types.Int64), f.field("b", types.Int64)])
639
- month = f.relation("month", [f.input_field("a", types.Int64), f.field("b", types.Int64)])
640
- year = f.relation("year", [f.input_field("a", types.Int64), f.field("b", types.Int64)])
641
-
642
- cast = f.relation(
643
- "cast",
644
- [
645
- f.input_field("to_type", types.Any),
646
- f.input_field("source", types.Any),
647
- f.field("target", types.Any)
648
- ],
649
- annos=[from_cast_annotation]
650
- )
651
-
652
- # Date construction with less overhead
653
- construct_date = f.relation("construct_date", [f.input_field("year", types.Int64), f.input_field("month", types.Int64), f.input_field("day", types.Int64), f.field("date", types.Date)])
654
- construct_date_from_datetime = f.relation("construct_date_from_datetime", [f.input_field("datetime", types.DateTime), f.input_field("timezone", types.String), f.field("date", types.Date)])
655
- construct_datetime_ms_tz = f.relation("construct_datetime_ms_tz", [f.input_field("year", types.Int64), f.input_field("month", types.Int64), f.input_field("day", types.Int64), f.input_field("hour", types.Int64), f.input_field("minute", types.Int64), f.input_field("second", types.Int64), f.input_field("milliseconds", types.Int64), f.input_field("timezone", types.String), f.field("datetime", types.DateTime)])
656
-
657
- # Solver helpers
658
- rel_primitive_solverlib_fo_appl = f.relation("rel_primitive_solverlib_fo_appl", [
659
- f.input_field("op", types.Int64),
660
- f.input_field("args", types.AnyList),
661
- f.field("result", types.String),
662
- ])
663
- rel_primitive_solverlib_ho_appl = aggregation("rel_primitive_solverlib_ho_appl", [
664
- f.input_field("over", types.Any),
665
- f.field("op", types.Int64),
666
- f.field("result", types.String),
667
- ])
668
- implies = f.relation("implies", [f.input_field("a", types.Bool), f.input_field("b", types.Bool)])
669
- all_different = aggregation("all_different", [f.input_field("over", types.Any)])
670
- special_ordered_set_type_2 = aggregation("special_ordered_set_type_2", [f.input_field("rank", types.Any)])
671
-
672
- # graph primitive algorithm helpers
673
- infomap = aggregation("infomap", [
674
- f.input_field("weights", types.AnyList),
675
- f.input_field("node_count", types.Any),
676
- f.input_field("edge_count", types.Any),
677
- f.input_field("teleportation_rate", types.Float),
678
- f.input_field("visit_rate_tolerance", types.Float),
679
- f.input_field("level_tolerance", types.Float),
680
- f.input_field("sweep_tolerance", types.Float),
681
- f.input_field("max_levels", types.Int64),
682
- f.input_field("max_sweeps", types.Int64),
683
- f.input_field("randomization_seed", types.Int64),
684
- f.field("termination_info", types.String),
685
- f.field("node_index", types.Int64),
686
- f.field("community", types.Int64)
687
- ])
688
-
689
- louvain = aggregation("louvain", [
690
- f.input_field("weights", types.AnyList),
691
- f.input_field("node_count", types.Any),
692
- f.input_field("edge_count", types.Any),
693
- f.input_field("level_tolerance", types.Float),
694
- f.input_field("sweep_tolerance", types.Float),
695
- f.input_field("max_levels", types.Int64),
696
- f.input_field("max_sweeps", types.Int64),
697
- f.input_field("randomization_seed", types.Int64),
698
- f.field("termination_info", types.String),
699
- f.field("node_index", types.Int64),
700
- f.field("community", types.Int64)
701
- ])
702
-
703
- label_propagation = aggregation("label_propagation", [
704
- f.input_field("weights", types.AnyList),
705
- f.input_field("node_count", types.Any),
706
- f.input_field("edge_count", types.Any),
707
- f.input_field("max_sweeps", types.Int64),
708
- f.input_field("randomization_seed", types.Int64),
709
- f.field("termination_info", types.String),
710
- f.field("node_index", types.Int64),
711
- f.field("community", types.Int64)
712
- ])
713
-
714
- #
715
- # Public access to built-in relations
716
- #
717
-
718
- def is_builtin(r: ir.Relation):
719
- return r in builtin_relations or r in builtin_overloads
720
-
721
- def is_annotation(r: ir.Relation):
722
- return r in builtin_annotations
723
-
724
- def is_pragma(r: ir.Relation):
725
- return r in pragma_builtins
726
-
727
- def _compute_builtin_relations() -> list[ir.Relation]:
728
- module = sys.modules[__name__]
729
- relations = []
730
- for name in dir(module):
731
- builtin = getattr(module, name)
732
- if isinstance(builtin, ir.Relation) and builtin not in builtin_annotations:
733
- relations.append(builtin)
734
- return relations
735
-
736
- def _compute_builtin_overloads() -> list[ir.Relation]:
737
- module = sys.modules[__name__]
738
- overloads = []
739
- for name in dir(module):
740
- builtin = getattr(module, name)
741
- if isinstance(builtin, ir.Relation) and builtin not in builtin_annotations:
742
- if builtin.overloads:
743
- for overload in builtin.overloads:
744
- if overload not in builtin_annotations:
745
- overloads.append(overload)
746
- return overloads
747
-
748
- # manually maintain the list of relations that are actually annotations
749
- builtin_annotations = [external, export, concept_population, from_cdc, from_cast, track, recursion_config]
750
- builtin_annotations_by_name = dict((r.name, r) for r in builtin_annotations)
751
-
752
- builtin_relations = _compute_builtin_relations()
753
- builtin_overloads = _compute_builtin_overloads()
754
- builtin_relations_by_name = dict((r.name, r) for r in builtin_relations)
755
-
756
- string_binary_builtins = [num_chars, starts_with, ends_with, contains, like_match, lower, upper, strip, regex_match]
757
-
758
- date_builtins = [date_year, date_quarter, date_month, date_week, date_day, date_dayofyear, date_add, date_subtract,
759
- dates_period_days, datetime_add, datetime_subtract, datetimes_period_milliseconds, datetime_year,
760
- datetime_quarter, datetime_month, datetime_week, datetime_day, datetime_dayofyear, datetime_hour,
761
- datetime_minute, datetime_second, date_weekday, datetime_weekday]
762
-
763
- date_periods = [year, month, week, day, hour, minute, second, millisecond, microsecond, nanosecond]
764
-
765
- math_unary_builtins = [abs, *abs.overloads, sqrt, *sqrt.overloads,
766
- natural_log, *natural_log.overloads, log10, *log10.overloads,
767
- cbrt, *cbrt.overloads, factorial, *factorial.overloads, cos, *cos.overloads,
768
- cosh, *cosh.overloads, acos, *acos.overloads, acosh, *acosh.overloads, sin, *sin.overloads,
769
- sinh, *sinh.overloads, asin, *asin.overloads, asinh, *asinh.overloads, tan, *tan.overloads,
770
- tanh, *tanh.overloads, atan, *atan.overloads, atanh, *atanh.overloads, *ceil.overloads,
771
- cot, *cot.overloads, acot, *acot.overloads, floor, *floor.overloads, exp, *exp.overloads,
772
- erf, *erf.overloads, erfinv, *erfinv.overloads]
139
+ elif isinstance(t, mm.ListType):
140
+ return is_abstract(t.element_type)
141
+ elif isinstance(t, mm.UnionType):
142
+ return any(is_abstract(t) for t in t.types)
143
+ else:
144
+ return False
773
145
 
774
- math_builtins = [*math_unary_builtins, maximum, *maximum.overloads, minimum, *minimum.overloads, mod, *mod.overloads,
775
- pow, *pow.overloads, power, *power.overloads, log, *log.overloads, trunc_div, *trunc_div.overloads]
146
+ def is_type_var(t: mm.Type) -> bool:
147
+ return t in [
148
+ builtins.core.TypeVar,
149
+ builtins.core.EntityTypeVar,
150
+ ]
776
151
 
777
- pragma_builtins = [rule_reasoner_sem_vo, rule_reasoner_phys_vo]
152
+ def is_concrete(t: mm.Type) -> bool:
153
+ return not is_abstract(t)
154
+
155
+ def is_number(t: mm.Type) -> bool:
156
+ """ True if the type is a number type. """
157
+ # note that builtins.core.Number is a ScalarType that represents "any number type",
158
+ # whereas concrete numbers are represented by NumberType instances.
159
+ return isinstance(t, mm.NumberType) or t == builtins.core.Number or t == builtins.core.ScaledNumber
160
+
161
+ def is_numeric(t: mm.Type) -> bool:
162
+ """ True if the type is numeric (Number or Float). """
163
+ # TODO - we could check by supertype instead, but that would be slower
164
+ return t == builtins.core.Numeric or t == builtins.core.Float or is_number(t)
165
+
166
+ def is_primitive(t: mm.Type) -> bool:
167
+ """
168
+ True if the type is a primitive type (boolean, string, date, datetime, float, number).
169
+ """
170
+ return t in [
171
+ CoreLibrary.Boolean,
172
+ CoreLibrary.String,
173
+ CoreLibrary.Date,
174
+ CoreLibrary.DateTime,
175
+ CoreLibrary.Float
176
+ ] or is_number(t)
177
+
178
+ def is_value_type(type: mm.Type):
179
+ """ True if the type extends a primitive type (i.e., is a value type). """
180
+ return isinstance(type, mm.ScalarType) and not is_primitive(type) and get_primitive_supertype(type) is not None
181
+
182
+ def get_primitive_supertype(type: mm.Type) -> Optional[mm.Type]:
183
+ """ Search the type hierarchy for a primitive supertype. """
184
+ if isinstance(type, mm.ScalarType):
185
+ if is_primitive(type):
186
+ return type
187
+ # walk the hierarchy to find a base primitive
188
+ for parent in type.super_types:
189
+ if found := get_primitive_supertype(parent):
190
+ return found
191
+ if isinstance(type, mm.UnionType):
192
+ for t in type.types:
193
+ if found := get_primitive_supertype(t):
194
+ return found
195
+ return None
196
+
197
+ def get_number_supertype(type: mm.Type) -> Optional[mm.NumberType]:
198
+ x = get_primitive_supertype(type)
199
+ if isinstance(x, mm.NumberType):
200
+ return x
201
+ return None
202
+
203
+ def extends(type: mm.Type, supertype: mm.Type) -> bool:
204
+ """ True if `type` extends `supertype` in the type hierarchy. """
205
+ if type == supertype:
206
+ return True
207
+ if isinstance(type, mm.ScalarType):
208
+ for parent in type.super_types:
209
+ if extends(parent, supertype):
210
+ return True
211
+ return False