Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Generators not supported over the network yet #6

Open
boutell opened this issue Nov 8, 2014 · 3 comments
Open

Generators not supported over the network yet #6

boutell opened this issue Nov 8, 2014 · 3 comments

Comments

@boutell
Copy link

boutell commented Nov 8, 2014

I had an idea for a way to make generators work over the network and I couldn't get it out of my head so I wrote some proof of concept code:

https://gist.github.com/boutell/59716a582da7c7f4884b

The basic concept is this: each active generator is represented by an object. The object contains the state of the generator, and also contains a "step" function which can be used to generate the next value.

After that the challenge is to serialize this state over the network. To do that, I add a "source" property which is the source code of "step" as obtained via "toString".

Since "step" never relies on a closure, but rather just manipulates the state object that is passed to it on each call, it is possible to reconstruct both the code and the current state of the generator on the receiving end.

The most daunting challenges not answered here:

  • The second computer will alter the state of the generator; that must be communicated back to the first computer.
  • Each invocation of the generator on either computer should probably result in a network message to the other computer.
  • Timing probably matters a whole heckuva lot, since generators can be invoked on every sixteenth note.

But those things are possible in principle with this hack.

@boutell
Copy link
Author

boutell commented Nov 8, 2014

The other weird thing worth mentioning is that I attach the state of the generator to the generator function as a property. And when I'm ready to send the current state of all generators "over the network," I do so with a JSON.stringify call that takes advantage of the second parameter to spot those functions, which can't go over the network, and replace them with the state object, which can.

@kylestetz
Copy link
Owner

Finally dug into this, thanks for the example!

So the issue turns out to be a little different thanks to a few assumptions we are allowed to make...

This proof of concept relies on one computer producing the sound and all other computers observing and contributing function calls. On all of the slave machines, the call doesn't do anything other than announce itself over the socket.

This is good— we don't have to keep state on any of the slave machines. All they are capable of doing is providing the initial context.

The challenge, then, is in communicating that a particular argument is a generator function (that has its own arguments). Generator functions on the slave machines could be overridden so that all they do is return e.g. (in the case of the step function) 'step(0,1,10)', a string which can be evaled on the master machine.

@boutell
Copy link
Author

boutell commented Dec 23, 2014

That does sound a lot simpler!

On Mon, Dec 22, 2014 at 5:48 PM, Kyle Stetz [email protected]
wrote:

Finally dug into this, thanks for the example!

So the issue turns out to be a little different thanks to a few
assumptions we are allowed to make...

This proof of concept relies on one computer producing the sound and all
other computers observing and contributing function calls. On all of the
slave machines, the call doesn't do anything other than announce itself
over the socket.

This is good— we don't have to keep state on any of the slave machines.
All they are capable of doing is providing the initial context.

The challenge, then, is in communicating that a particular argument is a
generator function (that has its own arguments). Generator functions on the
slave machines could be overridden so that all they do is return e.g. (in
the case of the step function) 'step(0,1,10)', a string which can be evaled
on the master machine.


Reply to this email directly or view it on GitHub
#6 (comment).

*THOMAS BOUTELL, *DEV & OPS
P'UNK AVENUE | (215) 755-1330 | punkave.com

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants