math-spec-mapping 0.2.5__tar.gz → 0.2.6__tar.gz

Sign up to get free protection for your applications and to get access to all the features.
Files changed (64) hide show
  1. {math_spec_mapping-0.2.5/src/math_spec_mapping.egg-info → math_spec_mapping-0.2.6}/PKG-INFO +5 -1
  2. {math_spec_mapping-0.2.5 → math_spec_mapping-0.2.6}/README.md +4 -0
  3. {math_spec_mapping-0.2.5 → math_spec_mapping-0.2.6}/pyproject.toml +4 -2
  4. math_spec_mapping-0.2.6/src/Load/implementations.py +16 -0
  5. {math_spec_mapping-0.2.5 → math_spec_mapping-0.2.6}/src/Load/load.py +2 -0
  6. {math_spec_mapping-0.2.5 → math_spec_mapping-0.2.6}/src/Load/type.py +32 -1
  7. {math_spec_mapping-0.2.5 → math_spec_mapping-0.2.6}/src/Reports/markdown.py +4 -0
  8. {math_spec_mapping-0.2.5 → math_spec_mapping-0.2.6}/src/__init__.py +2 -1
  9. {math_spec_mapping-0.2.5 → math_spec_mapping-0.2.6/src/math_spec_mapping.egg-info}/PKG-INFO +5 -1
  10. {math_spec_mapping-0.2.5 → math_spec_mapping-0.2.6}/src/math_spec_mapping.egg-info/SOURCES.txt +1 -0
  11. {math_spec_mapping-0.2.5 → math_spec_mapping-0.2.6}/src/math_spec_mapping.egg-info/top_level.txt +0 -2
  12. {math_spec_mapping-0.2.5 → math_spec_mapping-0.2.6}/LICENSE +0 -0
  13. {math_spec_mapping-0.2.5 → math_spec_mapping-0.2.6}/setup.cfg +0 -0
  14. {math_spec_mapping-0.2.5 → math_spec_mapping-0.2.6}/src/Classes/ActionTransmissionChannel.py +0 -0
  15. {math_spec_mapping-0.2.5 → math_spec_mapping-0.2.6}/src/Classes/Block.py +0 -0
  16. {math_spec_mapping-0.2.5 → math_spec_mapping-0.2.6}/src/Classes/BoundaryAction.py +0 -0
  17. {math_spec_mapping-0.2.5 → math_spec_mapping-0.2.6}/src/Classes/ControlAction.py +0 -0
  18. {math_spec_mapping-0.2.5 → math_spec_mapping-0.2.6}/src/Classes/Entity.py +0 -0
  19. {math_spec_mapping-0.2.5 → math_spec_mapping-0.2.6}/src/Classes/MathSpec.py +0 -0
  20. {math_spec_mapping-0.2.5 → math_spec_mapping-0.2.6}/src/Classes/Mechanism.py +0 -0
  21. {math_spec_mapping-0.2.5 → math_spec_mapping-0.2.6}/src/Classes/Metric.py +0 -0
  22. {math_spec_mapping-0.2.5 → math_spec_mapping-0.2.6}/src/Classes/Parameter.py +0 -0
  23. {math_spec_mapping-0.2.5 → math_spec_mapping-0.2.6}/src/Classes/Policy.py +0 -0
  24. {math_spec_mapping-0.2.5 → math_spec_mapping-0.2.6}/src/Classes/Space.py +0 -0
  25. {math_spec_mapping-0.2.5 → math_spec_mapping-0.2.6}/src/Classes/State.py +0 -0
  26. {math_spec_mapping-0.2.5 → math_spec_mapping-0.2.6}/src/Classes/StateUpdateTransmissionChannel.py +0 -0
  27. {math_spec_mapping-0.2.5 → math_spec_mapping-0.2.6}/src/Classes/StatefulMetric.py +0 -0
  28. {math_spec_mapping-0.2.5 → math_spec_mapping-0.2.6}/src/Classes/Type.py +0 -0
  29. {math_spec_mapping-0.2.5 → math_spec_mapping-0.2.6}/src/Classes/__init__.py +0 -0
  30. {math_spec_mapping-0.2.5 → math_spec_mapping-0.2.6}/src/Convenience/__init__.py +0 -0
  31. {math_spec_mapping-0.2.5 → math_spec_mapping-0.2.6}/src/Convenience/documentation.py +0 -0
  32. {math_spec_mapping-0.2.5 → math_spec_mapping-0.2.6}/src/Convenience/starter.py +0 -0
  33. {math_spec_mapping-0.2.5 → math_spec_mapping-0.2.6}/src/Load/__init__.py +0 -0
  34. {math_spec_mapping-0.2.5 → math_spec_mapping-0.2.6}/src/Load/action_transmission_channel.py +0 -0
  35. {math_spec_mapping-0.2.5 → math_spec_mapping-0.2.6}/src/Load/boundary_actions.py +0 -0
  36. {math_spec_mapping-0.2.5 → math_spec_mapping-0.2.6}/src/Load/control_actions.py +0 -0
  37. {math_spec_mapping-0.2.5 → math_spec_mapping-0.2.6}/src/Load/displays.py +0 -0
  38. {math_spec_mapping-0.2.5 → math_spec_mapping-0.2.6}/src/Load/entities.py +0 -0
  39. {math_spec_mapping-0.2.5 → math_spec_mapping-0.2.6}/src/Load/general.py +0 -0
  40. {math_spec_mapping-0.2.5 → math_spec_mapping-0.2.6}/src/Load/mechanism.py +0 -0
  41. {math_spec_mapping-0.2.5 → math_spec_mapping-0.2.6}/src/Load/metrics.py +0 -0
  42. {math_spec_mapping-0.2.5 → math_spec_mapping-0.2.6}/src/Load/parameters.py +0 -0
  43. {math_spec_mapping-0.2.5 → math_spec_mapping-0.2.6}/src/Load/policy.py +0 -0
  44. {math_spec_mapping-0.2.5 → math_spec_mapping-0.2.6}/src/Load/spaces.py +0 -0
  45. {math_spec_mapping-0.2.5 → math_spec_mapping-0.2.6}/src/Load/state_update_transmission_channels.py +0 -0
  46. {math_spec_mapping-0.2.5 → math_spec_mapping-0.2.6}/src/Load/stateful_metrics.py +0 -0
  47. {math_spec_mapping-0.2.5 → math_spec_mapping-0.2.6}/src/Load/states.py +0 -0
  48. {math_spec_mapping-0.2.5 → math_spec_mapping-0.2.6}/src/Load/wiring.py +0 -0
  49. {math_spec_mapping-0.2.5 → math_spec_mapping-0.2.6}/src/Reports/__init__.py +0 -0
  50. {math_spec_mapping-0.2.5 → math_spec_mapping-0.2.6}/src/Reports/boundary_actions.py +0 -0
  51. {math_spec_mapping-0.2.5 → math_spec_mapping-0.2.6}/src/Reports/control_actions.py +0 -0
  52. {math_spec_mapping-0.2.5 → math_spec_mapping-0.2.6}/src/Reports/general.py +0 -0
  53. {math_spec_mapping-0.2.5 → math_spec_mapping-0.2.6}/src/Reports/html.py +0 -0
  54. {math_spec_mapping-0.2.5 → math_spec_mapping-0.2.6}/src/Reports/mechanisms.py +0 -0
  55. {math_spec_mapping-0.2.5 → math_spec_mapping-0.2.6}/src/Reports/node_map.py +0 -0
  56. {math_spec_mapping-0.2.5 → math_spec_mapping-0.2.6}/src/Reports/parameters.py +0 -0
  57. {math_spec_mapping-0.2.5 → math_spec_mapping-0.2.6}/src/Reports/policies.py +0 -0
  58. {math_spec_mapping-0.2.5 → math_spec_mapping-0.2.6}/src/Reports/spaces.py +0 -0
  59. {math_spec_mapping-0.2.5 → math_spec_mapping-0.2.6}/src/Reports/state.py +0 -0
  60. {math_spec_mapping-0.2.5 → math_spec_mapping-0.2.6}/src/Reports/tables.py +0 -0
  61. {math_spec_mapping-0.2.5 → math_spec_mapping-0.2.6}/src/Reports/wiring.py +0 -0
  62. {math_spec_mapping-0.2.5 → math_spec_mapping-0.2.6}/src/math_spec_mapping.egg-info/dependency_links.txt +0 -0
  63. {math_spec_mapping-0.2.5 → math_spec_mapping-0.2.6}/src/math_spec_mapping.egg-info/requires.txt +0 -0
  64. {math_spec_mapping-0.2.5 → math_spec_mapping-0.2.6}/src/schema.py +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: math_spec_mapping
