math-spec-mapping 0.2.4__py3-none-any.whl → 0.2.5__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.
- Classes/Block.py +12 -0
- Convenience/__init__.py +1 -0
- Convenience/documentation.py +49 -0
- Load/stateful_metrics.py +4 -0
- Load/type.py +1 -0
- Reports/html.py +11 -4
- Reports/markdown.py +48 -4
- __init__.py +1 -0
- {math_spec_mapping-0.2.4.dist-info → math_spec_mapping-0.2.5.dist-info}/METADATA +1 -1
- {math_spec_mapping-0.2.4.dist-info → math_spec_mapping-0.2.5.dist-info}/RECORD +13 -12
- {math_spec_mapping-0.2.4.dist-info → math_spec_mapping-0.2.5.dist-info}/LICENSE +0 -0
- {math_spec_mapping-0.2.4.dist-info → math_spec_mapping-0.2.5.dist-info}/WHEEL +0 -0
- {math_spec_mapping-0.2.4.dist-info → math_spec_mapping-0.2.5.dist-info}/top_level.txt +0 -0
    
        Classes/Block.py
    CHANGED
    
    | @@ -141,6 +141,18 @@ class Block: | |
| 141 141 | 
             
                                self.all_updates.extend(x.all_updates)
         | 
| 142 142 | 
             
                    self.all_updates = list(set(self.all_updates))
         | 
| 143 143 |  | 
| 144 | 
            +
                def components_full(self):
         | 
| 145 | 
            +
                    q = [self]
         | 
| 146 | 
            +
                    out = []
         | 
| 147 | 
            +
                    while len(q) > 0:
         | 
| 148 | 
            +
                        cur = q.pop()
         | 
| 149 | 
            +
                        if hasattr(cur, "components"):
         | 
| 150 | 
            +
                            q.extend(cur.components)
         | 
| 151 | 
            +
                        else:
         | 
| 152 | 
            +
                            out.append(cur)
         | 
| 153 | 
            +
                    out = list(set(out))
         | 
| 154 | 
            +
                    return out
         | 
| 155 | 
            +
             | 
| 144 156 |  | 
| 145 157 | 
             
            class ParallelBlock(Block):
         | 
| 146 158 | 
             
                def __init__(self, data: Dict):
         | 
    
        Convenience/__init__.py
    CHANGED
    
    | @@ -0,0 +1 @@ | |
| 1 | 
            +
            from .documentation import write_top_level_json_description
         | 
| @@ -0,0 +1,49 @@ | |
| 1 | 
            +
            from src import schema
         | 
| 2 | 
            +
             | 
| 3 | 
            +
             | 
| 4 | 
            +
            def write_json_description(schema, key, name):
         | 
| 5 | 
            +
                out = "- **{}**: ".format(name)
         | 
| 6 | 
            +
             | 
| 7 | 
            +
                out += schema["definitions"][key]["description"]
         | 
| 8 | 
            +
                out += "\n"
         | 
| 9 | 
            +
                return out
         | 
| 10 | 
            +
             | 
| 11 | 
            +
             | 
| 12 | 
            +
            def write_top_level_json_description(indent_level):
         | 
| 13 | 
            +
             | 
| 14 | 
            +
                out = "#{} MSML Components".format("#" * indent_level)
         | 
| 15 | 
            +
                out += "\n\n"
         | 
| 16 | 
            +
                out += "MSML extends GDS with multiple types of blocks and other enhancements. Below are the definitions of top level components."
         | 
| 17 | 
            +
                out += "\n\n"
         | 
| 18 | 
            +
             | 
| 19 | 
            +
                out += "##{} Types & Spaces".format("#" * indent_level)
         | 
| 20 | 
            +
                out += "\n\n"
         | 
| 21 | 
            +
             | 
| 22 | 
            +
                out += write_json_description(schema, "Type", "Type")
         | 
| 23 | 
            +
                out += write_json_description(schema, "Space", "Space")
         | 
| 24 | 
            +
             | 
| 25 | 
            +
                out += "\n"
         | 
| 26 | 
            +
             | 
| 27 | 
            +
                out += "##{} Entities, States, Parameters & Metrics".format("#" * indent_level)
         | 
| 28 | 
            +
                out += "\n\n"
         | 
| 29 | 
            +
             | 
| 30 | 
            +
                out += write_json_description(schema, "Entity", "Entity")
         | 
| 31 | 
            +
                out += write_json_description(schema, "State", "State")
         | 
