Re: Memory Conservation
- To: mathgroup at smc.vnet.net
- Subject: [mg29922] Re: Memory Conservation
- From: Jens-Peer Kuska <kuska at informatik.uni-leipzig.de>
- Date: Thu, 19 Jul 2001 03:56:51 -0400 (EDT)
- Organization: Universitaet Leipzig
- References: <9iomg8$i13$1@smc.vnet.net> <9j3a5e$in4$1@smc.vnet.net>
- Sender: owner-wri-mathgroup at wolfram.com
Hi, Orestis Vantzos wrote: > > a) The main difference between Module and Block is just that; Module removes > all local variables. That is nonsense! Module[] has variables with *local* scope. That means, that for f1[x_]:=Module[{y},f2[x]] f2[x_]:=Module[{x2=x*x},x*x*x2] the function f2 can't access/modify the variable y defined in the Module[] of f2. That is the usual behaviour of programming languages (with exeption of LISP). With: f1[x_]:=Block[{y},f2[x]] f2[x_]:=Module[{x2=x*x},x*x*x2] f2[] *can* access and modify the variable y. That is called dynamic scope. Every function that is called form a Block[] has access to the Block[] variables. This sounds a bit strange but it is very useful. Here is an example of a function that transform a polynom due to Horners rule makeHorner[x_] := Fold[#2 + x*#1 &, 0, Reverse[coeff]] PolynomToHorner[p_, x_] /; PolynomialQ[p, x] := Block[{coeff}, coeff = CoefficientList[p, x]; makeHorner[x] ] The makeHorner[] function don't need the coefficents as an function argument. This is a way to avoid, that large data copyed to Mathematica's stack. It will usual faster than Module[] and save stack memory. *Both* Block[] and Module[] will clean the memory on return ! The local scope of Module[] is not so clean implemented as it should. Module[{y},...] will create a variable y$? where "?" is a number that changes for every call of the Module[]. Since y$? is an other symbol for ervery Module[] execution the called function can't get the true symbol name if it is not passed as an argument. BTW: Orestis ! please look into the manuals *before* you post a false statement. Regards Jens