diff options
-rw-r--r-- | src/PureMicroPasses.ml | 112 |
1 files changed, 66 insertions, 46 deletions
diff --git a/src/PureMicroPasses.ml b/src/PureMicroPasses.ml index 1ef4b325..e2894fe9 100644 --- a/src/PureMicroPasses.ml +++ b/src/PureMicroPasses.ml @@ -604,9 +604,13 @@ let filter_unused (filter_monadic_calls : bool) (ctx : trans_ctx) (* Return *) { def with body; inputs_lvs } -(** Add unit arguments for functions with no arguments, and change their return type. - TODO: filter the backward functions with no outputs. - *) +(** Return `None` if the function is a backward function with no outputs (so + that we eliminate the definition which is useless) *) +let filter_if_backward_with_no_outputs (def : fun_def) : fun_def option = + if Option.is_some def.back_id && def.signature.outputs = [] then None + else Some def + +(** Add unit arguments for functions with no arguments, and change their return type *) let to_monadic (def : fun_def) : fun_def = (* Update the body *) let obj = @@ -758,10 +762,12 @@ let unfold_monadic_let_bindings (_ctx : trans_ctx) (def : fun_def) : fun_def = (** Apply all the micro-passes to a function. + Will return `None` if the function is a backward function with no outputs. + [ctx]: used only for printing. *) let apply_passes_to_def (config : config) (ctx : trans_ctx) (def : fun_def) : - fun_def = + fun_def option = (* Debug *) log#ldebug (lazy @@ -785,55 +791,69 @@ let apply_passes_to_def (config : config) (ctx : trans_ctx) (def : fun_def) : let def = remove_meta def in log#ldebug (lazy ("remove_meta:\n\n" ^ fun_def_to_string ctx def ^ "\n")); - (* Add unit arguments for functions with no arguments, and change their return type. - * **Rk.**: from now onwards, the types in the AST are correct (until now, - * functions had return type `t` where they should have return type `result t`). - * Also, from now onwards, the outputs list has length 1. x*) - let def = to_monadic def in - log#ldebug (lazy ("to_monadic:\n\n" ^ fun_def_to_string ctx def ^ "\n")); - - (* Convert the unit variables to `()` if they are used as right-values or - * `_` if they are used as left values. *) - let def = unit_vars_to_unit def in - log#ldebug - (lazy ("unit_vars_to_unit:\n\n" ^ fun_def_to_string ctx def ^ "\n")); - - (* Inline the useless variable reassignments *) - let inline_named_vars = true in - let def = inline_useless_var_reassignments inline_named_vars def in - log#ldebug - (lazy - ("inline_useless_var_assignments:\n\n" ^ fun_def_to_string ctx def ^ "\n")); - - (* Eliminate the box functions *) - let def = eliminate_box_functions ctx def in - log#ldebug - (lazy ("eliminate_box_functions:\n\n" ^ fun_def_to_string ctx def ^ "\n")); - - (* Filter the unused variables, assignments, function calls, etc. *) - let def = filter_unused config.filter_unused_monadic_calls ctx def in - log#ldebug (lazy ("filter_unused:\n\n" ^ fun_def_to_string ctx def ^ "\n")); + (* Remove the backward functions with no outputs. + * Note that the calls to those functions should already have been removed, + * when translating from symbolic to pure. Here, we remove the definitions + * altogether, because they are now useless *) + let def = filter_if_backward_with_no_outputs def in + + match def with + | None -> None + | Some def -> + (* Add unit arguments for functions with no arguments, and change their return type. + * **Rk.**: from now onwards, the types in the AST are correct (until now, + * functions had return type `t` where they should have return type `result t`). + * Also, from now onwards, the outputs list has length 1. x*) + let def = to_monadic def in + log#ldebug (lazy ("to_monadic:\n\n" ^ fun_def_to_string ctx def ^ "\n")); + + (* Convert the unit variables to `()` if they are used as right-values or + * `_` if they are used as left values. *) + let def = unit_vars_to_unit def in + log#ldebug + (lazy ("unit_vars_to_unit:\n\n" ^ fun_def_to_string ctx def ^ "\n")); - (* Unfold the monadic let-bindings *) - let def = - if config.unfold_monadic_let_bindings then ( - let def = unfold_monadic_let_bindings ctx def in + (* Inline the useless variable reassignments *) + let inline_named_vars = true in + let def = inline_useless_var_reassignments inline_named_vars def in log#ldebug (lazy - ("unfold_monadic_let_bindings:\n\n" ^ fun_def_to_string ctx def ^ "\n")); - def) - else ( + ("inline_useless_var_assignments:\n\n" ^ fun_def_to_string ctx def + ^ "\n")); + + (* Eliminate the box functions *) + let def = eliminate_box_functions ctx def in log#ldebug - (lazy "ignoring unfold_monadic_let_bindings due to the configuration\n"); - def) - in + (lazy + ("eliminate_box_functions:\n\n" ^ fun_def_to_string ctx def ^ "\n")); - (* We are done *) - def + (* Filter the unused variables, assignments, function calls, etc. *) + let def = filter_unused config.filter_unused_monadic_calls ctx def in + log#ldebug + (lazy ("filter_unused:\n\n" ^ fun_def_to_string ctx def ^ "\n")); + + (* Unfold the monadic let-bindings *) + let def = + if config.unfold_monadic_let_bindings then ( + let def = unfold_monadic_let_bindings ctx def in + log#ldebug + (lazy + ("unfold_monadic_let_bindings:\n\n" ^ fun_def_to_string ctx def + ^ "\n")); + def) + else ( + log#ldebug + (lazy + "ignoring unfold_monadic_let_bindings due to the configuration\n"); + def) + in + + (* We are done *) + Some def let apply_passes_to_pure_fun_translation (config : config) (ctx : trans_ctx) (trans : pure_fun_translation) : pure_fun_translation = let forward, backwards = trans in - let forward = apply_passes_to_def config ctx forward in - let backwards = List.map (apply_passes_to_def config ctx) backwards in + let forward = Option.get (apply_passes_to_def config ctx forward) in + let backwards = List.filter_map (apply_passes_to_def config ctx) backwards in (forward, backwards) |