Forum: GNU Radio Scheduler Question

Posted by Almohanad Fayez (Guest)
on 2013-02-27 07:56
(Received via mailing list)
I've been reading through the code in gnuradio-core/runtime for a few 
days
to understand the internal workings of the gnuradio scheduler.  It seems 
to
me that gnuradio was originally based on a synchronous dataflow (sdf) 
model
of computation and the single thread schedule is an SDF sequential 
runtime
schedule, or a periodic admissible sequential schedule (PASS), and the
thread per block schedule is a parallel SDF scheduler, or a parallel
admissible parallel schedule (PAPS).

Does this sound like an accurate description of the schedulers and
underlying gnuradio model of computation or am I reading too much into 
it?
thanks
Posted by Michael Dickens (Guest)
on 2013-02-27 15:08
(Received via mailing list)
Hi Almohanad - From my (now old) memory of the GR runtime scheduler (STS 
and TBP), I believe you are roughly correct in the technical 
terminology, except that the schedules are not guaranteed to be 
periodic.  They are opportunistic / aperiodic: process as much data as 
"makes sense" given the blocks constraints and how much data is 
available and how much output space is available.  Tom (et.al.) have 
done some work on the TBP scheduler more recently than my memories, so 
maybe they have been tweaked to be truly periodic?

That said, I do not believe either scheduler was created specifically 
with those terms or concepts in mind; I believe the current scheduler(s) 
were programmed as they are because they work well and were original 
creations.  They might have been influenced by reading others works on 
SDF and the like, but I really doubt there was any true intent on 
recreating others works.

Again, these are memories that I believe are correct; but then who 
knows.  I believe Eric Blossom wrote both of the schedulers, and he's no 
longer around on this list to answer more officially (though I 
understand that folks do interact with him in person). - MLD
Posted by Tom Rondeau (Guest)
on 2013-02-27 15:58
(Received via mailing list)
On Wed, Feb 27, 2013 at 9:06 AM, Michael Dickens <mlk@alum.mit.edu> 
wrote:
> Hi Almohanad - From my (now old) memory of the GR runtime scheduler (STS and 
TBP), I believe you are roughly correct in the technical terminology, except that 
the schedules are not guaranteed to be periodic.  They are opportunistic / 
aperiodic: process as much data as "makes sense" given the blocks constraints and 
how much data is available and how much output space is available.  Tom (et.al.) 
have done some work on the TBP scheduler more recently than my memories, so maybe 
they have been tweaked to be truly periodic?
>
> That said, I do not believe either scheduler was created specifically with those 
terms or concepts in mind; I believe the current scheduler(s) were programmed as 
they are because they work well and were original creations.  They might have been 
influenced by reading others works on SDF and the like, but I really doubt there 
was any true intent on recreating others works.
>
> Again, these are memories that I believe are correct; but then who knows.  I 
believe Eric Blossom wrote both of the schedulers, and he's no longer around on 
this list to answer more officially (though I understand that folks do interact 
with him in person). - MLD

Yeah, that about sums it up from my understanding of the history, too.
The single-threaded scheduler was basically a dataflow model and I'm
sure Eric used that concept to inform his design.

When it comes to the TPB scheduler, the task was to make GNU Radio
multi-threaded. So Eric adapted the STS one and rethought how it could
work in parallel with some push-pull concepts about how much data is
available on the input versus how much buffer space is available on
the output. At this point, I'm not sure any strict concepts of
scheduler theory were necessarily adhered to, though it wouldn't
surprise me to learn that it's similar to some standard model(s) of
computation (Eric has a long history in that area, so he would be well
aware of the various concepts, models, and ideas).

Tom
Please log in before posting. Registration is free and takes only a minute.
Existing account (Switch to SSL-encrypted connection)
NEW: Do you have a Google/GoogleMail or Yahoo account? No registration required!
Log in with Google account | Log in with Yahoo account
No account? Register here.