3
- Version: 0.2.5
3
+ Version: 0.2.6
4
4
  Summary: A library for easy mapping of mathematical specifications.
5
5
  Author-email: Sean McOwen <Sean@Block.Science>
6
6
  Classifier: Programming Language :: Python :: 3
@@ -23,6 +23,10 @@ It uses block diagram wirings and spaces to represent the actions in complex sys
23
23
 
24
24
  One good example is the [wiring report](https://github.com/SeanMcOwen/Root-Finding-Simulation/blob/main/MSML/reports/Simulation%20Block.md) for the Root Finding Simulation canonical example.
25
25
 
26
+ ## Installing the library
27
+
28
+ To install the library, simply pip install by running "pip install math_spec_mapping"
29
+
26
30
  ## Why MSML?
27
31
 
28
32
  Writing mathematical specifications can be a difficult process, especially when variable names are changed or new mechanisms are introduced. MSML seeks to streamline the process with automations as well as enhance the abilities of static math specs to deliver deeper insights. Because it is automated, one can write specifications at different levels of details or for different purposes.
@@ -8,6 +8,10 @@ It uses block diagram wirings and spaces to represent the actions in complex sys
8
8
 
9
9
  One good example is the [wiring report](https://github.com/SeanMcOwen/Root-Finding-Simulation/blob/main/MSML/reports/Simulation%20Block.md) for the Root Finding Simulation canonical example.
10
10
 
11
+ ## Installing the library
12
+
13
+ To install the library, simply pip install by running "pip install math_spec_mapping"
14
+
11
15
  ## Why MSML?
12
16
 
13
17
  Writing mathematical specifications can be a difficult process, especially when variable names are changed or new mechanisms are introduced. MSML seeks to streamline the process with automations as well as enhance the abilities of static math specs to deliver deeper insights. Because it is automated, one can write specifications at different levels of details or for different purposes.
@@ -3,7 +3,7 @@ requires = ["setuptools>=61.0"]
3
3
  build-backend = "setuptools.build_meta"
4
4
  [project]
5
5
  name = "math_spec_mapping"
6
- version = "0.2.5"
6
+ version = "0.2.6"
7
7
  authors = [
8
8
  { name="Sean McOwen", email="Sean@Block.Science" },
9
9
  ]
@@ -19,4 +19,6 @@ classifiers = [
19
19
  "Programming Language :: Python :: 3",
20
20
  "License :: OSI Approved :: MIT License",
21
21
  "Operating System :: OS Independent",
22
- ]
22
+ ]
23
+ [tool.setuptools.packages.find]
24
+ where = ["src"]
@@ -0,0 +1,16 @@
1
+ import os
2
+
3
+
4
+ def load_implementations(ms):
5
+ implementations = {}
6
+ python_path = "src/Implementations/Python/__init__.py"
7
+ if os.path.exists(python_path):
8
+ implementations["python"] = load_python_implementations()
9
+
10
+ ms["Implementations"] = implementations
11
+
12
+
13
+ def load_python_implementations():
14
+ from src.Implementations.Python import implementation
15
+
16
+ return implementation
@@ -16,6 +16,7 @@ from .wiring import load_wiring
16
16
  from .type import load_types, load_type_keys
17
17
  from .metrics import load_metrics
18
18
  from .displays import load_displays
19
+ from .implementations import load_implementations
19
20
 
20
21
 
21
22
  def load_from_json(json: Dict) -> MathSpec:
@@ -39,6 +40,7 @@ def load_from_json(json: Dict) -> MathSpec:
39
40
  # Do loading one by one to transfer the json
40
41
 
41
42
  load_type_keys(ms)
43
+ load_implementations(ms)
42
44
  load_types(ms, json)
43
45
  load_spaces(ms, json)
44
46
  load_states(ms, json)
@@ -41,6 +41,10 @@ def convert_type(data, ms):
41
41
  if type_name in ms["Type Keys"]["typescript"]:
42
42
  data["type"]["typescript"] = ms["Type Keys"]["typescript"][type_name]
43
43
  data["type_name"]["typescript"] = ms["Type Keys"]["typescript"][type_name]
44
+ if "julia" in ms["Type Keys"]:
45
+ if type_name in ms["Type Keys"]["julia"]:
46
+ data["type"]["julia"] = ms["Type Keys"]["julia"][type_name]
47
+ data["type_name"]["julia"] = ms["Type Keys"]["julia"][type_name]
44
48
 
45
49
  # Build the type object
46
50
  return Type(data)
@@ -89,13 +93,40 @@ def load_typescript_type_key(path):
89
93
  return type_definitions
90
94
 
91
95
 
92
- def load_type_keys(ms) -> dict:
96
+ def load_julia_type_key(path):
97
+ with open(path, "r") as file:
98
+ type_definitions = file.read()
99
+ type_definitions = type_definitions.split("end")
100
+ type_definitions = [x.strip() for x in type_definitions]
101
+ type_definitions = [x for x in type_definitions if len(x) > 0]
102
+
103
+ hold = type_definitions[:]
104
+ type_definitions = {}
105
+ for x in hold:
106
+ name = x
107
+ if x.startswith("abstract type"):
108
+ name = name[14:]
109
+ name = name[: name.index("<:")].strip()
110
+ elif x.startswith("struct"):
111
+ name = name[7:]
112
+ name = name[: name.index("\n")].strip()
113
+ else:
114
+ assert False
115
+
116
+ type_definitions[name] = x
117
+ return type_definitions
118
+
119
+
120
+ def load_type_keys(ms):
93
121
  type_keys = {}
94
122
  python_path = "src/TypeMappings/types.py"
95
123
  typescript_path = "src/TypeMappings/types.ts"
124
+ julia_path = "src/TypeMappings/types.jl"
96
125
  if os.path.exists(python_path):
97
126
  type_keys["python"] = load_python_type_key()
98
127
  if os.path.exists(typescript_path):
99
128
  type_keys["typescript"] = load_typescript_type_key(typescript_path)
129
+ if os.path.exists(julia_path):
130
+ type_keys["julia"] = load_julia_type_key(julia_path)
100
131
 
101
132
  ms["Type Keys"] = type_keys
@@ -99,6 +99,10 @@ def write_types_markdown_report(ms, path, t, add_metadata=True):
99
99
  out += "### Typescript Type\n"
100
100
  out += t.type_name["typescript"]
101
101
  out += "\n"
102
+ if "julia" in t.type:
103
+ out += "### Julia Type\n"
104
+ out += t.type_name["julia"]
105
+ out += "\n"
102
106
  out += "\n"
103
107
  out += "## Notes"
104
108
  out += "\n\n"
@@ -26,4 +26,5 @@ from .Reports import (
26
26
  write_all_markdown_reports,
27
27
  )
28
28
  from .schema import schema
29
- from .Convenience import write_top_level_json_description
29
+
30
+ # from .Convenience import write_top_level_json_description
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: math_spec_mapping
3
- Version: 0.2.5
3
+ Version: 0.2.6
4
4
  Summary: A library for easy mapping of mathematical specifications.
5
5
  Author-email: Sean McOwen <Sean@Block.Science>
6
6
  Classifier: Programming Language :: Python :: 3
@@ -23,6 +23,10 @@ It uses block diagram wirings and spaces to represent the actions in complex sys
23
23
 
24
24
  One good example is the [wiring report](https://github.com/SeanMcOwen/Root-Finding-Simulation/blob/main/MSML/reports/Simulation%20Block.md) for the Root Finding Simulation canonical example.
25
25
 
26
+ ## Installing the library
27
+
28
+ To install the library, simply pip install by running "pip install math_spec_mapping"
29
+
26
30
  ## Why MSML?
27
31
 
28
32
  Writing mathematical specifications can be a difficult process, especially when variable names are changed or new mechanisms are introduced. MSML seeks to streamline the process with automations as well as enhance the abilities of static math specs to deliver deeper insights. Because it is automated, one can write specifications at different levels of details or for different purposes.
@@ -29,6 +29,7 @@ src/Load/control_actions.py
29
29
  src/Load/displays.py
30
30
  src/Load/entities.py
31
31
  src/Load/general.py
32
+ src/Load/implementations.py
32
33
  src/Load/load.py
33
34
  src/Load/mechanism.py
34
35
  src/Load/metrics.py
@@ -2,5 +2,3 @@ Classes
2
2
  Convenience
3
3
  Load
4
4
  Reports
5
- __init__
6
- schema