# HG changeset patch # User blanchet # Date 1380877948 -7200 # Node ID a2c4e0b7b1e256332c869e6cf7436c25d9fc887f # Parent 8298976acb54efae5ad54dd6a284a65c8c6d716b more parallelism in blocking mode diff -r 8298976acb54 -r a2c4e0b7b1e2 src/HOL/Tools/Sledgehammer/sledgehammer_run.ML --- a/src/HOL/Tools/Sledgehammer/sledgehammer_run.ML Fri Oct 04 09:46:08 2013 +0200 +++ b/src/HOL/Tools/Sledgehammer/sledgehammer_run.ML Fri Oct 04 11:12:28 2013 +0200 @@ -309,20 +309,21 @@ val launch_ueq_atps = launch_atps "Unit-equational provers" (SOME is_unit_equality) ueq_atps - fun launch_atps_and_smt_solvers () = + fun launch_atps_and_smt_solvers p = [launch_full_atps, launch_smts, launch_ueq_atps] - |> Par_List.map (fn f => ignore (f (unknownN, state))) + |> Par_List.map (fn f => fst (f p)) handle ERROR msg => (print ("Error: " ^ msg); error msg) fun maybe f (accum as (outcome_code, _)) = accum |> (mode = Normal orelse outcome_code <> someN) ? f in (unknownN, state) - |> (if blocking then + |> (if mode = Auto_Try then launch_full_atps - #> mode <> Auto_Try ? (maybe launch_ueq_atps #> maybe launch_smts) + else if blocking then + launch_atps_and_smt_solvers #> max_outcome_code #> rpair state else - (fn p => Future.fork (tap launch_atps_and_smt_solvers) |> K p)) + (fn p => (Future.fork (tap (fn () => launch_atps_and_smt_solvers p)); p))) handle TimeLimit.TimeOut => (print "Sledgehammer ran out of time."; (unknownN, state)) end