P_PCHOOSE_THEN expects a pair q, a tactic-generating function
f:thm->tactic, and a theorem of the form (A1 |- ?p. u) as
arguments.  A new theorem is created by introducing the given pair
q as a witness for the pair p whose existence is asserted in the original
theorem, (u[q/p] |- u[q/p]).  If the tactic-generating function f
applied to this theorem produces results as follows when applied to a
goal (A ?- u):
    A ?- t
   =========  f ({u[q/p]} |- u[q/p])
    A ?- t1
    A ?- t
   =========  P_PCHOOSE_THEN "q" f (A1 |- ?p. u)
    A ?- t1         ("q" not free anywhere)