+1

I have a lot of respect for you taking such a long path, for being patient & 
persistent.
 
> On 10 Mar 2015, at 18:06, Max Leske <[email protected]> wrote:
> 
> Great work Ben!
> 
>> On 10 Mar 2015, at 17:44, Ben Coman <[email protected]> wrote:
>> 
>> This is solved with the integration of issue 14353 into build 40548.
>> 
>> On an OSX > Virtualbox > LinuxMint17 with the following script...
>>     for i in `seq 1 10` ;
>>     do
>>         (time $MYPHAROVM  $MYIMAGE \
>>              eval "(Delay forSeconds: 1) wait") 2>&1 > /dev/null | grep real
>>     done
>> 
>> Build 40547 gives...
>> real 0m1.288s
>> real 0m1.256s
>> real 0m1.258s
>> real 0m0.254s
>> real 0m0.269s
>> real 0m0.274s
>> real 0m0.260s
>> real 0m0.245s
>> real 0m0.254s
>> real 0m1.260s
>> 
>> Build 40548 gives...
>> real 0m1.285s
>> real 0m1.259s
>> real 0m1.260s
>> real 0m1.260s
>> real 0m1.280s
>> real 0m1.267s
>> real 0m1.265s
>> real 0m1.293s
>> real 0m1.267s
>> real 0m1.278s
>> 
>> HTH,
>> cheers -ben
>> 
>> 
>> On Mon, Mar 2, 2015 at 12:08 PM, Ben Coman <[email protected]> wrote:
>> 
>> This is not going to get as much use before Release as I had hoped, so I 
>> refactored it to be able to easily switch between the existing and new code 
>> by making two schedulers...
>> * DelayMillisecondScheduler - essentially the existing code
>> * DelayMicrosecondScheduler - based off new primitive
>> which are switchable on the fly via a System Setting.
>> 
>> To try to make it easier to review, I've separated changes into three stages:
>> * SLICE.10 accumulates changes the Delay class to add some better semantics 
>> to instance variables and method renames
>> * SLICE.14 accumulates changes to split DelayScheduler into two subclasses 
>> for the two different schedulers (use the incoming code in the merge 
>> conflict)
>> * SLICE.17 accumulates changes to modify DelayMicrosecondScheduler, plus a 
>> couple of polishing things.
>> 
>> I've added some review notes to the issue
>> https://pharo.fogbugz.com/default.asp?14353 
>> 
>> fyi, Tomorrow I start a new job at Buewaters Power Station [1] (2 x 208MW 
>> generators).  They've been without an electrical engineer for three months 
>> leading up to their annual outage in five weeks, so I'm probably flat there 
>> playing catch-up for the next two months.  Today (GMT+8) would be a really 
>> good time to engage me with feedback and queries.  I'll try to hang out on 
>> IRC as much as possible to speed up discussion.
>> 
>> [1] http://www.bluewatersps.com.au/
>> 
>> cheers -ben
>> 
>> 
>> 
>> On Mon, Mar 2, 2015 at 3:09 AM, stepharo <[email protected]> wrote:
>> 
>> Please help us to push ben code.
>> 
>> 
>> 
>> -------- Message transféré --------
>> Sujet :      Re: [Pharo-dev] Super fast delay
>> Date :       Wed, 25 Feb 2015 02:00:25 +0800
>> De : Ben Coman <[email protected]>
>> Répondre à : Pharo Development List <[email protected]>
>> Pour :       Pharo Development List <[email protected]>
>> 
>> 
>> I've updated this fix for build 40504.  The following slice is read for 
>> review. 
>> SLICE-Issue-14353-Delay-refactoring-part-2---change-from-milliseconds-to-microseconds-BenComan.6
>> 
>> Even if you do not feel up to reviewing the code, it would be good for a few 
>> people to merge this to get a broad sample of symptoms fixed or caused.
>> 
>> 1. Open up Monticello and get ready to load the above slice from Pharo4Inbox 
>> repository.
>> 2. In a workspace, do "Delay stopTimerEventLoop".   Ignore the 
>> #intercyclePause: message that stream by. 
>> 3. Merge slice.
>> 4. In a workspace, do "Delay startTimerEventLoop".  The stream of 
>> #interCyclePause message should fade.
>> 5. Operate as you normally would. Test some cases that previously caused an 
>> error.
>> 
>> cheers -ben
>> 
>> On Thu, Feb 19, 2015 at 11:17 PM, Ben Coman <[email protected]> wrote:
>> 
>> 
>> On Thu, Feb 19, 2015 at 9:50 PM, Ben Coman <[email protected]> wrote:
>> 
>> 
>> On Mon, Feb 16, 2015 at 4:01 PM, Holger Hans Peter Freyther 
>> <[email protected]> wrote:
>> On Thu, Oct 30, 2014 at 06:32:48PM -0400, stepharo wrote:
>> 
>> Good Morning Ben, Stef,
>> 
>> > We really need people to have a look at the code of Ben.
>> 
>> I downloaded a Pharo-4 image today and executed:
>> 
>> To clarify.  The fix is not yet in Pharo-4.  
>>  
>> 
>> time pharo --nodisplay --headless ./Pharo-40490.image  eval "(Delay 
>> forSeconds: 5) wait"
>> a Delay(5000 msecs)
>> 
>> real    0m1.254s
>> user    0m1.192s
>> sys     0m0.060s
>> 
>> 
>> So the first delay doesn't appear to wait the five seconds. I
>> would like to work on kqueue/epoll and remove polling and it
>> looks this involves code with Delay as well. I wonder if you
>> could provide an overview of what needs to be done and what is
>> done?
>> 
>> The pre-requisite issue 14942 is waiting for review. It really should take 
>> only 10 minutes to review... 
>> 1. In latest Pharo 4, inspect "Delay newCodeEnabled" and observe that it is 
>> "true".  
>> 2. Open the Pharo4Inbox and filter on 14942.   
>> 3. Select newest slice and <Merge>.
>> 4. Observe the diff shows all "false" parts removed (it doesn't really get 
>> much simpler than this to review). 
>> 5. Click <merge> to finish.
>> 6. Observe the image continues to run smoothly.
>> 7. Report your observations on https://pharo.fogbugz.com/default.asp?14942 
>> 
>> btw, after the cleanup done by Issue 14942, Issue 14966 can delete ten class 
>> variables from Delay. 
>> When 14942 is integrated, can 14966 be integrated very soon after that.  I 
>> am basing the change of Delay to microsecond delay off 14966.
>> cheers -ben
>> 
>> 
>>  
>> 
>> I need to refresh myself on the fix I did back in 2-Dec.  Its languished 
>> while some support infrastructure was added to help the system ride-through 
>> the change.  
>> 
>> cheers -ben
>> 
>> 
>> 
>> 
>> 
> 


Reply via email to