| 32 | 
            +
                out += write_json_description(schema, "StatefulMetric", "Stateful Metric")
         | 
| 33 | 
            +
                out += write_json_description(schema, "Parameter", "Parameter")
         | 
| 34 | 
            +
                out += write_json_description(schema, "Metric", "Metric")
         | 
| 35 | 
            +
             | 
| 36 | 
            +
                out += "\n"
         | 
| 37 | 
            +
             | 
| 38 | 
            +
                out += "##{} Blocks & Wiring".format("#" * indent_level)
         | 
| 39 | 
            +
                out += "\n\n"
         | 
| 40 | 
            +
             | 
| 41 | 
            +
                out += write_json_description(schema, "BoundaryAction", "Boundary Action")
         | 
| 42 | 
            +
                out += write_json_description(schema, "ControlAction", "Control Action")
         | 
| 43 | 
            +
                out += write_json_description(schema, "Policy", "Policy")
         | 
| 44 | 
            +
                out += write_json_description(schema, "Mechanism", "Mechanism")
         | 
| 45 | 
            +
                out += write_json_description(schema, "Wiring", "Wiring")
         | 
| 46 | 
            +
             | 
| 47 | 
            +
                out += "\n"
         | 
| 48 | 
            +
             | 
| 49 | 
            +
                return out
         | 
    
        Load/stateful_metrics.py
    CHANGED
    
    | @@ -55,5 +55,9 @@ def load_stateful_metrics(ms: Dict, json: Dict) -> None: | |
| 55 55 | 
             
                """
         | 
| 56 56 |  | 
| 57 57 | 
             
                ms["Stateful Metrics"] = {}
         | 
| 58 | 
            +
                check = []
         | 
| 58 59 | 
             
                for sm in json["Stateful Metrics"]:
         | 
| 59 60 | 
             
                    ms["Stateful Metrics"][sm["name"]] = convert_stateful_metric(ms, sm)
         | 
| 61 | 
            +
                    for x in ms["Stateful Metrics"][sm["name"]].metrics:
         | 
| 62 | 
            +
                        assert x.name not in check, "{} stateful metric name is repeated"
         | 
| 63 | 
            +
                        check.append(x)
         | 
    
        Load/type.py
    CHANGED
    
    | @@ -37,6 +37,7 @@ def convert_type(data, ms): | |
| 37 37 | 
             
                            data["type_name"]["python"] = data["type"]["python"].__repr__()
         | 
| 38 38 | 
             
                        else:
         | 
| 39 39 | 
             
                            data["type_name"]["python"] = data["type"]["python"].__name__
         | 
| 40 | 
            +
                if "typescript" in ms["Type Keys"]:
         | 
| 40 41 | 
             
                    if type_name in ms["Type Keys"]["typescript"]:
         | 
| 41 42 | 
             
                        data["type"]["typescript"] = ms["Type Keys"]["typescript"][type_name]
         | 
| 42 43 | 
             
                        data["type_name"]["typescript"] = ms["Type Keys"]["typescript"][type_name]
         | 
    
        Reports/html.py
    CHANGED
    
    | @@ -147,11 +147,18 @@ def write_spec_tree( | |
| 147 147 | 
             
                out += symbol1 + "**Stateful Metrics**\n"
         | 
| 148 148 | 
             
                for name in ms.stateful_metrics.keys():
         | 
| 149 149 | 
             
                    if linking:
         | 
| 150 | 
            -
                        out += symbol2 + " | 
| 150 | 
            +
                        out += symbol2 + "{}".format(name) + "\n"
         | 
| 151 151 | 
             
                    else:
         | 
| 152 152 | 
             
                        out += symbol2 + name + "\n"
         | 
| 153 153 | 
             
                    for var in ms.stateful_metrics[name].metrics:
         | 
| 154 | 
            -
                        out += symbol3 + var.name + "\n"
         | 
| 154 | 
            +
                        out += symbol3 + "[[{}]]".format(var.name) + "\n"
         | 
| 155 | 
            +
             | 
| 156 | 
            +
                out += symbol1 + "**Types**\n"
         | 
| 157 | 
            +
                for name in ms.types.keys():
         | 
| 158 | 
            +
                    if linking:
         | 
| 159 | 
            +
                        out += symbol2 + "[[{}]]".format(name) + "\n"
         | 
| 160 | 
            +
                    else:
         | 
| 161 | 
            +
                        out += symbol2 + name + "\n"
         | 
| 155 162 |  | 
| 156 163 | 
             
                out += symbol1 + "**Spaces**\n"
         | 
| 157 164 | 
             
                for name in ms.spaces.keys():
         | 
| @@ -162,11 +169,11 @@ def write_spec_tree( | |
| 162 169 | 
             
                out += symbol1 + "**Parameters**\n"
         | 
| 163 170 | 
             
                for name in ms.parameters.data.keys():
         | 
| 164 171 | 
             
                    if linking:
         | 
| 165 | 
            -
                        out += symbol2 + " | 
| 172 | 
            +
                        out += symbol2 + "{}".format(name) + "\n"
         | 
| 166 173 | 
             
                    else:
         | 
| 167 174 | 
             
                        out += symbol2 + name + "\n"
         | 
| 168 175 | 
             
                    for param in [x.name for x in ms.parameters.data[name].parameters]:
         | 
| 169 | 
            -
                        out += symbol3 + param + "\n"
         | 
| 176 | 
            +
                        out += symbol3 + "[[{}]]".format(param) + "\n"
         | 
| 170 177 |  | 
| 171 178 | 
             
                out += symbol1 + "**Boundary Actions**\n"
         | 
| 172 179 | 
             
                for name in ms.boundary_actions.keys():
         | 
    
        Reports/markdown.py
    CHANGED
    
    | @@ -135,6 +135,12 @@ def write_boundary_action_markdown_report(ms, path, boundary_action, add_metadat | |
| 135 135 | 
             
                    out += "\n"
         | 
| 136 136 | 
             
                out += "\n"
         | 
| 137 137 |  | 
| 138 | 
            +
                out += "## Followed By\n"
         | 
| 139 | 
            +
                for i, x in enumerate([x[0] for x in boundary_action.calls]):
         | 
| 140 | 
            +
                    out += "{}. [[{}]]".format(i + 1, x.label)
         | 
| 141 | 
            +
                    out += "\n"
         | 
| 142 | 
            +
                out += "\n"
         | 
| 143 | 
            +
             | 
| 138 144 | 
             
                out += "## Constraints"
         | 
| 139 145 | 
             
                for i, x in enumerate(boundary_action.constraints):
         | 
| 140 146 | 
             
                    out += "{}. {}".format(i + 1, x)
         | 
| @@ -342,6 +348,12 @@ def write_control_action_markdown_report(ms, path, control_action, add_metadata= | |
| 342 348 | 
             
                out += control_action.description
         | 
| 343 349 | 
             
                out += "\n"
         | 
| 344 350 |  | 
| 351 | 
            +
                out += "## Followed By\n"
         | 
| 352 | 
            +
                for i, x in enumerate([x[0] for x in control_action.calls]):
         | 
| 353 | 
            +
                    out += "{}. [[{}]]".format(i + 1, x.label)
         | 
| 354 | 
            +
                    out += "\n"
         | 
| 355 | 
            +
                out += "\n"
         | 
| 356 | 
            +
             | 
| 345 357 | 
             
                out += "## Constraints"
         | 
| 346 358 | 
             
                for i, x in enumerate(control_action.constraints):
         | 
| 347 359 | 
             
                    out += "{}. {}".format(i + 1, x)
         | 
| @@ -406,7 +418,14 @@ def write_wiring_markdown_report(ms, path, wiring, add_metadata=True): | |
| 406 418 |  | 
| 407 419 | 
             
                out += "\n"
         | 
| 408 420 |  | 
| 409 | 
            -
                out += "##  | 
| 421 | 
            +
                out += "## All Blocks\n"
         | 
| 422 | 
            +
                for i, x in enumerate(wiring.components_full()):
         | 
| 423 | 
            +
                    out += "{}. [[{}]]".format(i + 1, x.name)
         | 
| 424 | 
            +
                    out += "\n"
         | 
| 425 | 
            +
             | 
| 426 | 
            +
                out += "\n"
         | 
| 427 | 
            +
             | 
| 428 | 
            +
                out += "## Constraints\n"
         | 
| 410 429 | 
             
                for i, x in enumerate(wiring.constraints):
         | 
| 411 430 | 
             
                    out += "{}. {}".format(i + 1, x)
         | 
| 412 431 | 
             
                    out += "\n"
         | 
| @@ -510,7 +529,7 @@ def write_stateful_metrics_markdown_report(ms, path, metric, add_metadata=True): | |
| 510 529 |  | 
| 511 530 | 
             
                out += "## Variables Used\n"
         | 
| 512 531 | 
             
                for i, x in enumerate(metric.variables_used):
         | 
| 513 | 
            -
                    out += "{}. {}.{}".format(i + 1, x[0], x[1])
         | 
| 532 | 
            +
                    out += "{}. [[{}]].{}".format(i + 1, x[0], x[1])
         | 
| 514 533 | 
             
                    out += "\n"
         | 
| 515 534 | 
             
                out += "\n"
         | 
| 516 535 |  | 
| @@ -544,12 +563,18 @@ def write_metrics_markdown_report(ms, path, metric, add_metadata=True): | |
| 544 563 | 
             
                out += "## Parameters Used\n"
         | 
| 545 564 | 
             
                for i, x in enumerate(metric.parameters_used):
         | 
| 546 565 | 
             
                    out += "{}. [[{}]]".format(i + 1, x)
         | 
| 566 | 
            +
                    var = ms.parameters.parameter_map[x]
         | 
| 567 | 
            +
                    if var.symbol:
         | 
| 568 | 
            +
                        out += " , symbol: {}".format(var.symbol)
         | 
| 547 569 | 
             
                    out += "\n"
         | 
| 548 570 | 
             
                out += "\n"
         | 
| 549 571 |  | 
| 550 572 | 
             
                out += "## Variables Used\n"
         | 
| 551 573 | 
             
                for i, x in enumerate(metric.variables_used):
         | 
| 552 574 | 
             
                    out += "{}. {}.{}".format(i + 1, x[0], x[1])
         | 
| 575 | 
            +
                    var = ms.state[x[0]].variable_map[x[1]]
         | 
| 576 | 
            +
                    if var.symbol:
         | 
| 577 | 
            +
                        out += " , symbol: {}".format(var.symbol)
         | 
| 553 578 | 
             
                    out += "\n"
         | 
| 554 579 | 
             
                out += "\n"
         | 
| 555 580 |  | 
| @@ -603,7 +628,7 @@ def write_wiring_display_markdown_report(ms, path, wiring, add_metadata=True): | |
| 603 628 | 
             
                out += "\n"
         | 
| 604 629 |  | 
| 605 630 | 
             
                out += "## Unique Components Used\n"
         | 
| 606 | 
            -
                components = [set(x. | 
| 631 | 
            +
                components = [set(x.components_full()) for x in wirings]
         | 
| 607 632 | 
             
                components = set().union(*components)
         | 
| 608 633 | 
             
                for i, x in enumerate(components):
         | 
| 609 634 | 
             
                    out += "{}. [[{}]]".format(i + 1, x.name)
         | 
| @@ -638,7 +663,26 @@ def write_wiring_display_markdown_report(ms, path, wiring, add_metadata=True): | |
| 638 663 | 
             
                    f.write(out)
         | 
| 639 664 |  | 
| 640 665 |  | 
| 641 | 
            -
            def write_all_markdown_reports(ms, path):
         | 
| 666 | 
            +
            def write_all_markdown_reports(ms, path, clear_folders=False):
         | 
| 667 | 
            +
                if clear_folders:
         | 
| 668 | 
            +
                    for x in [
         | 
| 669 | 
            +
                        "Metrics",
         | 
| 670 | 
            +
                        "Mechanisms",
         | 
| 671 | 
            +
                        "Types",
         | 
| 672 | 
            +
                        "Control Actions",
         | 
| 673 | 
            +
                        "Spaces",
         | 
| 674 | 
            +
                        ".obsidian",
         | 
| 675 | 
            +
                        "Boundary Actions",
         | 
| 676 | 
            +
                        "Policies",
         | 
| 677 | 
            +
                        "Wiring",
         | 
| 678 | 
            +
                        "States",
         | 
| 679 | 
            +
                        "Parameters",
         | 
| 680 | 
            +
                        "Entities",
         | 
| 681 | 
            +
                        "Stateful Metrics",
         | 
| 682 | 
            +
                    ]:
         | 
| 683 | 
            +
                        if os.path.exists("{}/{}".format(path, x)):
         | 
| 684 | 
            +
                            for y in os.listdir("{}/{}".format(path, x)):
         | 
| 685 | 
            +
                                os.remove("{}/{}/{}".format(path, x, y))
         | 
| 642 686 |  | 
| 643 687 | 
             
                # Write entities
         | 
| 644 688 | 
             
                entities = list(ms.entities.keys())
         | 
    
        __init__.py
    CHANGED
    
    
| @@ -1,7 +1,7 @@ | |
| 1 | 
            -
            __init__.py,sha256= | 
| 1 | 
            +
            __init__.py,sha256=RJMgTt0U7VnF0CtTYKCtx3idtAHhHHn54wBJ9WEZJYE,904
         | 
| 2 2 | 
             
            schema.py,sha256=6mrRqzEnTTSXjb19xJ63MBp0KjKH0s7i6TfT4MkAY9k,233
         | 
| 3 3 | 
             
            Classes/ActionTransmissionChannel.py,sha256=zWMo5QsgPh5WGIWXl-xOrZNMXYJXmK6Vejw1dQvi0og,246
         | 
| 4 | 
            -
            Classes/Block.py,sha256= | 
| 4 | 
            +
            Classes/Block.py,sha256=hXQO221IP-TqZm_TwFKfURpEEjZm7L1TPZDCYlaOdho,17302
         | 
| 5 5 | 
             
            Classes/BoundaryAction.py,sha256=AOENCqCEfpjotnHhzUj_F2SOP0SGpkN1tNPr8Mtl6Tc,476
         | 
| 6 6 | 
             
            Classes/ControlAction.py,sha256=xaU3_WVeWOoOFX3O86x30_9Eiirfe76KrO3M2kfjcmo,471
         | 
| 7 7 | 
             
            Classes/Entity.py,sha256=fA0-b128_OHHxfCg4pzqyQV083EYev1HlVpy86S5igg,1226
         | 
| @@ -16,7 +16,8 @@ Classes/StateUpdateTransmissionChannel.py,sha256=3hBLvD1lE64PkwqksBXAfFWv7foOZzG | |
| 16 16 | 
             
            Classes/StatefulMetric.py,sha256=UCis1BJ7fsajHHxFF05ZiyDean2D4s4a95uYYW1Mjq4,749
         | 
| 17 17 | 
             
            Classes/Type.py,sha256=ZDHSiaDixHOxasOJlHbuBsMjZ29O2O5K_nmHOmlO-Ck,228
         | 
| 18 18 | 
             
            Classes/__init__.py,sha256=_hXyZMJanmIex_W6yCR2H7Jw8iU2JJIf3U7VcvBSOGU,737
         | 
| 19 | 
            -
            Convenience/__init__.py,sha256 | 
| 19 | 
            +
            Convenience/__init__.py,sha256=-hNZVoaNSgTmZTiyZoMfWyg14xonC3ppz-diQk1VlUY,60
         | 
| 20 | 
            +
            Convenience/documentation.py,sha256=Jf7-JJIk_vZkNBIGV4bs5LM3B0RVaCCtuwJ164thGfY,1607
         | 
| 20 21 | 
             
            Convenience/starter.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
         | 
| 21 22 | 
             
            Load/__init__.py,sha256=_ga5nHi7U5rY5lCF36_XI9Qmybq4P8R4m5I5mmjLBk8,33
         | 
| 22 23 | 
             
            Load/action_transmission_channel.py,sha256=9Wer7g2s5SSOcUYuZ0PqSKUVVnW3EvGQJZNXJTwW__0,2561
         | 
| @@ -32,16 +33,16 @@ Load/parameters.py,sha256=aid_vqYub9643s82NDtMAXLRdV9BPQkri5MadA0L0eQ,1334 | |
| 32 33 | 
             
            Load/policy.py,sha256=fDBuOe1LWw-6C_xcYtvtx9dpjWoD9GNEumW7bK8QaT0,2077
         | 
| 33 34 | 
             
            Load/spaces.py,sha256=7zgGA57Te7T4hfuCCDElffiidWgn1lKm5E14e1yjt8M,1116
         | 
| 34 35 | 
             
            Load/state_update_transmission_channels.py,sha256=FJWp5n4HdtHAfof5BUQ6BnRakljatL2h8dWCapaVSc0,2238
         | 
| 35 | 
            -
            Load/stateful_metrics.py,sha256= | 
| 36 | 
            +
            Load/stateful_metrics.py,sha256=uGSTc6x6lld5xptgSUMHrO0Vg0QDRIL14C6zTg33S8o,1977
         | 
| 36 37 | 
             
            Load/states.py,sha256=cwo29SBAtj1FoQLEb8c0wkSCn038lIgM9RjNiZefUaE,1223
         | 
| 37 | 
            -
            Load/type.py,sha256= | 
| 38 | 
            +
            Load/type.py,sha256=VFwbkI0BQFsof1HzltFL-ZKIRJDqvu4aWNJ3sUSo-UQ,3083
         | 
| 38 39 | 
             
            Load/wiring.py,sha256=1dR94U5N1W_WI5rL6lYBltH25ZvApB2pIpq9r5Opkug,3083
         | 
| 39 40 | 
             
            Reports/__init__.py,sha256=W27I6S9Ro1hWeHmnxIokCA06awB__eYey7PvKD4Hc1s,933
         | 
| 40 41 | 
             
            Reports/boundary_actions.py,sha256=45BPp4QjWdD-3E9ZWwqgj_nI2-YdcI2ZZ19_Qv_K7Qk,1410
         | 
| 41 42 | 
             
            Reports/control_actions.py,sha256=NksekZKIPFSIkubttFstKFthc5AU9B9PWRLSl9j1wWs,1216
         | 
| 42 43 | 
             
            Reports/general.py,sha256=WOOn6Wlb8M4fsdN49FlKLwOka6vJPQ9aCUy88TL2ki0,1610
         | 
| 43 | 
            -
            Reports/html.py,sha256= | 
| 44 | 
            -
            Reports/markdown.py,sha256= | 
| 44 | 
            +
            Reports/html.py,sha256=rBnwvWeFgCfP7O8nsBL6hWE63Y1Qd24QyGD2Z7CnZ-8,8094
         | 
| 45 | 
            +
            Reports/markdown.py,sha256=Z3cD72G5n77AbpT0NO-iytyiL-aGCddHpK_O3zJ8_mQ,21022
         | 
| 45 46 | 
             
            Reports/mechanisms.py,sha256=d2Rxt3JBYvqAOAYUynl0buYVoXEHrO8EGq7GK6hK8NA,1322
         | 
| 46 47 | 
             
            Reports/node_map.py,sha256=FdSMDQG16NX6n9sZcH-T5xwsvgjrV9OqBHc9J_VlNK0,3129
         | 
| 47 48 | 
             
            Reports/parameters.py,sha256=yizNG4lNGrgrlzYYcHMGfXKDFlPw4PMDYshDqZ3YARs,535
         | 
| @@ -50,8 +51,8 @@ Reports/spaces.py,sha256=-76hR5wQBv4lsG000ypBJ-OprjsNjI-rNRMYdtsYnjQ,579 | |
| 50 51 | 
             
            Reports/state.py,sha256=RSHDjzSiUj4ZjReWbkBW7k2njs3Ovp-q0rCC7GBfD-A,2203
         | 
| 51 52 | 
             
            Reports/tables.py,sha256=O0CNuqh3LMECq5uLjBOoxMUk5hUvkUK660FNnwWUxDY,1505
         | 
| 52 53 | 
             
            Reports/wiring.py,sha256=u9SvKWy6T-WJUEgFI6-zgZanoOaTTs_2YwmEceDLsV8,1618
         | 
| 53 | 
            -
            math_spec_mapping-0.2. | 
| 54 | 
            -
            math_spec_mapping-0.2. | 
| 55 | 
            -
            math_spec_mapping-0.2. | 
| 56 | 
            -
            math_spec_mapping-0.2. | 
| 57 | 
            -
            math_spec_mapping-0.2. | 
| 54 | 
            +
            math_spec_mapping-0.2.5.dist-info/LICENSE,sha256=ObyEzSw8kgCaFbEfpu1zP4TrcAKLA0xhqHMZZfyh7N0,1069
         | 
| 55 | 
            +
            math_spec_mapping-0.2.5.dist-info/METADATA,sha256=LuSr9APc07yodCCbrw8ZgyI9P6-V4npJLEUw5Lp6dp4,5898
         | 
| 56 | 
            +
            math_spec_mapping-0.2.5.dist-info/WHEEL,sha256=GJ7t_kWBFywbagK5eo9IoUwLW6oyOeTKmQ-9iHFVNxQ,92
         | 
| 57 | 
            +
            math_spec_mapping-0.2.5.dist-info/top_level.txt,sha256=DKHirRZ28B4EfLjV3iAU31Sdj6q90EDPTSkRGRZf3uo,49
         | 
| 58 | 
            +
            math_spec_mapping-0.2.5.dist-info/RECORD,,
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         |