In Coq: inversion of existential quantifier with multiple variables, with one command?

Question

I am working through a proof in which there is a hypothesis

Hypothesis H : exists a b v, P a b v.

If I use inversion H, then I recover

H: exists a b v : nat, P a b v
x: nat
H0: exists b v : nat, P x b v

which is fine, but then I need to use inversion twice more to recover b and v. Is there a single command to recover a, b, v all at once?

Answer (Anton Trunov)

You can use a list of patterns (p1 & ... & pn) for sequence of right-associative binary inductive constructors such as conj or ex_intro:

H: exists a b v : nat, P a b v
a, b, v: nat
H': P a b v

False

Another nice example from the reference manual: if we have a hypothesis

A /\ (exists x, B /\ C /\ D).

Then, we can destruct it with

destruct H as (a & x & b & c & d).

Answer (pintoch)

Yes, by specifying binders for the objects you want to introduce, like this:

H: exists a b v : nat, P a b v
a, b, v: nat
H': P a b v

False

Note that destruct also works here (with the same syntax), it generates a slightly simpler proof (In general, the manual warns against large proofs generated by inversion).