@eagleoutice/flowr 1.5.2 → 2.0.0
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.
- package/abstract-interpretation/handler/binop/binop.d.ts +3 -4
- package/abstract-interpretation/handler/binop/binop.js +4 -2
- package/abstract-interpretation/handler/binop/operators.d.ts +2 -2
- package/abstract-interpretation/handler/binop/operators.js +14 -28
- package/abstract-interpretation/processor.d.ts +3 -2
- package/abstract-interpretation/processor.js +2 -2
- package/benchmark/slicer.d.ts +101 -0
- package/benchmark/slicer.js +214 -0
- package/benchmark/stats/print.d.ts +7 -0
- package/benchmark/stats/print.js +151 -0
- package/benchmark/stats/stats.d.ts +42 -0
- package/benchmark/stats/stats.js +6 -0
- package/benchmark/stopwatch.d.ts +35 -0
- package/benchmark/stopwatch.js +79 -0
- package/benchmark/summarizer/data.d.ts +54 -0
- package/benchmark/summarizer/first-phase/input.d.ts +3 -0
- package/benchmark/summarizer/first-phase/input.js +76 -0
- package/benchmark/summarizer/first-phase/process.d.ts +11 -0
- package/benchmark/summarizer/first-phase/process.js +205 -0
- package/benchmark/summarizer/second-phase/graph.d.ts +2 -0
- package/benchmark/summarizer/second-phase/graph.js +54 -0
- package/benchmark/summarizer/second-phase/process.d.ts +6 -0
- package/benchmark/summarizer/second-phase/process.js +127 -0
- package/benchmark/summarizer/summarizer.d.ts +31 -0
- package/benchmark/summarizer/summarizer.js +58 -0
- package/cli/benchmark-app.d.ts +10 -0
- package/cli/benchmark-app.js +67 -0
- package/cli/benchmark-helper-app.d.ts +9 -0
- package/cli/benchmark-helper-app.js +69 -0
- package/cli/common/features.d.ts +3 -0
- package/cli/common/features.js +30 -0
- package/cli/common/options.d.ts +20 -0
- package/cli/common/options.js +85 -0
- package/cli/common/script.d.ts +21 -0
- package/cli/common/script.js +61 -0
- package/cli/common/scripts-info.d.ts +25 -0
- package/cli/common/scripts-info.js +83 -0
- package/cli/export-quads-app.d.ts +7 -0
- package/cli/export-quads-app.js +43 -0
- package/cli/flowr.d.ts +29 -0
- package/cli/flowr.js +141 -0
- package/cli/repl/commands/cfg.d.ts +3 -0
- package/cli/repl/commands/cfg.js +37 -0
- package/cli/repl/commands/commands.d.ts +13 -0
- package/cli/repl/commands/commands.js +142 -0
- package/cli/repl/commands/dataflow.d.ts +3 -0
- package/cli/repl/commands/dataflow.js +34 -0
- package/cli/repl/commands/execute.d.ts +4 -0
- package/cli/repl/commands/execute.js +27 -0
- package/cli/repl/commands/main.d.ts +39 -0
- package/cli/repl/commands/main.js +14 -0
- package/cli/repl/commands/normalize.d.ts +3 -0
- package/cli/repl/commands/normalize.js +34 -0
- package/cli/repl/commands/parse.d.ts +2 -0
- package/cli/repl/commands/parse.js +110 -0
- package/cli/repl/commands/quit.d.ts +2 -0
- package/cli/repl/commands/quit.js +15 -0
- package/cli/repl/commands/version.d.ts +16 -0
- package/cli/repl/commands/version.js +28 -0
- package/cli/repl/core.d.ts +36 -0
- package/cli/repl/core.js +174 -0
- package/cli/repl/execute.d.ts +28 -0
- package/cli/repl/execute.js +79 -0
- package/cli/repl/print-version.d.ts +2 -0
- package/cli/repl/print-version.js +10 -0
- package/cli/repl/prompt.d.ts +2 -0
- package/cli/repl/prompt.js +9 -0
- package/cli/repl/server/connection.d.ts +21 -0
- package/cli/repl/server/connection.js +218 -0
- package/cli/repl/server/messages/analysis.d.ts +72 -0
- package/cli/repl/server/messages/analysis.js +21 -0
- package/cli/repl/server/messages/error.d.ts +11 -0
- package/{core/input.js → cli/repl/server/messages/error.js} +1 -1
- package/cli/repl/server/messages/hello.d.ts +20 -0
- package/{core/output.js → cli/repl/server/messages/hello.js} +1 -1
- package/cli/repl/server/messages/messages.d.ts +35 -0
- package/cli/repl/server/messages/messages.js +40 -0
- package/cli/repl/server/messages/repl.d.ts +33 -0
- package/cli/repl/server/messages/repl.js +37 -0
- package/cli/repl/server/messages/slice.d.ts +26 -0
- package/cli/repl/server/messages/slice.js +37 -0
- package/cli/repl/server/net.d.ts +49 -0
- package/cli/repl/server/net.js +63 -0
- package/cli/repl/server/send.d.ts +4 -0
- package/cli/repl/server/send.js +18 -0
- package/cli/repl/server/server.d.ts +20 -0
- package/cli/repl/server/server.js +66 -0
- package/cli/repl/server/validate.d.ts +15 -0
- package/cli/repl/server/validate.js +34 -0
- package/cli/slicer-app.d.ts +11 -0
- package/cli/slicer-app.js +83 -0
- package/cli/statistics-app.d.ts +11 -0
- package/cli/statistics-app.js +99 -0
- package/cli/statistics-helper-app.d.ts +11 -0
- package/cli/statistics-helper-app.js +87 -0
- package/cli/summarizer-app.d.ts +18 -0
- package/cli/summarizer-app.js +66 -0
- package/core/pipeline-executor.d.ts +154 -0
- package/core/pipeline-executor.js +221 -0
- package/core/print/dataflow-printer.d.ts +3 -4
- package/core/print/dataflow-printer.js +5 -5
- package/core/print/normalize-printer.d.ts +1 -1
- package/core/print/normalize-printer.js +3 -3
- package/core/print/parse-printer.js +3 -3
- package/core/print/print.d.ts +13 -4
- package/core/print/print.js +13 -2
- package/core/print/slice-diff-ansi.d.ts +3 -2
- package/core/print/slice-diff-ansi.js +4 -4
- package/core/steps/all/core/00-parse.d.ts +28 -0
- package/core/steps/all/core/00-parse.js +24 -0
- package/core/steps/all/core/10-normalize.d.ts +29 -0
- package/core/steps/all/core/10-normalize.js +26 -0
- package/core/steps/all/core/20-dataflow.d.ts +27 -0
- package/core/steps/all/core/20-dataflow.js +29 -0
- package/core/steps/all/static-slicing/00-slice.d.ts +28 -0
- package/core/steps/all/static-slicing/00-slice.js +21 -0
- package/core/steps/all/static-slicing/10-reconstruct.d.ts +25 -0
- package/core/steps/all/static-slicing/10-reconstruct.js +21 -0
- package/core/steps/pipeline/create-pipeline.d.ts +6 -0
- package/core/steps/pipeline/create-pipeline.js +130 -0
- package/core/steps/pipeline/default-pipelines.d.ts +251 -0
- package/core/steps/pipeline/default-pipelines.js +18 -0
- package/core/steps/pipeline/invalid-pipeline-error.d.ts +6 -0
- package/core/steps/pipeline/invalid-pipeline-error.js +14 -0
- package/core/steps/pipeline/pipeline.d.ts +60 -0
- package/core/steps/pipeline/pipeline.js +28 -0
- package/core/steps/pipeline-step.d.ts +85 -0
- package/core/steps/pipeline-step.js +8 -0
- package/dataflow/environments/append.d.ts +4 -4
- package/dataflow/environments/append.js +4 -4
- package/dataflow/environments/built-in.d.ts +25 -0
- package/dataflow/environments/built-in.js +123 -0
- package/dataflow/environments/clone.d.ts +2 -0
- package/dataflow/environments/clone.js +23 -0
- package/dataflow/environments/{register.d.ts → define.d.ts} +3 -3
- package/dataflow/environments/define.js +51 -0
- package/dataflow/environments/diff.d.ts +6 -0
- package/dataflow/environments/diff.js +85 -0
- package/dataflow/environments/environment.d.ts +10 -43
- package/dataflow/environments/environment.js +32 -138
- package/dataflow/environments/identifier.d.ts +31 -0
- package/dataflow/environments/identifier.js +3 -0
- package/dataflow/environments/overwrite.d.ts +4 -4
- package/dataflow/environments/overwrite.js +9 -22
- package/dataflow/environments/resolve-by-name.d.ts +7 -6
- package/dataflow/environments/resolve-by-name.js +35 -19
- package/dataflow/environments/scoping.js +1 -4
- package/dataflow/extractor.d.ts +6 -6
- package/dataflow/extractor.js +47 -57
- package/dataflow/graph/diff.d.ts +24 -7
- package/dataflow/graph/diff.js +114 -74
- package/dataflow/graph/edge.d.ts +66 -20
- package/dataflow/graph/edge.js +73 -27
- package/dataflow/graph/graph.d.ts +53 -29
- package/dataflow/graph/graph.js +84 -89
- package/dataflow/graph/quads.js +2 -2
- package/dataflow/graph/vertex.d.ts +37 -34
- package/dataflow/info.d.ts +49 -0
- package/dataflow/info.js +29 -0
- package/dataflow/internal/linker.d.ts +11 -10
- package/dataflow/internal/linker.js +64 -90
- package/dataflow/internal/process/functions/call/argument/make-argument.d.ts +6 -0
- package/dataflow/internal/process/functions/call/argument/make-argument.js +31 -0
- package/dataflow/internal/process/functions/call/argument/unpack-argument.d.ts +3 -0
- package/dataflow/internal/process/functions/call/argument/unpack-argument.js +18 -0
- package/dataflow/internal/process/functions/call/built-in/built-in-access.d.ts +9 -0
- package/dataflow/internal/process/functions/call/built-in/built-in-access.js +82 -0
- package/dataflow/internal/process/functions/call/built-in/built-in-assignment.d.ts +29 -0
- package/dataflow/internal/process/functions/call/built-in/built-in-assignment.js +167 -0
- package/dataflow/internal/process/functions/call/built-in/built-in-expression-list.d.ts +11 -0
- package/dataflow/internal/process/functions/call/built-in/built-in-expression-list.js +165 -0
- package/dataflow/internal/process/functions/call/built-in/built-in-for-loop.d.ts +7 -0
- package/dataflow/internal/process/functions/call/built-in/built-in-for-loop.js +97 -0
- package/dataflow/internal/process/functions/call/built-in/built-in-function-definition.d.ts +7 -0
- package/dataflow/internal/process/functions/call/built-in/built-in-function-definition.js +165 -0
- package/dataflow/internal/process/functions/call/built-in/built-in-get.d.ts +7 -0
- package/dataflow/internal/process/functions/call/built-in/built-in-get.js +36 -0
- package/dataflow/internal/process/functions/call/built-in/built-in-if-then-else.d.ts +7 -0
- package/dataflow/internal/process/functions/call/built-in/built-in-if-then-else.js +100 -0
- package/dataflow/internal/process/functions/call/built-in/built-in-library.d.ts +7 -0
- package/dataflow/internal/process/functions/call/built-in/built-in-library.js +32 -0
- package/dataflow/internal/process/functions/call/built-in/built-in-logical-bin-op.d.ts +9 -0
- package/dataflow/internal/process/functions/call/built-in/built-in-logical-bin-op.js +35 -0
- package/dataflow/internal/process/functions/call/built-in/built-in-pipe.d.ts +7 -0
- package/dataflow/internal/process/functions/call/built-in/built-in-pipe.js +35 -0
- package/dataflow/internal/process/functions/call/built-in/built-in-quote.d.ts +9 -0
- package/dataflow/internal/process/functions/call/built-in/built-in-quote.js +29 -0
- package/dataflow/internal/process/functions/call/built-in/built-in-repeat-loop.d.ts +7 -0
- package/dataflow/internal/process/functions/call/built-in/built-in-repeat-loop.js +32 -0
- package/dataflow/internal/process/functions/call/built-in/built-in-replacement.d.ts +12 -0
- package/dataflow/internal/process/functions/call/built-in/built-in-replacement.js +45 -0
- package/dataflow/internal/process/functions/call/built-in/built-in-source.d.ts +11 -0
- package/dataflow/internal/process/functions/call/built-in/built-in-source.js +72 -0
- package/dataflow/internal/process/functions/call/built-in/built-in-while-loop.d.ts +7 -0
- package/dataflow/internal/process/functions/call/built-in/built-in-while-loop.js +61 -0
- package/dataflow/internal/process/functions/call/common.d.ts +35 -0
- package/dataflow/internal/process/functions/call/common.js +70 -0
- package/dataflow/internal/process/functions/call/default-call-handling.d.ts +5 -0
- package/dataflow/internal/process/functions/call/default-call-handling.js +15 -0
- package/dataflow/internal/process/functions/call/known-call-handling.d.ts +26 -0
- package/dataflow/internal/process/functions/call/known-call-handling.js +62 -0
- package/dataflow/internal/process/functions/call/named-call-handling.d.ts +7 -0
- package/dataflow/internal/process/functions/call/named-call-handling.js +53 -0
- package/dataflow/internal/process/functions/call/unnamed-call-handling.d.ts +6 -0
- package/dataflow/internal/process/functions/call/unnamed-call-handling.js +58 -0
- package/dataflow/internal/process/functions/process-argument.d.ts +9 -0
- package/dataflow/internal/process/functions/{argument.js → process-argument.js} +25 -20
- package/dataflow/internal/process/functions/{parameter.d.ts → process-parameter.d.ts} +3 -2
- package/dataflow/internal/process/functions/{parameter.js → process-parameter.js} +10 -13
- package/dataflow/internal/process/process-named-call.d.ts +6 -0
- package/dataflow/internal/process/process-named-call.js +17 -0
- package/dataflow/internal/process/process-symbol.d.ts +5 -0
- package/dataflow/internal/process/process-symbol.js +26 -0
- package/dataflow/internal/process/process-uninteresting-leaf.d.ts +4 -0
- package/dataflow/internal/process/process-uninteresting-leaf.js +9 -0
- package/dataflow/internal/process/process-value.d.ts +4 -0
- package/dataflow/internal/process/process-value.js +22 -0
- package/dataflow/logger.d.ts +1 -0
- package/dataflow/logger.js +6 -0
- package/dataflow/processor.d.ts +18 -13
- package/dataflow/processor.js +1 -1
- package/package.json +48 -85
- package/r-bridge/data/data.d.ts +603 -0
- package/r-bridge/data/data.js +753 -0
- package/r-bridge/data/get.d.ts +19 -0
- package/r-bridge/data/get.js +51 -0
- package/r-bridge/data/print.d.ts +1 -0
- package/r-bridge/data/print.js +58 -0
- package/r-bridge/data/types.d.ts +33 -0
- package/r-bridge/data/types.js +3 -0
- package/r-bridge/init.d.ts +3 -0
- package/r-bridge/init.js +22 -0
- package/r-bridge/lang-4.x/ast/model/collect.d.ts +2 -1
- package/r-bridge/lang-4.x/ast/model/collect.js +2 -2
- package/r-bridge/lang-4.x/ast/model/model.d.ts +26 -5
- package/r-bridge/lang-4.x/ast/model/nodes/r-access.d.ts +4 -3
- package/r-bridge/lang-4.x/ast/model/nodes/r-argument.d.ts +4 -0
- package/r-bridge/lang-4.x/ast/model/nodes/r-binary-op.d.ts +0 -17
- package/r-bridge/lang-4.x/ast/model/nodes/r-expression-list.d.ts +3 -1
- package/r-bridge/lang-4.x/ast/model/nodes/r-function-call.d.ts +6 -4
- package/r-bridge/lang-4.x/ast/model/nodes/r-function-call.js +2 -0
- package/r-bridge/lang-4.x/ast/model/nodes/r-function-definition.d.ts +2 -3
- package/r-bridge/lang-4.x/ast/model/nodes/r-number.d.ts +1 -1
- package/r-bridge/lang-4.x/ast/model/nodes/r-string.d.ts +1 -1
- package/r-bridge/lang-4.x/ast/model/nodes/r-symbol.js +2 -2
- package/r-bridge/lang-4.x/ast/model/nodes/r-unary-op.d.ts +0 -11
- package/r-bridge/lang-4.x/ast/model/operators.d.ts +6 -18
- package/r-bridge/lang-4.x/ast/model/operators.js +36 -48
- package/r-bridge/lang-4.x/ast/model/processing/decorate.d.ts +19 -15
- package/r-bridge/lang-4.x/ast/model/processing/decorate.js +59 -54
- package/r-bridge/lang-4.x/ast/model/processing/node-id.d.ts +8 -0
- package/r-bridge/lang-4.x/ast/model/processing/node-id.js +18 -0
- package/r-bridge/lang-4.x/ast/model/processing/role.d.ts +2 -2
- package/r-bridge/lang-4.x/ast/model/processing/stateful-fold.d.ts +28 -17
- package/r-bridge/lang-4.x/ast/model/processing/stateful-fold.js +7 -34
- package/r-bridge/lang-4.x/ast/model/processing/visitor.js +5 -2
- package/r-bridge/lang-4.x/ast/model/type.js +13 -6
- package/r-bridge/lang-4.x/ast/parser/json/format.d.ts +4 -1
- package/r-bridge/lang-4.x/ast/parser/json/format.js +9 -2
- package/r-bridge/lang-4.x/ast/parser/json/parser.d.ts +5 -5
- package/r-bridge/lang-4.x/ast/parser/json/parser.js +22 -27
- package/r-bridge/lang-4.x/ast/parser/xml/input-format.d.ts +10 -7
- package/r-bridge/lang-4.x/ast/parser/xml/input-format.js +19 -11
- package/r-bridge/lang-4.x/ast/parser/xml/internal/control/{if-then-else.d.ts → normalize-if-then-else.d.ts} +3 -3
- package/r-bridge/lang-4.x/ast/parser/xml/internal/control/{if-then-else.js → normalize-if-then-else.js} +10 -13
- package/r-bridge/lang-4.x/ast/parser/xml/internal/control/{if-then.d.ts → normalize-if-then.d.ts} +3 -3
- package/r-bridge/lang-4.x/ast/parser/xml/internal/control/{if-then.js → normalize-if-then.js} +9 -12
- package/r-bridge/lang-4.x/ast/parser/xml/internal/expression/normalize-expression.d.ts +10 -0
- package/r-bridge/lang-4.x/ast/parser/xml/internal/expression/normalize-expression.js +64 -0
- package/r-bridge/lang-4.x/ast/parser/xml/internal/functions/{argument.d.ts → normalize-argument.d.ts} +4 -4
- package/r-bridge/lang-4.x/ast/parser/xml/internal/functions/{argument.js → normalize-argument.js} +13 -17
- package/r-bridge/lang-4.x/ast/parser/xml/internal/functions/{call.d.ts → normalize-call.d.ts} +6 -4
- package/r-bridge/lang-4.x/ast/parser/xml/internal/functions/{call.js → normalize-call.js} +24 -29
- package/r-bridge/lang-4.x/ast/parser/xml/internal/functions/normalize-definition.d.ts +12 -0
- package/r-bridge/lang-4.x/ast/parser/xml/internal/functions/{definition.js → normalize-definition.js} +14 -19
- package/r-bridge/lang-4.x/ast/parser/xml/internal/functions/{parameter.d.ts → normalize-parameter.d.ts} +4 -4
- package/r-bridge/lang-4.x/ast/parser/xml/internal/functions/{parameter.js → normalize-parameter.js} +12 -16
- package/r-bridge/lang-4.x/ast/parser/xml/internal/loops/normalize-break.d.ts +4 -0
- package/r-bridge/lang-4.x/ast/parser/xml/internal/loops/{break.js → normalize-break.js} +6 -8
- package/r-bridge/lang-4.x/ast/parser/xml/internal/loops/normalize-for.d.ts +4 -0
- package/r-bridge/lang-4.x/ast/parser/xml/internal/loops/{for.js → normalize-for.js} +18 -20
- package/r-bridge/lang-4.x/ast/parser/xml/internal/loops/normalize-next.d.ts +4 -0
- package/r-bridge/lang-4.x/ast/parser/xml/internal/loops/{next.js → normalize-next.js} +6 -8
- package/r-bridge/lang-4.x/ast/parser/xml/internal/loops/normalize-repeat.d.ts +13 -0
- package/r-bridge/lang-4.x/ast/parser/xml/internal/loops/{repeat.js → normalize-repeat.js} +13 -16
- package/r-bridge/lang-4.x/ast/parser/xml/internal/loops/normalize-while.d.ts +4 -0
- package/r-bridge/lang-4.x/ast/parser/xml/internal/loops/{while.js → normalize-while.js} +10 -12
- package/r-bridge/lang-4.x/ast/parser/xml/internal/{access.d.ts → normalize-access.d.ts} +4 -4
- package/r-bridge/lang-4.x/ast/parser/xml/internal/{access.js → normalize-access.js} +44 -45
- package/r-bridge/lang-4.x/ast/parser/xml/internal/operators/{binary.d.ts → normalize-binary.d.ts} +3 -3
- package/r-bridge/lang-4.x/ast/parser/xml/internal/operators/{binary.js → normalize-binary.js} +23 -73
- package/r-bridge/lang-4.x/ast/parser/xml/internal/operators/normalize-unary.d.ts +13 -0
- package/r-bridge/lang-4.x/ast/parser/xml/internal/operators/normalize-unary.js +47 -0
- package/r-bridge/lang-4.x/ast/parser/xml/internal/other/normalize-comment.d.ts +11 -0
- package/r-bridge/lang-4.x/ast/parser/xml/internal/other/{comment.js → normalize-comment.js} +5 -10
- package/r-bridge/lang-4.x/ast/parser/xml/internal/other/normalize-line-directive.d.ts +13 -0
- package/r-bridge/lang-4.x/ast/parser/xml/internal/other/{line-directive.js → normalize-line-directive.js} +7 -12
- package/r-bridge/lang-4.x/ast/parser/xml/internal/structure/normalize-delimiter.d.ts +3 -0
- package/r-bridge/lang-4.x/ast/parser/xml/internal/structure/normalize-delimiter.js +15 -0
- package/r-bridge/lang-4.x/ast/parser/xml/internal/structure/normalize-expressions.d.ts +10 -0
- package/r-bridge/lang-4.x/ast/parser/xml/internal/structure/normalize-expressions.js +182 -0
- package/r-bridge/lang-4.x/ast/parser/xml/internal/structure/normalize-root.d.ts +4 -0
- package/r-bridge/lang-4.x/ast/parser/xml/internal/structure/normalize-root.js +34 -0
- package/r-bridge/lang-4.x/ast/parser/xml/internal/structure/normalize-single-node.d.ts +13 -0
- package/r-bridge/lang-4.x/ast/parser/xml/internal/structure/normalize-single-node.js +59 -0
- package/r-bridge/lang-4.x/ast/parser/xml/internal/values/normalize-number.d.ts +16 -0
- package/r-bridge/lang-4.x/ast/parser/xml/internal/values/{number.js → normalize-number.js} +12 -18
- package/r-bridge/lang-4.x/ast/parser/xml/internal/values/normalize-string.d.ts +11 -0
- package/r-bridge/lang-4.x/ast/parser/xml/internal/values/{string.js → normalize-string.js} +7 -12
- package/r-bridge/lang-4.x/ast/parser/xml/internal/values/{symbol.d.ts → normalize-symbol.d.ts} +4 -4
- package/r-bridge/lang-4.x/ast/parser/xml/internal/values/{symbol.js → normalize-symbol.js} +12 -15
- package/r-bridge/lang-4.x/ast/parser/xml/{internal/meta.d.ts → normalize-meta.d.ts} +5 -3
- package/r-bridge/lang-4.x/ast/parser/xml/{internal/meta.js → normalize-meta.js} +8 -8
- package/r-bridge/lang-4.x/ast/parser/xml/{data.d.ts → normalizer-data.d.ts} +1 -5
- package/r-bridge/lang-4.x/ast/parser/xml/normalizer-data.js +3 -0
- package/r-bridge/lang-4.x/{values.d.ts → convert-values.d.ts} +2 -2
- package/r-bridge/lang-4.x/{values.js → convert-values.js} +5 -5
- package/r-bridge/retriever.d.ts +5 -5
- package/r-bridge/retriever.js +11 -24
- package/r-bridge/shell-executor.d.ts +0 -1
- package/r-bridge/shell-executor.js +7 -12
- package/r-bridge/shell.d.ts +14 -12
- package/r-bridge/shell.js +52 -47
- package/reconstruct/reconstruct.d.ts +4 -2
- package/reconstruct/reconstruct.js +193 -185
- package/slicing/criterion/collect-all.d.ts +4 -3
- package/slicing/criterion/collect-all.js +5 -1
- package/slicing/criterion/filters/all-variables.js +14 -22
- package/slicing/criterion/parse.d.ts +4 -2
- package/slicing/criterion/parse.js +13 -11
- package/slicing/static/fingerprint.d.ts +5 -0
- package/slicing/static/fingerprint.js +17 -0
- package/slicing/static/slice-call.d.ts +10 -0
- package/slicing/static/slice-call.js +86 -0
- package/slicing/static/slicer-types.d.ts +33 -0
- package/slicing/static/slicer-types.js +3 -0
- package/slicing/static/static-slicer.d.ts +6 -24
- package/slicing/static/static-slicer.js +54 -155
- package/slicing/static/visiting-queue.d.ts +23 -0
- package/slicing/static/visiting-queue.js +53 -0
- package/statistics/features/common-syntax-probability.d.ts +29 -0
- package/statistics/features/common-syntax-probability.js +159 -0
- package/statistics/features/feature.d.ts +182 -0
- package/statistics/features/feature.js +39 -0
- package/statistics/features/post-processing.d.ts +12 -0
- package/statistics/features/post-processing.js +21 -0
- package/statistics/features/supported/assignments/assignments.d.ts +12 -0
- package/statistics/features/supported/assignments/assignments.js +55 -0
- package/statistics/features/supported/assignments/post-process.d.ts +3 -0
- package/statistics/features/supported/assignments/post-process.js +124 -0
- package/statistics/features/supported/comments/comments.d.ts +18 -0
- package/statistics/features/supported/comments/comments.js +133 -0
- package/statistics/features/supported/comments/post-process.d.ts +3 -0
- package/statistics/features/supported/comments/post-process.js +49 -0
- package/statistics/features/supported/control-flow/control-flow.d.ts +17 -0
- package/statistics/features/supported/control-flow/control-flow.js +68 -0
- package/statistics/features/supported/control-flow/post-process.d.ts +3 -0
- package/statistics/features/supported/control-flow/post-process.js +64 -0
- package/statistics/features/supported/data-access/data-access.d.ts +15 -0
- package/statistics/features/supported/data-access/data-access.js +120 -0
- package/statistics/features/supported/data-access/post-process.d.ts +3 -0
- package/statistics/features/supported/data-access/post-process.js +106 -0
- package/statistics/features/supported/defined-functions/defined-functions.d.ts +34 -0
- package/statistics/features/supported/defined-functions/defined-functions.js +142 -0
- package/statistics/features/supported/defined-functions/post-process.d.ts +6 -0
- package/statistics/features/supported/defined-functions/post-process.js +169 -0
- package/statistics/features/supported/expression-list/expression-list.d.ts +9 -0
- package/statistics/features/supported/expression-list/expression-list.js +36 -0
- package/statistics/features/supported/expression-list/post-process.d.ts +3 -0
- package/statistics/features/supported/expression-list/post-process.js +43 -0
- package/statistics/features/supported/loops/loops.d.ts +20 -0
- package/statistics/features/supported/loops/loops.js +79 -0
- package/statistics/features/supported/loops/post-process.d.ts +3 -0
- package/statistics/features/supported/loops/post-process.js +71 -0
- package/statistics/features/supported/used-functions/post-process.d.ts +6 -0
- package/statistics/features/supported/used-functions/post-process.js +178 -0
- package/statistics/features/supported/used-functions/used-functions.d.ts +24 -0
- package/statistics/features/supported/used-functions/used-functions.js +97 -0
- package/statistics/features/supported/used-packages/post-process.d.ts +3 -0
- package/statistics/features/supported/used-packages/post-process.js +120 -0
- package/statistics/features/supported/used-packages/used-packages.d.ts +16 -0
- package/statistics/features/supported/used-packages/used-packages.js +130 -0
- package/statistics/features/supported/values/post-process.d.ts +3 -0
- package/statistics/features/supported/values/post-process.js +71 -0
- package/statistics/features/supported/values/values.d.ts +14 -0
- package/statistics/features/supported/values/values.js +101 -0
- package/statistics/features/supported/variables/post-process.d.ts +9 -0
- package/statistics/features/supported/variables/post-process.js +121 -0
- package/statistics/features/supported/variables/variables.d.ts +15 -0
- package/statistics/features/supported/variables/variables.js +60 -0
- package/statistics/meta-statistics.d.ts +33 -0
- package/statistics/meta-statistics.js +17 -0
- package/statistics/output/file-provider.d.ts +37 -0
- package/statistics/output/file-provider.js +97 -0
- package/statistics/output/print-stats.d.ts +17 -0
- package/statistics/output/print-stats.js +69 -0
- package/statistics/output/statistics-file.d.ts +37 -0
- package/statistics/output/statistics-file.js +69 -0
- package/statistics/statistics.d.ts +28 -0
- package/statistics/statistics.js +108 -0
- package/statistics/summarizer/auto-detect.d.ts +2 -0
- package/statistics/summarizer/auto-detect.js +32 -0
- package/statistics/summarizer/first-phase/process.d.ts +6 -0
- package/statistics/summarizer/first-phase/process.js +81 -0
- package/statistics/summarizer/post-process/clusterer.d.ts +26 -0
- package/statistics/summarizer/post-process/clusterer.js +43 -0
- package/statistics/summarizer/post-process/file-based-count.d.ts +17 -0
- package/statistics/summarizer/post-process/file-based-count.js +49 -0
- package/statistics/summarizer/post-process/histogram.d.ts +59 -0
- package/statistics/summarizer/post-process/histogram.js +128 -0
- package/statistics/summarizer/post-process/post-process-output.d.ts +16 -0
- package/statistics/summarizer/post-process/post-process-output.js +105 -0
- package/statistics/summarizer/second-phase/process.d.ts +11 -0
- package/statistics/summarizer/second-phase/process.js +116 -0
- package/statistics/summarizer/summarizer.d.ts +35 -0
- package/statistics/summarizer/summarizer.js +135 -0
- package/util/ansi.d.ts +2 -2
- package/util/ansi.js +2 -2
- package/util/arrays.d.ts +11 -1
- package/util/arrays.js +34 -1
- package/util/assert.d.ts +1 -0
- package/util/assert.js +5 -1
- package/util/cfg/cfg.d.ts +3 -2
- package/util/cfg/cfg.js +17 -28
- package/util/cfg/visitor.d.ts +1 -1
- package/util/defaultmap.d.ts +1 -1
- package/util/defaultmap.js +1 -1
- package/util/diff.d.ts +4 -4
- package/util/files.d.ts +2 -2
- package/util/files.js +1 -1
- package/util/log.d.ts +1 -0
- package/util/log.js +7 -1
- package/util/logic.d.ts +1 -0
- package/util/logic.js +3 -0
- package/util/mermaid/ast.d.ts +1 -1
- package/util/mermaid/ast.js +2 -2
- package/util/mermaid/cfg.d.ts +1 -1
- package/util/mermaid/dfg.d.ts +34 -8
- package/util/mermaid/dfg.js +99 -70
- package/util/mermaid/mermaid.d.ts +1 -1
- package/util/mermaid/mermaid.js +6 -7
- package/util/objects.js +4 -0
- package/util/quads.d.ts +3 -3
- package/util/quads.js +0 -1
- package/util/range.d.ts +27 -14
- package/util/range.js +31 -27
- package/util/version.js +1 -1
- package/core/index.d.ts +0 -4
- package/core/index.js +0 -23
- package/core/input.d.ts +0 -42
- package/core/output.d.ts +0 -15
- package/core/slicer.d.ts +0 -124
- package/core/slicer.js +0 -227
- package/core/steps.d.ts +0 -508
- package/core/steps.js +0 -100
- package/dataflow/environments/index.d.ts +0 -7
- package/dataflow/environments/index.js +0 -23
- package/dataflow/environments/register.js +0 -40
- package/dataflow/environments/scopes.d.ts +0 -6
- package/dataflow/environments/scopes.js +0 -6
- package/dataflow/graph/index.d.ts +0 -4
- package/dataflow/graph/index.js +0 -21
- package/dataflow/index.d.ts +0 -5
- package/dataflow/index.js +0 -24
- package/dataflow/internal/info.d.ts +0 -21
- package/dataflow/internal/info.js +0 -16
- package/dataflow/internal/process/access.d.ts +0 -4
- package/dataflow/internal/process/access.js +0 -53
- package/dataflow/internal/process/expression-list.d.ts +0 -8
- package/dataflow/internal/process/expression-list.js +0 -144
- package/dataflow/internal/process/functions/argument.d.ts +0 -8
- package/dataflow/internal/process/functions/exit-points.d.ts +0 -2
- package/dataflow/internal/process/functions/exit-points.js +0 -121
- package/dataflow/internal/process/functions/function-call.d.ts +0 -5
- package/dataflow/internal/process/functions/function-call.js +0 -105
- package/dataflow/internal/process/functions/function-definition.d.ts +0 -4
- package/dataflow/internal/process/functions/function-definition.js +0 -176
- package/dataflow/internal/process/functions/source.d.ts +0 -8
- package/dataflow/internal/process/functions/source.js +0 -81
- package/dataflow/internal/process/if-then-else.d.ts +0 -4
- package/dataflow/internal/process/if-then-else.js +0 -56
- package/dataflow/internal/process/loops/for-loop.d.ts +0 -4
- package/dataflow/internal/process/loops/for-loop.js +0 -54
- package/dataflow/internal/process/loops/repeat-loop.d.ts +0 -4
- package/dataflow/internal/process/loops/repeat-loop.js +0 -21
- package/dataflow/internal/process/loops/while-loop.d.ts +0 -4
- package/dataflow/internal/process/loops/while-loop.js +0 -31
- package/dataflow/internal/process/operators/assignment.d.ts +0 -4
- package/dataflow/internal/process/operators/assignment.js +0 -129
- package/dataflow/internal/process/operators/non-assignment-binary-op.d.ts +0 -4
- package/dataflow/internal/process/operators/non-assignment-binary-op.js +0 -25
- package/dataflow/internal/process/operators/pipe.d.ts +0 -4
- package/dataflow/internal/process/operators/pipe.js +0 -46
- package/dataflow/internal/process/operators/unary-op.d.ts +0 -4
- package/dataflow/internal/process/operators/unary-op.js +0 -10
- package/dataflow/internal/process/symbol.d.ts +0 -4
- package/dataflow/internal/process/symbol.js +0 -21
- package/dataflow/internal/process/uninteresting-leaf.d.ts +0 -3
- package/dataflow/internal/process/uninteresting-leaf.js +0 -9
- package/index.d.ts +0 -4
- package/index.js +0 -21
- package/r-bridge/index.d.ts +0 -11
- package/r-bridge/index.js +0 -28
- package/r-bridge/lang-4.x/ast/index.d.ts +0 -3
- package/r-bridge/lang-4.x/ast/index.js +0 -22
- package/r-bridge/lang-4.x/ast/model/index.d.ts +0 -6
- package/r-bridge/lang-4.x/ast/model/index.js +0 -23
- package/r-bridge/lang-4.x/ast/model/nodes/index.d.ts +0 -21
- package/r-bridge/lang-4.x/ast/model/nodes/index.js +0 -38
- package/r-bridge/lang-4.x/ast/model/nodes/info/index.d.ts +0 -13
- package/r-bridge/lang-4.x/ast/model/nodes/info/index.js +0 -27
- package/r-bridge/lang-4.x/ast/model/processing/index.d.ts +0 -5
- package/r-bridge/lang-4.x/ast/model/processing/index.js +0 -22
- package/r-bridge/lang-4.x/ast/parser/xml/hooks.d.ts +0 -292
- package/r-bridge/lang-4.x/ast/parser/xml/hooks.js +0 -136
- package/r-bridge/lang-4.x/ast/parser/xml/index.d.ts +0 -3
- package/r-bridge/lang-4.x/ast/parser/xml/index.js +0 -20
- package/r-bridge/lang-4.x/ast/parser/xml/internal/control/index.d.ts +0 -2
- package/r-bridge/lang-4.x/ast/parser/xml/internal/control/index.js +0 -19
- package/r-bridge/lang-4.x/ast/parser/xml/internal/expression/expression.d.ts +0 -10
- package/r-bridge/lang-4.x/ast/parser/xml/internal/expression/expression.js +0 -65
- package/r-bridge/lang-4.x/ast/parser/xml/internal/expression/index.d.ts +0 -1
- package/r-bridge/lang-4.x/ast/parser/xml/internal/expression/index.js +0 -18
- package/r-bridge/lang-4.x/ast/parser/xml/internal/functions/definition.d.ts +0 -12
- package/r-bridge/lang-4.x/ast/parser/xml/internal/functions/index.d.ts +0 -2
- package/r-bridge/lang-4.x/ast/parser/xml/internal/functions/index.js +0 -20
- package/r-bridge/lang-4.x/ast/parser/xml/internal/index.d.ts +0 -9
- package/r-bridge/lang-4.x/ast/parser/xml/internal/index.js +0 -26
- package/r-bridge/lang-4.x/ast/parser/xml/internal/loops/break.d.ts +0 -4
- package/r-bridge/lang-4.x/ast/parser/xml/internal/loops/for.d.ts +0 -4
- package/r-bridge/lang-4.x/ast/parser/xml/internal/loops/index.d.ts +0 -5
- package/r-bridge/lang-4.x/ast/parser/xml/internal/loops/index.js +0 -22
- package/r-bridge/lang-4.x/ast/parser/xml/internal/loops/next.d.ts +0 -4
- package/r-bridge/lang-4.x/ast/parser/xml/internal/loops/repeat.d.ts +0 -13
- package/r-bridge/lang-4.x/ast/parser/xml/internal/loops/while.d.ts +0 -4
- package/r-bridge/lang-4.x/ast/parser/xml/internal/operators/index.d.ts +0 -3
- package/r-bridge/lang-4.x/ast/parser/xml/internal/operators/index.js +0 -20
- package/r-bridge/lang-4.x/ast/parser/xml/internal/operators/special.d.ts +0 -6
- package/r-bridge/lang-4.x/ast/parser/xml/internal/operators/special.js +0 -24
- package/r-bridge/lang-4.x/ast/parser/xml/internal/operators/unary.d.ts +0 -13
- package/r-bridge/lang-4.x/ast/parser/xml/internal/operators/unary.js +0 -59
- package/r-bridge/lang-4.x/ast/parser/xml/internal/other/comment.d.ts +0 -11
- package/r-bridge/lang-4.x/ast/parser/xml/internal/other/index.d.ts +0 -1
- package/r-bridge/lang-4.x/ast/parser/xml/internal/other/index.js +0 -18
- package/r-bridge/lang-4.x/ast/parser/xml/internal/other/line-directive.d.ts +0 -12
- package/r-bridge/lang-4.x/ast/parser/xml/internal/structure/elements.d.ts +0 -10
- package/r-bridge/lang-4.x/ast/parser/xml/internal/structure/elements.js +0 -159
- package/r-bridge/lang-4.x/ast/parser/xml/internal/structure/index.d.ts +0 -3
- package/r-bridge/lang-4.x/ast/parser/xml/internal/structure/index.js +0 -20
- package/r-bridge/lang-4.x/ast/parser/xml/internal/structure/root.d.ts +0 -4
- package/r-bridge/lang-4.x/ast/parser/xml/internal/structure/root.js +0 -33
- package/r-bridge/lang-4.x/ast/parser/xml/internal/structure/single-element.d.ts +0 -13
- package/r-bridge/lang-4.x/ast/parser/xml/internal/structure/single-element.js +0 -64
- package/r-bridge/lang-4.x/ast/parser/xml/internal/values/index.d.ts +0 -3
- package/r-bridge/lang-4.x/ast/parser/xml/internal/values/index.js +0 -20
- package/r-bridge/lang-4.x/ast/parser/xml/internal/values/number.d.ts +0 -13
- package/r-bridge/lang-4.x/ast/parser/xml/internal/values/string.d.ts +0 -11
- package/r-bridge/lang-4.x/index.d.ts +0 -2
- package/r-bridge/lang-4.x/index.js +0 -19
- package/slicing/criterion/filters/index.d.ts +0 -1
- package/slicing/criterion/filters/index.js +0 -18
- package/slicing/criterion/index.d.ts +0 -3
- package/slicing/criterion/index.js +0 -20
- package/slicing/index.d.ts +0 -3
- package/slicing/index.js +0 -20
- package/slicing/static/index.d.ts +0 -1
- package/slicing/static/index.js +0 -18
- package/util/mermaid/index.d.ts +0 -3
- package/util/mermaid/index.js +0 -20
- /package/{r-bridge/lang-4.x/ast/parser/xml → benchmark/summarizer}/data.js +0 -0
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
export interface IStoppableStopwatch {
|
|
2
|
+
/** Stop the given stopwatch. */
|
|
3
|
+
stop(): void;
|
|
4
|
+
}
|
|
5
|
+
/**
|
|
6
|
+
* Allows to measure keys of type `T` with a `Stopwatch`.
|
|
7
|
+
*
|
|
8
|
+
* Measure with {@link start}, {@link measure} or {@link measureAsync}, retrieve the final measurements with {@link get}.
|
|
9
|
+
*/
|
|
10
|
+
export declare class Measurements<T> {
|
|
11
|
+
private measurements;
|
|
12
|
+
/**
|
|
13
|
+
* Start a timer for the given key, and guards that this is the first time this key is started.
|
|
14
|
+
* Call {@link IStoppableStopwatch#stop} on the returned stopwatch to stop the timer.
|
|
15
|
+
*/
|
|
16
|
+
start(key: T): IStoppableStopwatch;
|
|
17
|
+
/**
|
|
18
|
+
* Automatically call {@link Measurements#start | start} and the corresponding stop to measure the execution time of the given function.
|
|
19
|
+
* @see {@link measureAsync}
|
|
20
|
+
*/
|
|
21
|
+
measure<Out>(key: T, fn: () => Out): Out;
|
|
22
|
+
/**
|
|
23
|
+
* Similar to {@link measure}, but await the promise as part of the measurement
|
|
24
|
+
*
|
|
25
|
+
* @param key - The key to write the resulting measurement to
|
|
26
|
+
* @param fn - The function to measure
|
|
27
|
+
*
|
|
28
|
+
* @see measure
|
|
29
|
+
*/
|
|
30
|
+
measureAsync<Out>(key: T, fn: () => Promise<Out>): Promise<Out>;
|
|
31
|
+
/**
|
|
32
|
+
* Retrieve all measure-results, requires that all stop-watches that have been started have also been stopped.
|
|
33
|
+
*/
|
|
34
|
+
get(): Map<T, bigint>;
|
|
35
|
+
}
|
|
@@ -0,0 +1,79 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.Measurements = void 0;
|
|
4
|
+
const assert_1 = require("../util/assert");
|
|
5
|
+
/** unguarded start-stop wrapper */
|
|
6
|
+
class Stopwatch {
|
|
7
|
+
timeStart;
|
|
8
|
+
timeEnd;
|
|
9
|
+
stopped = false;
|
|
10
|
+
start() {
|
|
11
|
+
this.timeStart = process.hrtime.bigint();
|
|
12
|
+
}
|
|
13
|
+
stop() {
|
|
14
|
+
this.timeEnd = process.hrtime.bigint();
|
|
15
|
+
// check after to not affect measurements
|
|
16
|
+
(0, assert_1.guard)(!this.stopped, 'cannot stop a stopwatch twice');
|
|
17
|
+
this.stopped = true;
|
|
18
|
+
}
|
|
19
|
+
get() {
|
|
20
|
+
(0, assert_1.guard)(this.timeStart !== undefined && this.timeEnd !== undefined, 'cannot get elapsed time as the stopwatch has not been started/stopped');
|
|
21
|
+
return this.timeEnd - this.timeStart;
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
/**
|
|
25
|
+
* Allows to measure keys of type `T` with a `Stopwatch`.
|
|
26
|
+
*
|
|
27
|
+
* Measure with {@link start}, {@link measure} or {@link measureAsync}, retrieve the final measurements with {@link get}.
|
|
28
|
+
*/
|
|
29
|
+
class Measurements {
|
|
30
|
+
measurements = new Map();
|
|
31
|
+
/**
|
|
32
|
+
* Start a timer for the given key, and guards that this is the first time this key is started.
|
|
33
|
+
* Call {@link IStoppableStopwatch#stop} on the returned stopwatch to stop the timer.
|
|
34
|
+
*/
|
|
35
|
+
start(key) {
|
|
36
|
+
// we guard *before* starting so there is no additional time penalty
|
|
37
|
+
(0, assert_1.guard)(!this.measurements.has(key), `already started stop watch for ${JSON.stringify(key)}`);
|
|
38
|
+
const stopwatch = new Stopwatch();
|
|
39
|
+
this.measurements.set(key, stopwatch);
|
|
40
|
+
stopwatch.start();
|
|
41
|
+
return stopwatch;
|
|
42
|
+
}
|
|
43
|
+
/**
|
|
44
|
+
* Automatically call {@link Measurements#start | start} and the corresponding stop to measure the execution time of the given function.
|
|
45
|
+
* @see {@link measureAsync}
|
|
46
|
+
*/
|
|
47
|
+
measure(key, fn) {
|
|
48
|
+
const stopwatch = this.start(key);
|
|
49
|
+
const result = fn();
|
|
50
|
+
stopwatch.stop();
|
|
51
|
+
return result;
|
|
52
|
+
}
|
|
53
|
+
/**
|
|
54
|
+
* Similar to {@link measure}, but await the promise as part of the measurement
|
|
55
|
+
*
|
|
56
|
+
* @param key - The key to write the resulting measurement to
|
|
57
|
+
* @param fn - The function to measure
|
|
58
|
+
*
|
|
59
|
+
* @see measure
|
|
60
|
+
*/
|
|
61
|
+
async measureAsync(key, fn) {
|
|
62
|
+
const stopwatch = this.start(key);
|
|
63
|
+
const result = await fn();
|
|
64
|
+
stopwatch.stop();
|
|
65
|
+
return result;
|
|
66
|
+
}
|
|
67
|
+
/**
|
|
68
|
+
* Retrieve all measure-results, requires that all stop-watches that have been started have also been stopped.
|
|
69
|
+
*/
|
|
70
|
+
get() {
|
|
71
|
+
const result = new Map();
|
|
72
|
+
for (const [key, stopwatch] of this.measurements) {
|
|
73
|
+
result.set(key, stopwatch.get());
|
|
74
|
+
}
|
|
75
|
+
return result;
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
exports.Measurements = Measurements;
|
|
79
|
+
//# sourceMappingURL=stopwatch.js.map
|
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
import type { SummarizedMeasurement } from '../../util/summarizer';
|
|
2
|
+
import type { CommonSlicerMeasurements, PerSliceMeasurements, SlicerStats, SlicerStatsDataflow, SlicerStatsInput } from '../stats/stats';
|
|
3
|
+
export interface SliceSizeCollection {
|
|
4
|
+
lines: number[];
|
|
5
|
+
characters: number[];
|
|
6
|
+
nonWhitespaceCharacters: number[];
|
|
7
|
+
/** like library statements during reconstruction */
|
|
8
|
+
autoSelected: number[];
|
|
9
|
+
dataflowNodes: number[];
|
|
10
|
+
tokens: number[];
|
|
11
|
+
normalizedTokens: number[];
|
|
12
|
+
}
|
|
13
|
+
/**
|
|
14
|
+
* @see SlicerStats
|
|
15
|
+
* @see summarizeSlicerStats
|
|
16
|
+
*/
|
|
17
|
+
export type SummarizedSlicerStats = {
|
|
18
|
+
perSliceMeasurements: SummarizedPerSliceStats;
|
|
19
|
+
} & Omit<SlicerStats, 'perSliceMeasurements'>;
|
|
20
|
+
export interface Reduction<T = number> {
|
|
21
|
+
numberOfLines: T;
|
|
22
|
+
numberOfLinesNoAutoSelection: T;
|
|
23
|
+
numberOfCharacters: T;
|
|
24
|
+
numberOfNonWhitespaceCharacters: T;
|
|
25
|
+
numberOfRTokens: T;
|
|
26
|
+
numberOfNormalizedTokens: T;
|
|
27
|
+
numberOfDataflowNodes: T;
|
|
28
|
+
}
|
|
29
|
+
export interface SummarizedPerSliceStats {
|
|
30
|
+
/** number of total slicing calls */
|
|
31
|
+
numberOfSlices: number;
|
|
32
|
+
/** statistics on the used slicing criteria (number of ids within criteria etc.) */
|
|
33
|
+
sliceCriteriaSizes: SummarizedMeasurement;
|
|
34
|
+
measurements: Map<PerSliceMeasurements, SummarizedMeasurement>;
|
|
35
|
+
reduction: Reduction<SummarizedMeasurement>;
|
|
36
|
+
failedToRepParse: number;
|
|
37
|
+
timesHitThreshold: number;
|
|
38
|
+
sliceSize: {
|
|
39
|
+
[K in keyof SliceSizeCollection]: SummarizedMeasurement;
|
|
40
|
+
};
|
|
41
|
+
}
|
|
42
|
+
export interface UltimateSlicerStats {
|
|
43
|
+
totalRequests: number;
|
|
44
|
+
totalSlices: number;
|
|
45
|
+
commonMeasurements: Map<CommonSlicerMeasurements, SummarizedMeasurement>;
|
|
46
|
+
perSliceMeasurements: Map<PerSliceMeasurements, SummarizedMeasurement>;
|
|
47
|
+
/** sum */
|
|
48
|
+
failedToRepParse: number;
|
|
49
|
+
/** sum */
|
|
50
|
+
timesHitThreshold: number;
|
|
51
|
+
reduction: Reduction<SummarizedMeasurement>;
|
|
52
|
+
input: SlicerStatsInput<SummarizedMeasurement>;
|
|
53
|
+
dataflow: SlicerStatsDataflow<SummarizedMeasurement>;
|
|
54
|
+
}
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
/// <reference types="node" />
|
|
2
|
+
export declare function processRunMeasurement(line: Buffer, fileNum: number, lineNum: number, summarizedText: string, outputPath: string): Promise<void>;
|
|
3
|
+
export declare function processSummarizedFileMeasurement(file: string, summariesFile: string, outputPath: string): void;
|
|
@@ -0,0 +1,76 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.processSummarizedFileMeasurement = exports.processRunMeasurement = void 0;
|
|
7
|
+
const fs_1 = __importDefault(require("fs"));
|
|
8
|
+
const process_1 = require("../second-phase/process");
|
|
9
|
+
const process_2 = require("./process");
|
|
10
|
+
const assert_1 = require("../../../util/assert");
|
|
11
|
+
const ansi_1 = require("../../../util/ansi");
|
|
12
|
+
const json_1 = require("../../../util/json");
|
|
13
|
+
const files_1 = require("../../../util/files");
|
|
14
|
+
const print_1 = require("../../stats/print");
|
|
15
|
+
async function processRunMeasurement(line, fileNum, lineNum, summarizedText, outputPath) {
|
|
16
|
+
let got = JSON.parse(line.toString());
|
|
17
|
+
console.log(`[file ${fileNum}, line ${lineNum}] Summarize for ${got.filename}`);
|
|
18
|
+
// now we have to recover the maps and bigints :C
|
|
19
|
+
got = {
|
|
20
|
+
filename: got.filename,
|
|
21
|
+
'file-id': got['file-id'],
|
|
22
|
+
'run-num': got['run-num'],
|
|
23
|
+
stats: {
|
|
24
|
+
input: got.stats.input,
|
|
25
|
+
request: got.stats.request,
|
|
26
|
+
dataflow: got.stats.dataflow,
|
|
27
|
+
commonMeasurements: new Map(got.stats.commonMeasurements
|
|
28
|
+
.map(([k, v]) => {
|
|
29
|
+
(0, assert_1.guard)(v.endsWith('n'), 'Expected a bigint');
|
|
30
|
+
return [k, BigInt(v.slice(0, -1))];
|
|
31
|
+
})),
|
|
32
|
+
perSliceMeasurements: new Map(got.stats.perSliceMeasurements
|
|
33
|
+
.map(([k, v]) => mapPerSliceStats(k, v)))
|
|
34
|
+
}
|
|
35
|
+
};
|
|
36
|
+
const totalSlices = got.stats.perSliceMeasurements.size;
|
|
37
|
+
console.log(`Summarizing ${totalSlices} slices...`);
|
|
38
|
+
let atSliceNumber = 0;
|
|
39
|
+
const summarized = await (0, process_2.summarizeSlicerStats)(got.stats, (criterion, stats) => {
|
|
40
|
+
console.log(`${ansi_1.escape}1F${ansi_1.escape}1G${ansi_1.escape}2K [${++atSliceNumber}/${totalSlices}] Summarizing ${JSON.stringify(criterion)} (reconstructed has ${stats.reconstructedCode.code.length} characters)`);
|
|
41
|
+
});
|
|
42
|
+
console.log(` - Append raw summary to ${outputPath}`);
|
|
43
|
+
fs_1.default.appendFileSync(outputPath, `${JSON.stringify({
|
|
44
|
+
filename: got.filename,
|
|
45
|
+
'file-id': got['file-id'],
|
|
46
|
+
'run-num': got['run-num'],
|
|
47
|
+
summarize: summarized
|
|
48
|
+
}, json_1.jsonReplacer)}\n`);
|
|
49
|
+
console.log(` - Append textual summary to ${summarizedText}`);
|
|
50
|
+
fs_1.default.appendFileSync(summarizedText, `${(0, print_1.stats2string)(summarized)}\n`);
|
|
51
|
+
}
|
|
52
|
+
exports.processRunMeasurement = processRunMeasurement;
|
|
53
|
+
function processSummarizedFileMeasurement(file, summariesFile, outputPath) {
|
|
54
|
+
console.log(`Summarize all runs for ${file}`);
|
|
55
|
+
const summaries = [];
|
|
56
|
+
(0, files_1.readLineByLineSync)(summariesFile, l => (0, process_1.processNextSummary)(l, summaries));
|
|
57
|
+
fs_1.default.appendFileSync(outputPath, `${JSON.stringify({
|
|
58
|
+
filename: file,
|
|
59
|
+
summarize: (0, process_1.summarizeAllSummarizedStats)(summaries)
|
|
60
|
+
}, json_1.jsonReplacer)}\n`);
|
|
61
|
+
}
|
|
62
|
+
exports.processSummarizedFileMeasurement = processSummarizedFileMeasurement;
|
|
63
|
+
function mapPerSliceStats(k, v) {
|
|
64
|
+
return [k, {
|
|
65
|
+
reconstructedCode: v.reconstructedCode,
|
|
66
|
+
slicingCriteria: v.slicingCriteria,
|
|
67
|
+
timesHitThreshold: v.timesHitThreshold,
|
|
68
|
+
measurements: new Map(v.measurements
|
|
69
|
+
.map(([k, v]) => {
|
|
70
|
+
(0, assert_1.guard)(v.endsWith('n'), 'Expected a bigint');
|
|
71
|
+
return [k, BigInt(v.slice(0, -1))];
|
|
72
|
+
})),
|
|
73
|
+
numberOfDataflowNodesSliced: v.numberOfDataflowNodesSliced
|
|
74
|
+
}];
|
|
75
|
+
}
|
|
76
|
+
//# sourceMappingURL=input.js.map
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import type { Reduction, SummarizedSlicerStats } from '../data';
|
|
2
|
+
import type { SummarizedMeasurement } from '../../../util/summarizer';
|
|
3
|
+
import type { PerSliceStats, SlicerStats } from '../../stats/stats';
|
|
4
|
+
import type { SlicingCriteria } from '../../../slicing/criterion/parse';
|
|
5
|
+
/**
|
|
6
|
+
* Summarizes the given stats by calculating the min, max, median, mean, and the standard deviation for each measurement.
|
|
7
|
+
* @see Slicer
|
|
8
|
+
*/
|
|
9
|
+
export declare function summarizeSlicerStats(stats: SlicerStats, report?: (criteria: SlicingCriteria, stats: PerSliceStats) => void): Promise<Readonly<SummarizedSlicerStats>>;
|
|
10
|
+
export declare function summarizeSummarizedMeasurement(data: SummarizedMeasurement[]): SummarizedMeasurement;
|
|
11
|
+
export declare function summarizeReductions(reductions: Reduction<SummarizedMeasurement>[]): Reduction<SummarizedMeasurement>;
|
|
@@ -0,0 +1,205 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
|
19
|
+
if (mod && mod.__esModule) return mod;
|
|
20
|
+
var result = {};
|
|
21
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
22
|
+
__setModuleDefault(result, mod);
|
|
23
|
+
return result;
|
|
24
|
+
};
|
|
25
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
26
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
27
|
+
};
|
|
28
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
29
|
+
exports.summarizeReductions = exports.summarizeSummarizedMeasurement = exports.summarizeSlicerStats = void 0;
|
|
30
|
+
const tmp = __importStar(require("tmp"));
|
|
31
|
+
const fs_1 = __importDefault(require("fs"));
|
|
32
|
+
const defaultmap_1 = require("../../../util/defaultmap");
|
|
33
|
+
const log_1 = require("../../../util/log");
|
|
34
|
+
const strings_1 = require("../../../util/strings");
|
|
35
|
+
const summarizer_1 = require("../../../util/summarizer");
|
|
36
|
+
const assert_1 = require("../../../util/assert");
|
|
37
|
+
const shell_1 = require("../../../r-bridge/shell");
|
|
38
|
+
const retriever_1 = require("../../../r-bridge/retriever");
|
|
39
|
+
const visitor_1 = require("../../../r-bridge/lang-4.x/ast/model/processing/visitor");
|
|
40
|
+
const tempfile = (() => {
|
|
41
|
+
let _tempfile = undefined;
|
|
42
|
+
return () => {
|
|
43
|
+
if (_tempfile === undefined) {
|
|
44
|
+
_tempfile = tmp.fileSync({ postfix: '.R', keep: false });
|
|
45
|
+
process.on('beforeExit', () => _tempfile?.removeCallback());
|
|
46
|
+
}
|
|
47
|
+
return _tempfile;
|
|
48
|
+
};
|
|
49
|
+
})();
|
|
50
|
+
function safeDivPercentage(a, b) {
|
|
51
|
+
if (isNaN(a) || isNaN(b)) {
|
|
52
|
+
return undefined;
|
|
53
|
+
}
|
|
54
|
+
else if (b === 0) {
|
|
55
|
+
return a === 0 ? 0 : undefined;
|
|
56
|
+
}
|
|
57
|
+
else {
|
|
58
|
+
const result = 1 - (a / b);
|
|
59
|
+
if (isNaN(result)) {
|
|
60
|
+
log_1.log.error(`NaN for ${a} and ${b}\n`);
|
|
61
|
+
return undefined;
|
|
62
|
+
}
|
|
63
|
+
else {
|
|
64
|
+
return result;
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
function calculateReductionForSlice(input, dataflow, perSlice) {
|
|
69
|
+
return {
|
|
70
|
+
numberOfLines: safeDivPercentage(perSlice.lines, input.numberOfLines),
|
|
71
|
+
numberOfLinesNoAutoSelection: safeDivPercentage(perSlice.lines - perSlice.autoSelected, input.numberOfLines),
|
|
72
|
+
numberOfCharacters: safeDivPercentage(perSlice.characters, input.numberOfCharacters),
|
|
73
|
+
numberOfNonWhitespaceCharacters: safeDivPercentage(perSlice.nonWhitespaceCharacters, input.numberOfNonWhitespaceCharacters),
|
|
74
|
+
numberOfRTokens: safeDivPercentage(perSlice.tokens, input.numberOfRTokens),
|
|
75
|
+
numberOfNormalizedTokens: safeDivPercentage(perSlice.normalizedTokens, input.numberOfNormalizedTokens),
|
|
76
|
+
numberOfDataflowNodes: safeDivPercentage(perSlice.dataflowNodes, dataflow.numberOfNodes)
|
|
77
|
+
};
|
|
78
|
+
}
|
|
79
|
+
/**
|
|
80
|
+
* Summarizes the given stats by calculating the min, max, median, mean, and the standard deviation for each measurement.
|
|
81
|
+
* @see Slicer
|
|
82
|
+
*/
|
|
83
|
+
async function summarizeSlicerStats(stats, report = () => {
|
|
84
|
+
}) {
|
|
85
|
+
const perSliceStats = stats.perSliceMeasurements;
|
|
86
|
+
const collect = new defaultmap_1.DefaultMap(() => []);
|
|
87
|
+
const sizeOfSliceCriteria = [];
|
|
88
|
+
const reParseShellSession = new shell_1.RShell();
|
|
89
|
+
const reductions = [];
|
|
90
|
+
let failedOutputs = 0;
|
|
91
|
+
const sliceSize = {
|
|
92
|
+
lines: [],
|
|
93
|
+
autoSelected: [],
|
|
94
|
+
characters: [],
|
|
95
|
+
nonWhitespaceCharacters: [],
|
|
96
|
+
tokens: [],
|
|
97
|
+
normalizedTokens: [],
|
|
98
|
+
dataflowNodes: []
|
|
99
|
+
};
|
|
100
|
+
let timesHitThreshold = 0;
|
|
101
|
+
for (const [criteria, perSliceStat] of perSliceStats) {
|
|
102
|
+
report(criteria, perSliceStat);
|
|
103
|
+
for (const measure of perSliceStat.measurements) {
|
|
104
|
+
collect.get(measure[0]).push(Number(measure[1]));
|
|
105
|
+
}
|
|
106
|
+
sizeOfSliceCriteria.push(perSliceStat.slicingCriteria.length);
|
|
107
|
+
timesHitThreshold += perSliceStat.timesHitThreshold > 0 ? 1 : 0;
|
|
108
|
+
const { code: output, autoSelected } = perSliceStat.reconstructedCode;
|
|
109
|
+
sliceSize.autoSelected.push(autoSelected);
|
|
110
|
+
const lines = output.split('\n').length;
|
|
111
|
+
sliceSize.lines.push(lines);
|
|
112
|
+
sliceSize.characters.push(output.length);
|
|
113
|
+
const nonWhitespace = (0, strings_1.withoutWhitespace)(output).length;
|
|
114
|
+
sliceSize.nonWhitespaceCharacters.push(nonWhitespace);
|
|
115
|
+
// reparse the output to get the number of tokens
|
|
116
|
+
try {
|
|
117
|
+
// there seem to be encoding issues, therefore, we dump to a temp file
|
|
118
|
+
fs_1.default.writeFileSync(tempfile().name, output);
|
|
119
|
+
const reParsed = await (0, retriever_1.retrieveNormalizedAstFromRCode)({ request: 'file', content: tempfile().name }, reParseShellSession);
|
|
120
|
+
let numberOfNormalizedTokens = 0;
|
|
121
|
+
(0, visitor_1.visitAst)(reParsed.ast, _ => {
|
|
122
|
+
numberOfNormalizedTokens++;
|
|
123
|
+
return false;
|
|
124
|
+
});
|
|
125
|
+
sliceSize.normalizedTokens.push(numberOfNormalizedTokens);
|
|
126
|
+
const numberOfRTokens = await (0, retriever_1.retrieveNumberOfRTokensOfLastParse)(reParseShellSession);
|
|
127
|
+
sliceSize.tokens.push(numberOfRTokens);
|
|
128
|
+
reductions.push(calculateReductionForSlice(stats.input, stats.dataflow, {
|
|
129
|
+
lines: lines,
|
|
130
|
+
characters: output.length,
|
|
131
|
+
nonWhitespaceCharacters: nonWhitespace,
|
|
132
|
+
autoSelected: autoSelected,
|
|
133
|
+
tokens: numberOfRTokens,
|
|
134
|
+
normalizedTokens: numberOfNormalizedTokens,
|
|
135
|
+
dataflowNodes: perSliceStat.numberOfDataflowNodesSliced
|
|
136
|
+
}));
|
|
137
|
+
}
|
|
138
|
+
catch (e) {
|
|
139
|
+
console.error(` ! Failed to re-parse the output of the slicer for ${JSON.stringify(criteria)}`); //, e
|
|
140
|
+
console.error(` Code: ${output}\n`);
|
|
141
|
+
failedOutputs++;
|
|
142
|
+
}
|
|
143
|
+
sliceSize.dataflowNodes.push(perSliceStat.numberOfDataflowNodesSliced);
|
|
144
|
+
}
|
|
145
|
+
// summarize all measurements:
|
|
146
|
+
const summarized = new Map();
|
|
147
|
+
for (const [criterion, measurements] of collect.entries()) {
|
|
148
|
+
summarized.set(criterion, (0, summarizer_1.summarizeMeasurement)(measurements));
|
|
149
|
+
}
|
|
150
|
+
reParseShellSession.close();
|
|
151
|
+
return {
|
|
152
|
+
...stats,
|
|
153
|
+
perSliceMeasurements: {
|
|
154
|
+
numberOfSlices: perSliceStats.size,
|
|
155
|
+
sliceCriteriaSizes: (0, summarizer_1.summarizeMeasurement)(sizeOfSliceCriteria),
|
|
156
|
+
measurements: summarized,
|
|
157
|
+
failedToRepParse: failedOutputs,
|
|
158
|
+
timesHitThreshold,
|
|
159
|
+
reduction: {
|
|
160
|
+
numberOfLines: (0, summarizer_1.summarizeMeasurement)(reductions.map(r => r.numberOfLines).filter(assert_1.isNotUndefined)),
|
|
161
|
+
numberOfLinesNoAutoSelection: (0, summarizer_1.summarizeMeasurement)(reductions.map(r => r.numberOfLinesNoAutoSelection).filter(assert_1.isNotUndefined)),
|
|
162
|
+
numberOfCharacters: (0, summarizer_1.summarizeMeasurement)(reductions.map(r => r.numberOfCharacters).filter(assert_1.isNotUndefined)),
|
|
163
|
+
numberOfNonWhitespaceCharacters: (0, summarizer_1.summarizeMeasurement)(reductions.map(r => r.numberOfNonWhitespaceCharacters).filter(assert_1.isNotUndefined)),
|
|
164
|
+
numberOfRTokens: (0, summarizer_1.summarizeMeasurement)(reductions.map(r => r.numberOfRTokens).filter(assert_1.isNotUndefined)),
|
|
165
|
+
numberOfNormalizedTokens: (0, summarizer_1.summarizeMeasurement)(reductions.map(r => r.numberOfNormalizedTokens).filter(assert_1.isNotUndefined)),
|
|
166
|
+
numberOfDataflowNodes: (0, summarizer_1.summarizeMeasurement)(reductions.map(r => r.numberOfDataflowNodes).filter(assert_1.isNotUndefined))
|
|
167
|
+
},
|
|
168
|
+
sliceSize: {
|
|
169
|
+
lines: (0, summarizer_1.summarizeMeasurement)(sliceSize.lines),
|
|
170
|
+
characters: (0, summarizer_1.summarizeMeasurement)(sliceSize.characters),
|
|
171
|
+
nonWhitespaceCharacters: (0, summarizer_1.summarizeMeasurement)(sliceSize.nonWhitespaceCharacters),
|
|
172
|
+
autoSelected: (0, summarizer_1.summarizeMeasurement)(sliceSize.autoSelected),
|
|
173
|
+
tokens: (0, summarizer_1.summarizeMeasurement)(sliceSize.tokens),
|
|
174
|
+
normalizedTokens: (0, summarizer_1.summarizeMeasurement)(sliceSize.normalizedTokens),
|
|
175
|
+
dataflowNodes: (0, summarizer_1.summarizeMeasurement)(sliceSize.dataflowNodes)
|
|
176
|
+
}
|
|
177
|
+
}
|
|
178
|
+
};
|
|
179
|
+
}
|
|
180
|
+
exports.summarizeSlicerStats = summarizeSlicerStats;
|
|
181
|
+
function summarizeSummarizedMeasurement(data) {
|
|
182
|
+
const min = data.map(d => d.min).filter(assert_1.isNotUndefined).reduce((a, b) => Math.min(a, b), Infinity);
|
|
183
|
+
const max = data.map(d => d.max).filter(assert_1.isNotUndefined).reduce((a, b) => Math.max(a, b), -Infinity);
|
|
184
|
+
// get most average
|
|
185
|
+
const median = data.map(d => d.median).filter(assert_1.isNotUndefined).reduce((a, b) => a + b, 0) / data.length;
|
|
186
|
+
const mean = data.map(d => d.mean).filter(assert_1.isNotUndefined).reduce((a, b) => a + b, 0) / data.length;
|
|
187
|
+
// Method 1 of https://www.statology.org/averaging-standard-deviations/
|
|
188
|
+
const std = Math.sqrt(data.map(d => d.std ** 2).filter(assert_1.isNotUndefined).reduce((a, b) => a + b, 0) / data.length);
|
|
189
|
+
const total = data.map(d => d.total).filter(assert_1.isNotUndefined).reduce((a, b) => a + b, 0);
|
|
190
|
+
return { min, max, median, mean, std, total };
|
|
191
|
+
}
|
|
192
|
+
exports.summarizeSummarizedMeasurement = summarizeSummarizedMeasurement;
|
|
193
|
+
function summarizeReductions(reductions) {
|
|
194
|
+
return {
|
|
195
|
+
numberOfDataflowNodes: summarizeSummarizedMeasurement(reductions.map(r => r.numberOfDataflowNodes)),
|
|
196
|
+
numberOfLines: summarizeSummarizedMeasurement(reductions.map(r => r.numberOfLines)),
|
|
197
|
+
numberOfCharacters: summarizeSummarizedMeasurement(reductions.map(r => r.numberOfCharacters)),
|
|
198
|
+
numberOfNonWhitespaceCharacters: summarizeSummarizedMeasurement(reductions.map(r => r.numberOfNonWhitespaceCharacters)),
|
|
199
|
+
numberOfLinesNoAutoSelection: summarizeSummarizedMeasurement(reductions.map(r => r.numberOfLinesNoAutoSelection)),
|
|
200
|
+
numberOfNormalizedTokens: summarizeSummarizedMeasurement(reductions.map(r => r.numberOfNormalizedTokens)),
|
|
201
|
+
numberOfRTokens: summarizeSummarizedMeasurement(reductions.map(r => r.numberOfRTokens))
|
|
202
|
+
};
|
|
203
|
+
}
|
|
204
|
+
exports.summarizeReductions = summarizeReductions;
|
|
205
|
+
//# sourceMappingURL=process.js.map
|
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.writeGraphOutput = void 0;
|
|
7
|
+
const fs_1 = __importDefault(require("fs"));
|
|
8
|
+
const json_1 = require("../../../util/json");
|
|
9
|
+
function writeGraphOutput(ultimate, outputGraphPath) {
|
|
10
|
+
console.log(`Producing benchmark graph data (${outputGraphPath})...`);
|
|
11
|
+
const data = [];
|
|
12
|
+
for (const { name, measurements } of [{ name: 'per-file', measurements: ultimate.commonMeasurements }, { name: 'per-slice', measurements: ultimate.perSliceMeasurements }]) {
|
|
13
|
+
for (const [point, measurement] of measurements) {
|
|
14
|
+
if (point === 'close R session' || point === 'initialize R session') {
|
|
15
|
+
continue;
|
|
16
|
+
}
|
|
17
|
+
const pointName = point === 'total' ? `total ${name}` : point;
|
|
18
|
+
data.push({
|
|
19
|
+
name: pointName[0].toUpperCase() + pointName.slice(1),
|
|
20
|
+
unit: 'ms',
|
|
21
|
+
value: Number(measurement.mean / 1e6),
|
|
22
|
+
range: Number(measurement.std / 1e6),
|
|
23
|
+
extra: `median: ${(measurement.median / 1e6).toFixed(2)}ms`
|
|
24
|
+
});
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
data.push({
|
|
28
|
+
name: 'failed to reconstruct/re-parse',
|
|
29
|
+
unit: '#',
|
|
30
|
+
value: ultimate.failedToRepParse,
|
|
31
|
+
extra: `out of ${ultimate.totalSlices} slices`
|
|
32
|
+
});
|
|
33
|
+
data.push({
|
|
34
|
+
name: 'times hit threshold',
|
|
35
|
+
unit: '#',
|
|
36
|
+
value: ultimate.timesHitThreshold
|
|
37
|
+
});
|
|
38
|
+
data.push({
|
|
39
|
+
name: 'reduction (characters)',
|
|
40
|
+
unit: '#',
|
|
41
|
+
value: ultimate.reduction.numberOfCharacters.mean,
|
|
42
|
+
extra: `std: ${ultimate.reduction.numberOfCharacters.std}`
|
|
43
|
+
});
|
|
44
|
+
data.push({
|
|
45
|
+
name: 'reduction (normalized tokens)',
|
|
46
|
+
unit: '#',
|
|
47
|
+
value: ultimate.reduction.numberOfNormalizedTokens.mean,
|
|
48
|
+
extra: `std: ${ultimate.reduction.numberOfNormalizedTokens.std}`
|
|
49
|
+
});
|
|
50
|
+
// write the output file
|
|
51
|
+
fs_1.default.writeFileSync(outputGraphPath, JSON.stringify(data, json_1.jsonReplacer));
|
|
52
|
+
}
|
|
53
|
+
exports.writeGraphOutput = writeGraphOutput;
|
|
54
|
+
//# sourceMappingURL=graph.js.map
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
/// <reference types="node" />
|
|
2
|
+
import type { SummarizedSlicerStats, UltimateSlicerStats } from '../data';
|
|
3
|
+
export declare function summarizeAllSummarizedStats(stats: SummarizedSlicerStats[]): UltimateSlicerStats;
|
|
4
|
+
export declare function summarizeAllUltimateStats(stats: UltimateSlicerStats[]): UltimateSlicerStats;
|
|
5
|
+
export declare function processNextSummary(line: Buffer, allSummarized: SummarizedSlicerStats[]): void;
|
|
6
|
+
export declare function processNextUltimateSummary(line: Buffer, allSummarized: UltimateSlicerStats[]): void;
|
|
@@ -0,0 +1,127 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.processNextUltimateSummary = exports.processNextSummary = exports.summarizeAllUltimateStats = exports.summarizeAllSummarizedStats = void 0;
|
|
4
|
+
const process_1 = require("../first-phase/process");
|
|
5
|
+
const defaultmap_1 = require("../../../util/defaultmap");
|
|
6
|
+
const summarizer_1 = require("../../../util/summarizer");
|
|
7
|
+
const assert_1 = require("../../../util/assert");
|
|
8
|
+
const stats_1 = require("../../stats/stats");
|
|
9
|
+
function summarizeAllSummarizedStats(stats) {
|
|
10
|
+
const commonMeasurements = new defaultmap_1.DefaultMap(() => []);
|
|
11
|
+
const perSliceMeasurements = new defaultmap_1.DefaultMap(() => []);
|
|
12
|
+
const reductions = [];
|
|
13
|
+
const inputs = [];
|
|
14
|
+
const dataflows = [];
|
|
15
|
+
let failedToRepParse = 0;
|
|
16
|
+
let timesHitThreshold = 0;
|
|
17
|
+
let totalSlices = 0;
|
|
18
|
+
for (const stat of stats) {
|
|
19
|
+
for (const [k, v] of stat.commonMeasurements) {
|
|
20
|
+
commonMeasurements.get(k).push(Number(v));
|
|
21
|
+
}
|
|
22
|
+
for (const [k, v] of stat.perSliceMeasurements.measurements) {
|
|
23
|
+
perSliceMeasurements.get(k).push(v);
|
|
24
|
+
}
|
|
25
|
+
reductions.push(stat.perSliceMeasurements.reduction);
|
|
26
|
+
inputs.push(stat.input);
|
|
27
|
+
dataflows.push(stat.dataflow);
|
|
28
|
+
failedToRepParse += stat.perSliceMeasurements.failedToRepParse;
|
|
29
|
+
totalSlices += stat.perSliceMeasurements.numberOfSlices;
|
|
30
|
+
timesHitThreshold += stat.perSliceMeasurements.timesHitThreshold;
|
|
31
|
+
}
|
|
32
|
+
return {
|
|
33
|
+
totalRequests: stats.length,
|
|
34
|
+
totalSlices: totalSlices,
|
|
35
|
+
commonMeasurements: new Map([...commonMeasurements.entries()].map(([k, v]) => [k, (0, summarizer_1.summarizeMeasurement)(v)])),
|
|
36
|
+
perSliceMeasurements: new Map([...perSliceMeasurements.entries()].map(([k, v]) => [k, (0, process_1.summarizeSummarizedMeasurement)(v)])),
|
|
37
|
+
failedToRepParse,
|
|
38
|
+
timesHitThreshold,
|
|
39
|
+
reduction: (0, process_1.summarizeReductions)(reductions),
|
|
40
|
+
input: {
|
|
41
|
+
numberOfLines: (0, summarizer_1.summarizeMeasurement)(inputs.map(i => i.numberOfLines)),
|
|
42
|
+
numberOfCharacters: (0, summarizer_1.summarizeMeasurement)(inputs.map(i => i.numberOfCharacters)),
|
|
43
|
+
numberOfNonWhitespaceCharacters: (0, summarizer_1.summarizeMeasurement)(inputs.map(i => i.numberOfNonWhitespaceCharacters)),
|
|
44
|
+
numberOfRTokens: (0, summarizer_1.summarizeMeasurement)(inputs.map(i => i.numberOfRTokens)),
|
|
45
|
+
numberOfNormalizedTokens: (0, summarizer_1.summarizeMeasurement)(inputs.map(i => i.numberOfNormalizedTokens))
|
|
46
|
+
},
|
|
47
|
+
dataflow: {
|
|
48
|
+
numberOfNodes: (0, summarizer_1.summarizeMeasurement)(dataflows.map(d => d.numberOfNodes)),
|
|
49
|
+
numberOfFunctionDefinitions: (0, summarizer_1.summarizeMeasurement)(dataflows.map(d => d.numberOfFunctionDefinitions)),
|
|
50
|
+
numberOfCalls: (0, summarizer_1.summarizeMeasurement)(dataflows.map(d => d.numberOfCalls)),
|
|
51
|
+
numberOfEdges: (0, summarizer_1.summarizeMeasurement)(dataflows.map(d => d.numberOfEdges))
|
|
52
|
+
}
|
|
53
|
+
};
|
|
54
|
+
}
|
|
55
|
+
exports.summarizeAllSummarizedStats = summarizeAllSummarizedStats;
|
|
56
|
+
function summarizeAllUltimateStats(stats) {
|
|
57
|
+
return {
|
|
58
|
+
// these should be deterministic, so we don't technically need to use max, but we do just in case something unexpected happens :)
|
|
59
|
+
totalRequests: Math.max(...stats.map(s => s.totalRequests)),
|
|
60
|
+
totalSlices: Math.max(...stats.map(s => s.totalSlices)),
|
|
61
|
+
failedToRepParse: Math.max(...stats.map(s => s.failedToRepParse)),
|
|
62
|
+
timesHitThreshold: Math.max(...stats.map(s => s.timesHitThreshold)),
|
|
63
|
+
// average out / summarize other measurements
|
|
64
|
+
commonMeasurements: new Map(stats_1.CommonSlicerMeasurements.map(m => [m, (0, process_1.summarizeSummarizedMeasurement)(stats.map(s => s.commonMeasurements.get(m)))])),
|
|
65
|
+
perSliceMeasurements: new Map(stats_1.PerSliceMeasurements.map(m => [m, (0, process_1.summarizeSummarizedMeasurement)(stats.map(s => s.perSliceMeasurements.get(m)))])),
|
|
66
|
+
reduction: (0, process_1.summarizeReductions)(stats.map(s => s.reduction)),
|
|
67
|
+
input: {
|
|
68
|
+
numberOfLines: (0, process_1.summarizeSummarizedMeasurement)(stats.map(s => s.input.numberOfLines)),
|
|
69
|
+
numberOfCharacters: (0, process_1.summarizeSummarizedMeasurement)(stats.map(s => s.input.numberOfCharacters)),
|
|
70
|
+
numberOfNonWhitespaceCharacters: (0, process_1.summarizeSummarizedMeasurement)(stats.map(s => s.input.numberOfNonWhitespaceCharacters)),
|
|
71
|
+
numberOfRTokens: (0, process_1.summarizeSummarizedMeasurement)(stats.map(s => s.input.numberOfRTokens)),
|
|
72
|
+
numberOfNormalizedTokens: (0, process_1.summarizeSummarizedMeasurement)(stats.map(s => s.input.numberOfNormalizedTokens))
|
|
73
|
+
},
|
|
74
|
+
dataflow: {
|
|
75
|
+
numberOfNodes: (0, process_1.summarizeSummarizedMeasurement)(stats.map(s => s.dataflow.numberOfNodes)),
|
|
76
|
+
numberOfFunctionDefinitions: (0, process_1.summarizeSummarizedMeasurement)(stats.map(s => s.dataflow.numberOfFunctionDefinitions)),
|
|
77
|
+
numberOfCalls: (0, process_1.summarizeSummarizedMeasurement)(stats.map(s => s.dataflow.numberOfCalls)),
|
|
78
|
+
numberOfEdges: (0, process_1.summarizeSummarizedMeasurement)(stats.map(s => s.dataflow.numberOfEdges))
|
|
79
|
+
}
|
|
80
|
+
};
|
|
81
|
+
}
|
|
82
|
+
exports.summarizeAllUltimateStats = summarizeAllUltimateStats;
|
|
83
|
+
function processNextSummary(line, allSummarized) {
|
|
84
|
+
let got = JSON.parse(line.toString());
|
|
85
|
+
got = {
|
|
86
|
+
summarize: {
|
|
87
|
+
input: got.summarize.input,
|
|
88
|
+
request: got.summarize.request,
|
|
89
|
+
dataflow: got.summarize.dataflow,
|
|
90
|
+
commonMeasurements: new Map(got.summarize.commonMeasurements
|
|
91
|
+
.map(([k, v]) => {
|
|
92
|
+
(0, assert_1.guard)(v.endsWith('n'), 'Expected a bigint');
|
|
93
|
+
return [k, BigInt(v.slice(0, -1))];
|
|
94
|
+
})),
|
|
95
|
+
perSliceMeasurements: {
|
|
96
|
+
numberOfSlices: got.summarize.perSliceMeasurements.numberOfSlices,
|
|
97
|
+
sliceCriteriaSizes: got.summarize.perSliceMeasurements.sliceCriteriaSizes,
|
|
98
|
+
measurements: new Map(got.summarize.perSliceMeasurements.measurements),
|
|
99
|
+
reduction: got.summarize.perSliceMeasurements.reduction,
|
|
100
|
+
timesHitThreshold: got.summarize.perSliceMeasurements.timesHitThreshold,
|
|
101
|
+
failedToRepParse: got.summarize.perSliceMeasurements.failedToRepParse,
|
|
102
|
+
sliceSize: got.summarize.perSliceMeasurements.sliceSize
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
};
|
|
106
|
+
allSummarized.push(got.summarize);
|
|
107
|
+
}
|
|
108
|
+
exports.processNextSummary = processNextSummary;
|
|
109
|
+
function processNextUltimateSummary(line, allSummarized) {
|
|
110
|
+
let got = JSON.parse(line.toString());
|
|
111
|
+
got = {
|
|
112
|
+
summarize: {
|
|
113
|
+
totalRequests: got.summarize.totalRequests,
|
|
114
|
+
totalSlices: got.summarize.totalSlices,
|
|
115
|
+
commonMeasurements: new Map(got.summarize.commonMeasurements),
|
|
116
|
+
perSliceMeasurements: new Map(got.summarize.perSliceMeasurements),
|
|
117
|
+
failedToRepParse: got.summarize.failedToRepParse,
|
|
118
|
+
timesHitThreshold: got.summarize.timesHitThreshold,
|
|
119
|
+
reduction: got.summarize.reduction,
|
|
120
|
+
input: got.summarize.input,
|
|
121
|
+
dataflow: got.summarize.dataflow,
|
|
122
|
+
}
|
|
123
|
+
};
|
|
124
|
+
allSummarized.push(got.summarize);
|
|
125
|
+
}
|
|
126
|
+
exports.processNextUltimateSummary = processNextUltimateSummary;
|
|
127
|
+
//# sourceMappingURL=process.js.map
|