| PureBytes Links Trading Reference Links | There is much easier and reliable method: 
dt = LastValue( DateTime() );
if( StaticVarGet( "lastdt" ) != dt )
{
  _TRACE("New bar");
  StaticVarSet("lastdt", dt );
}
(Note that it works only if Tools->Preferences->Intraday is set
to show START or END time of interval).
Best regards,
Tomasz Janeczko
amibroker.com
----- Original Message ----- 
From: "Yofa" <jtoth100@xxxxxxxxxxx>
To: <amibroker@xxxxxxxxxxxxxxx>
Sent: Tuesday, March 17, 2009 1:03 PM
Subject: Re: [amibroker] Re: Testing for new bar using string manipulation and quotation time
> Hi,
> 
> barTime % 100 == 0 will not work reliably! If there is no new tick or no CPU 
> time to do refresh it will skipp new bars a few times!
> This is a common problem. Look for similar posts here. You will fined code 
> samples.
> 
> Y
> --------------------------------------------------
> From: "Mike" <sfclimbers@xxxxxxxxx>
> Sent: Tuesday, March 17, 2009 4:04 AM
> To: <amibroker@xxxxxxxxxxxxxxx>
> Subject: [amibroker] Re: Testing for new bar using string manipulation and 
> quotation time
> 
>> If you have any concerns about rounding, you could use AlmostEqual instead 
>> of "==".
>>
>> http://www.amibroker.com/guide/afl/afl_view.php?id=301
>>
>> Mike
>>
>> --- In amibroker@xxxxxxxxxxxxxxx, "ozzyapeman" <zoopfree@xxx> wrote:
>>>
>>> Thanks a bunch, Mike. Modulo's so much simpler!
>>>
>>>
>>> --- In amibroker@xxxxxxxxxxxxxxx, "Mike" <sfclimbers@> wrote:
>>> >
>>> > Again, assuming that your approach is sound, better still would be to 
>>> > use the modulo operator.
>>> >
>>> > barTime = 103731;
>>> >
>>> > if (barTime % 100 == 0)
>>> >   _TRACE( "New bar found" );
>>> >
>>> > Mike
>>> >
>>> > --- In amibroker@xxxxxxxxxxxxxxx, "Mike" <sfclimbers@> wrote:
>>> > >
>>> > > Without commenting on the validity of the approach (I am not a real 
>>> > > time trader), I can suggest that your problem is coming from a 
>>> > > formatting incompatibility.
>>> > >
>>> > > Add a format clause indicating zero decimal places and it will work 
>>> > > fine.
>>> > >
>>> > > Note too that your switching back to a number again is redundant and 
>>> > > even error prone since "==" is not necessarily exact when dealing 
>>> > > with floats. Just use the string manipulation directly.
>>> > >
>>> > > barTime       = 103731;
>>> > > barTimeStr    = NumToStr( barTime, 6.0 );
>>> > >
>>> > > if ( StrRight( barTimeStr, 2 ) == "00" )
>>> > >     _TRACE ( "New bar found" );
>>> > >
>>> > > Mike
>>> > >
>>> > > --- In amibroker@xxxxxxxxxxxxxxx, "ozzyapeman" <zoopfree@> wrote:
>>> > > >
>>> > > > Hello, hoping someone can help out with this string conversion 
>>> > > > problem.
>>> > > >
>>> > > > In live trading, I am pulling quotation time using TimeNum(), and 
>>> > > > want
>>> > > > to test for the start of a new bar. So my thinking is to simply 
>>> > > > convert
>>> > > > the time to a number, extract the last two characters, convert back 
>>> > > > to a
>>> > > > number and see if it equals 0. If so, that means the last two 
>>> > > > digits in
>>> > > > the quotation time are "00" and hence we are at the start of a new 
>>> > > > bar.
>>> > > >
>>> > > > However, the sample code below is always thinking we have a new bar
>>> > > > whether the time is, for e.g.  :
>>> > > >
>>> > > > 10:37:31   or
>>> > > > 10:37:00
>>> > > >
>>> > > >   Obviously, only the second time should trip the 'new bar' print. 
>>> > > > But
>>> > > > instead, both do:
>>> > > >
>>> > > >
>>> > > > barTime       = 103731;  // we would normally use TimeNum() here, 
>>> > > > but
>>> > > > using a number for example
>>> > > >
>>> > > > barTimeStr    = NumToStr(barTime);
>>> > > >
>>> > > > NewBarSeconds = StrToNum ( StrRight(barTimeStr, 2) );
>>> > > >
>>> > > > printf("NewBarSeconds = " + NewBarSeconds);
>>> > > >
>>> > > > if (NewBarSeconds == 0)
>>> > > >
>>> > > > printf("    We have a new bar");
>>> > > >
>>> > >
>>> >
>>>
>>
>>
>>
>>
>> ------------------------------------
>>
>> **** IMPORTANT PLEASE READ ****
>> This group is for the discussion between users only.
>> This is *NOT* technical support channel.
>>
>> TO GET TECHNICAL SUPPORT send an e-mail directly to
>> SUPPORT {at} amibroker.com
>>
>> TO SUBMIT SUGGESTIONS please use FEEDBACK CENTER at
>> http://www.amibroker.com/feedback/
>> (submissions sent via other channels won't be considered)
>>
>> For NEW RELEASE ANNOUNCEMENTS and other news always check DEVLOG:
>> http://www.amibroker.com/devlog/
>>
>> Yahoo! Groups Links
>>
>>
>>
>> 
> 
> 
> ------------------------------------
> 
> **** IMPORTANT PLEASE READ ****
> This group is for the discussion between users only.
> This is *NOT* technical support channel.
> 
> TO GET TECHNICAL SUPPORT send an e-mail directly to 
> SUPPORT {at} amibroker.com
> 
> TO SUBMIT SUGGESTIONS please use FEEDBACK CENTER at
> http://www.amibroker.com/feedback/
> (submissions sent via other channels won't be considered)
> 
> For NEW RELEASE ANNOUNCEMENTS and other news always check DEVLOG:
> http://www.amibroker.com/devlog/
> 
> Yahoo! Groups Links
> 
> 
> 
------------------------------------
**** IMPORTANT PLEASE READ ****
This group is for the discussion between users only.
This is *NOT* technical support channel.
TO GET TECHNICAL SUPPORT send an e-mail directly to 
SUPPORT {at} amibroker.com
TO SUBMIT SUGGESTIONS please use FEEDBACK CENTER at
http://www.amibroker.com/feedback/
(submissions sent via other channels won't be considered)
For NEW RELEASE ANNOUNCEMENTS and other news always check DEVLOG:
http://www.amibroker.com/devlog/
Yahoo! Groups Links
<*> To visit your group on the web, go to:
    http://groups.yahoo.com/group/amibroker/
<*> Your email settings:
    Individual Email | Traditional
<*> To change settings online go to:
    http://groups.yahoo.com/group/amibroker/join
    (Yahoo! ID required)
<*> To change settings via email:
    mailto:amibroker-digest@xxxxxxxxxxxxxxx 
    mailto:amibroker-fullfeatured@xxxxxxxxxxxxxxx
<*> To unsubscribe from this group, send an email to:
    amibroker-unsubscribe@xxxxxxxxxxxxxxx
<*> Your use of Yahoo! Groups is subject to:
    http://docs.yahoo.com/info/terms/
 |