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

Selectable motion clouds #59

Closed
RoboDoig opened this issue Jun 4, 2024 · 10 comments
Closed

Selectable motion clouds #59

RoboDoig opened this issue Jun 4, 2024 · 10 comments
Labels
Phase3 Issues for the Phase3 milestone

Comments

@RoboDoig
Copy link
Collaborator

RoboDoig commented Jun 4, 2024

Motion cloud textures will be selected from a list that is pre-loaded in TextureResources. Right now one must manually select the BindTexture source for the motion clouds. Would be good if the schema allowed named reference to the motion cloud texture selected on each block.

@ederancz
Copy link
Collaborator

ederancz commented Jul 1, 2024

This is part of the new contract.

@glopesdev glopesdev added the Phase3 Issues for the Phase3 milestone label Jul 11, 2024
@RoboDoig
Copy link
Collaborator Author

Note for me, check ranson-rig implementation for texture loading

@RoboDoig
Copy link
Collaborator Author

A related issue that will fall under this new implementation - currently the workflow assumes a hard-coded number of frames for each motion cloud. This value is used to 'wrap' the motion cloud sequence back around to the start during phase procession. The wrap value should be determined automatically or added as a parameter in the session settings. Ideally automatically.

@RoboDoig
Copy link
Collaborator Author

I've implemented the ability to select motion cloud textures by name in the schema and updated the local version of the Bonsai shaders package to allow automatic wrapping see here for longer term support for this feature.

There is still an error on the first motion cloud that is loaded, I think because I've implemented the GetTextureData operator as a source with the texture name as a parameter, somehow the initialisation order means that it tries to access the texture before the name property is updated.

@RoboDoig
Copy link
Collaborator Author

RoboDoig commented Oct 3, 2024

@EleonoraAmbrad - please see PR #85 for implementation of this. Seems to work but if you have a chance to test on one of your motion cloud experiments that would be great!

@EleonoraAmbrad
Copy link
Collaborator

EleonoraAmbrad commented Oct 14, 2024

Finally got to test this, it's working, but I have a few questions:

  • I failed to load a .png file using Add image texture, does the input need to be a .mp4 file? I am asking because I am struggling really hard to generate an .mp4 file with the image size we need, but it seems to be straightforward with .png format so that would make it easier for me to start --> update: I managed, it was a matter of not setting number of frames to 1

  • the mapping is now limited to 1 screen (might be an artifact from debugging?)

I am also wondering: I will need to display drifting clouds in open loop experiments, can I implement this using the current workflow? I would need to couple the movement of the cloud to a function generator producing a sine wave of different frequencies (mimicking temporal frequencies). Otherwise: will I need to generate the sinewave as csv, similar to what we do for the playback?

Thank you!

@EleonoraAmbrad
Copy link
Collaborator

EleonoraAmbrad commented Oct 15, 2024

Finally got to test this, it's working, but I have a few questions:

  • I failed to load a .png file using Add image texture, does the input need to be a .mp4 file? I am asking because I am struggling really hard to generate an .mp4 file with the image size we need, but it seems to be straightforward with .png format so that would make it easier for me to start -->

update: I managed, it was a matter of not setting number of frames to 1

  • the mapping is now limited to 1 screen (might be an artifact from debugging?)

update:solved, errpr on my side

I am also wondering: I will need to display drifting clouds in open loop experiments, can I implement this using the current workflow? I would need to couple the movement of the cloud to a function generator producing a sine wave of different frequencies (mimicking temporal frequencies). Otherwise: will I need to generate the sinewave as csv, similar to what we do for the playback?

update: just realised that the csv approach might not work because if i produce a sinewave it will not be harp timestamped, so I will probably try to generate a harp timestamped sinewave now

Thank you!

@EleonoraAmbrad
Copy link
Collaborator

sf_0=0.01-B_sf=0.06-theta=0-B_theta=0.25-alpha=0-seed=1

When trying to load this .mp4 file, which has the size we need (2 screens = 3840 frame size), I get an error saying: 'Index was outside the bounds of the array'. The error comes from the node BindTexture, within the DoBlock node. I tried changing the index to the one of the image, but it seems that it is automatically loadd (and therefore it cannot be read).

The file is under Textures, where the others are. Thanks for the help

@RoboDoig
Copy link
Collaborator Author

Issue was that last indexed frame on each block persisted to the next block in BindTexture. If therefore one loads a length 4096 texture and the last frame accessed is 4000; then one loads a length 256 texture the first index that the block will try and access is 4000 and out of bounds of the new texture. Fixed by always initialising new blocks to the 0th index of the texture sequence.

@RoboDoig
Copy link
Collaborator Author

Tested bugfixes, closing issue with #85

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

No branches or pull requests

4 participants