MathGroup Archive 2006

[Date Index] [Thread Index] [Author Index]

Search the Archive

Re: Deleting Selective DownValues

  • To: mathgroup at smc.vnet.net
  • Subject: [mg64007] Re: [mg63985] Deleting Selective DownValues
  • From: "Carl K. Woll" <carlw at wolfram.com>
  • Date: Fri, 27 Jan 2006 05:13:18 -0500 (EST)
  • References: <200601260843.DAA22213@smc.vnet.net>
  • Sender: owner-wri-mathgroup at wolfram.com

David Park wrote:
> I think I found the solution for deleting definitions with a given number of arguments. The trick was to change the function name to stop evaluation.
> 
> deleteDownValue[label_Symbol, numberOfArgs_Integer?Positive] :=
>   Module[{g},
>     DownValues[f] =
>         Select[DownValues[f], 
>           Length[First[#] /. label -> g /. HoldPattern -> Identity] != 
>               numberOfArgs &];]
> 
> Clear[f]
> f[x_, y_, z_] := x y z
> f[a_, b_] := a b
> f[x_] := x
> DownValues[f]
> deleteDownValue[f, 2]
> DownValues[f]
> 
> {HoldPattern[f[x_, y_, z_]] :> x y z, HoldPattern[f[a_, b_]] :> a b, 
>   HoldPattern[f[x_]] :> x}
> 
> {HoldPattern[f[x_, y_, z_]] :> x y z, HoldPattern[f[x_]] :> x}
> 
> David Park
> djmp at earthlink.net
> http://home.earthlink.net/~djmp/ 

David,

Here's another idea:

deletedv[f_, n_] := DownValues[f] = DeleteCases[DownValues[f],
     (Verbatim[HoldPattern][_[x__]] :> _)
      /; Length[{x}] == n]

Carl Woll
Wolfram Research


  • Prev by Date: Re: Deleting Selective DownValues
  • Next by Date: When does Mathematica display a message?
  • Previous by thread: Deleting Selective DownValues
  • Next by thread: Deleting Selective DownValues