[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

[Metastockusers] Re: Better coding in MetaStock



PureBytes Links

Trading Reference Links


...and finally:

5) Always check that your code works in MetaStock as intended, 
preferably before posting.  ;)

Correction:

Short 
---8<----------

{ Variables } 
SMAperiods:=14; 
EnvPercent:=3; 

{ Envelope signals } 
Env:=EnvPercent/100; 
upper:=C>(1+Env)*Mov(C,SMAperiods,S); 
lower:=C<(1-Env)*Mov(C,SMAperiods,S); 

{ Trade binary flag } 
binary:=ValueWhen(1,upper-lower<>0,upper-lower); 

{ Short trade flag } 
binary<0

---8<----------


jose '-)



--- In Metastockusers@xxxxxxxxxxxxxxx, "Jose Silva" <josesilva22@xxxx> 
wrote:
> 
> 
> Some poor MetaStock coding practices worth avoiding:
> 
> 1) MetaStock's PREV function slows down processing dramatically -
> its use should be avoided wherever possible.  Placing unnecessary
> PREV functions in a formula generally reflects poor programming
> skills;
> 
> 2) Rather than create a zillion formulae with different hard-coded 
> parameters scattered inside the formula, assign these values to 
> parameters so they may be easily changed as required;
> 
> 3) Always use meaningful names for variables.  The code may need to
> be followed and understood by others, or worse still, Alzheimer's
> may just be around the corner;
> 
> 4) Use {comments} wherever possible, for the same reasons as #3.
> 
> 
> Here is a recent example of code that ignores the above four points:
> 
> ========================
> 3% envelope 14 MA Expert
> ========================
> ---8<--------------
> Long 
> 
> A:=C>1.03*Mov(C,14,S); 
> B:=C<.97*Mov(C,14,S); 
> D:=If(A,1,If(B,0,PREV)); 
> D=1 
> 
> Short 
> 
> A:=C>1.03*Mov(C,14,S); 
> B:=C<.97*Mov(C,14,S); 
> D:=If(A,1,If(B,0,PREV)); 
> D=0 
> 
> Symbol tab 
> 
> Long 
> 
> A:=C>1.03*Mov(C,14,S); 
> B:=C<.97*Mov(C,14,S); 
> D:=If(A,1,If(B,0,PREV)); 
> D=1 AND Ref(D,-1)=0 
> 
> short 
> 
> A:=C>1.03*Mov(C,14,S); 
> B:=C<.97*Mov(C,14,S); 
> D:=If(A,1,If(B,0,PREV)); 
> D=0 AND Ref(D,-1)=1
> ---8<--------------
> 
> The code above is an example of poor coding in MetaStock, because:
> 
> 1) Four (unnecessary) PREV function slows down the plotting of the 
> Expert signals, and would dramatically slow down an exploration
> based on this code;
> 
> 2) No parameters assigned to global variables - it would take some 
> effort to change the 16 values, and there is always the risk of 
> introducing errors;
> 
> 3) No meaningful names assigned to variables.  Try following the
> code of some of the longer formulae, and the problem becomes
> apparent;
> 
> 4) No {comments} used.  The author may not need them, but others
> could do with some.
> 
> 
> The code below plots the same signals, and:
> 
> 1) Avoids PREV functions;
> 
> 2) Assigns global variables to variables at the easy-to-get head of 
> the formula;
> 
> 3) Uses names for variables that reflect their intended use;
> 
> 4 {Comments}, {Comments}, {Comments}.
> 
> ===========================
> 14 SMA / 3% envelope Expert
> ===========================
> 
> Highlights tab:
> 
> Long 
> ---8<----------
> 
> { Variables }
> SMAperiods:=14;
> EnvPercent:=3;
> 
> { Envelope signals }
> Env:=EnvPercent/100;
> upper:=C>(1+Env)*Mov(C,SMAperiods,S); 
> lower:=C<(1-Env)*Mov(C,SMAperiods,S); 
> 
> { Trade binary flag }
> binary:=ValueWhen(1,upper-lower<>0,upper-lower);
> 
> { Long trade flag }
> binary=1
> 
> ---8<----------
> 
> 
> Short 
> ---8<----------
> 
> { Variables }
> SMAperiods:=14;
> EnvPercent:=3;
> 
> { Envelope signals }
> Env:=EnvPercent/100;
> upper:=C>(1+Env)*Mov(C,SMAperiods,S); 
> lower:=C<(1-Env)*Mov(C,SMAperiods,S); 
> 
> { Trade binary flag }
> binary:=ValueWhen(1,upper-lower<>0,upper-lower);
> 
> { Short trade flag }
> binary=0
> 
> ---8<----------
> 
> 
> Symbols tab:
> 
> Long 
> ---8<----------
> 
> { Variables }
> SMAperiods:=14;
> EnvPercent:=3;
> 
> { Envelope signals }
> Env:=EnvPercent/100;
> upper:=C>(1+Env)*Mov(C,SMAperiods,S); 
> lower:=C<(1-Env)*Mov(C,SMAperiods,S); 
> 
> { Trade binary flag }
> binary:=ValueWhen(1,upper-lower<>0,upper-lower);
> 
> { Long trade - first signal }
> long:=binary=1 AND Alert(binary<1,2);
> long
> 
> ---8<----------
> 
> Short 
> ---8<----------
> 
> { Variables }
> SMAperiods:=14;
> EnvPercent:=3;
> 
> { Envelope signals }
> Env:=EnvPercent/100;
> upper:=C>(1+Env)*Mov(C,SMAperiods,S); 
> lower:=C<(1-Env)*Mov(C,SMAperiods,S); 
> 
> { Trade binary flag }
> binary:=ValueWhen(1,upper-lower<>0,upper-lower);
> 
> { Short trade - first signal }
> short:=binary<1 AND Alert(binary>0,2);
> short
> 
> ---8<----------
> 
> Life is so much easier with clean, annotated code... ;)
> 
> 
> jose '-)
> http://www.metastocktools.com





------------------------ Yahoo! Groups Sponsor --------------------~--> 
In low income neighborhoods, 84% do not own computers.
At Network for Good, help bridge the Digital Divide!
http://us.click.yahoo.com/EpW3eD/3MnJAA/cosFAA/zMEolB/TM
--------------------------------------------------------------------~-> 

 
Yahoo! Groups Links

<*> To visit your group on the web, go to:
    http://groups.yahoo.com/group/Metastockusers/

<*> To unsubscribe from this group, send an email to:
    Metastockusers-unsubscribe@xxxxxxxxxxxxxxx

<*> Your use of Yahoo! Groups is subject to:
    http://docs.yahoo.com/info/terms/