-
Notifications
You must be signed in to change notification settings - Fork 132
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
Buzsaki functions for NWB file format #319
base: dev
Are you sure you want to change the base?
Conversation
Hey @DavidTingley, @dlevenstein, @brendonw1, etc. @mpompolas has been contributing to our effort to bring NWB into buzcode. For many labs, we are working with them to build converters into NWB. For the Buzsaki Lab, we are trying to go further, working with your analysis to incorporate it directly with NWB. This will
We are developing/validating NWB for your pipeline in a way so that you can always revert to using the buzcode format, so we are not risking breaking your analysis pipeline. We think at this point we have built the necessary IO functions (analogs to already existing IO functions) so that the buzcode suite can be used on NWB files. At this point, it would be very helpful if you could take a look at these changes and let us know if anything is missing or if you need any more information. This is the first of hopefully many NWB lab integrations, and we are using this experience to learn the best way to do it, so feedback is definitely welcome! |
The converter works in a convenient modular way. Example calls are in YutaMouse41_toNWB.m Added an xml importer since I had trouble with the default from Buzcode
Hi all - would it be better to build this into the the existing I/O files? That way as we continue to develop we don't need to update two sets of load functions. |
I in theory like it being integrated - but it may be a lot of work... I
guess if we start one at a time it's not so bad
…On Mon, Apr 29, 2019 at 2:22 PM Dan Levenstein ***@***.***> wrote:
Hi all - would it be better to build this into the the existing I/O files?
That way as we continue to develop we don't need to update two sets of load
functions.
—
You are receiving this because you were mentioned.
Reply to this email directly, view it on GitHub
<#319 (comment)>,
or mute the thread
<https://github.com/notifications/unsubscribe-auth/AA26WTJDTIPV2G6IPPH22HLPS44IDANCNFSM4HISDDMQ>
.
|
I expect that as we continue to develop, we'll update the buzcode I/O functions and no one will keep the NWB functions up to date. We are already running into this issue with the phy spikes import function, which needs to be incorporated into bz_getSpikes (issues #264 and #261). Happy to merge the pull request, but I have a hard time seeing this as the right approach moving forward... none of us have/are using NWB data for daily analysis and that's the only way any of this stays up to date. IMO A better approach would be to have a file-type switch in a single load function, which pipes to unified formatting step as early as possible before output. |
@dlevenstein and @brendonw1 thanks for taking a look at this and thinking critically about how it will integrate with your workflow. @dlevenstein, your request to integrate this into current IO functions makes sense. I can see how having multiple IO functions might be difficult to maintain. @mpompolas and I will discuss today and get back you you about this. |
@dlevenstein @brendonw1 Let me get back to you after I chat with @bendichter . |
Ok, I'll take care of the merge of both importers and get back to you by next week. My plan is to add a file-type switch, to check if there is a .nwb file present on the basefolder/current folder. If there is, it will give priority to the .nwb info (I assume here that users would convert all the relevant files to a single .nwb file after they are finalized - unless you guys object and prefer the other files to be prioritized). |
Please don't default to nwb. |
Ok, which branch should I use? |
yup - dev is good. Thanks! |
Thank you very much.
…On Wed, May 1, 2019 at 5:12 PM Dan Levenstein ***@***.***> wrote:
yup - dev is good. Thanks!
—
You are receiving this because you were mentioned.
Reply to this email directly, view it on GitHub
<#319 (comment)>,
or mute the thread
<https://github.com/notifications/unsubscribe-auth/AA26WTPK5VVZZBKZ4IHK4ZLPTIBUFANCNFSM4HISDDMQ>
.
|
…s according to standard and non-standard files
Hi all, I also added a folder for example functions to store the YutaMouse41-150903 dataset into an NWB file. Please take a look at the updated functions and let me know if you have any comments. |
I would need some guidance on the detectorinfo.detectionparms field within *events.mat file. Thanks |
This seems great. Can you guys who have been discussing all of this give
some explanation of the imagined workflow? Or how NWB would be used in
this context?
…On Wed, May 22, 2019 at 1:06 AM Konstantinos ***@***.***> wrote:
I would need some guidance on the detectorinfo.detectionparms field within
*events.mat file.
Can someone tell me what fields are mandatory there? (this structure seems
to store a lot of information and is not clear to me how I should proceed
to generalize it).
Thanks
—
You are receiving this because you were mentioned.
Reply to this email directly, view it on GitHub
<#319?email_source=notifications&email_token=AA26WTJWFR3FSO5RJAWTCBLPWTIEPA5CNFSM4HISDDM2YY3PNVWWK3TUL52HS4DFVREXG43VMVBW63LNMVXHJKTDN5WW2ZLOORPWSZGODV55B5A#issuecomment-494653684>,
or mute the thread
<https://github.com/notifications/unsubscribe-auth/AA26WTITNMIM3OWYZOWLZE3PWTIEPANCNFSM4HISDDMQ>
.
|
The NWB format enables the entire lab to use a universal language. You guys have already done a great job at standardizing your formats but as far as I understand there are still differentiations between users. The idea would be for every person to be able to use all other members' data, even if they were saving files in a different format. That said, the scope of NWB goes further than the Buzsaki lab. You will be able to use data from other labs since, as I mentioned before, it would be in the same universal language. I personally have supported NWB integration within Brainstorm as part of the invasive neurophysiology toolbox: Other tools have already been adopting NWB integration, as presented last week at Janelia, so you can potentially use these as well: |
Thanks so much Konstantinos. That sounds about like my understanding
actually of NWB and I love the idea.
I’m wondering though if this community has thoughts on interfacing buzcode
formats w NWB - in terms of pragmatic workflow. I guess I’m assuming we
stick w buzcode for initial analysis and then switch to NWB for sharing
data later.
…On Thu, May 23, 2019 at 8:16 PM Konstantinos ***@***.***> wrote:
The NWB format enables the entire lab to use a universal language. You
guys have already done a great job at standardizing your formats but as far
as I understand there are still differentiations between users. The idea
would be for every person to be able to use all other members' data, even
if they were saving files in a different format.
Of course, attention needs to be put on how people put their files in NWB:
Probably there needs to be a discussion on what is essential to be saved on
an NWB and all datasets are guaranteed to have these specified fields.
That said, the scope of NWB goes further than the Buzsaki lab. You will be
able to use data from other labs since, as I mentioned before, it would be
in the same universal language. I personally have supported NWB integration
within Brainstorm as part of the invasive neurophysiology toolbox:
https://neuroimage.usc.edu/brainstorm/e-phys/Introduction
Other tools have already been adopting NWB integration, as presented last
week at Janelia, so you can potentially use these as well:
https://neurodatawithoutborders.github.io/tools
—
You are receiving this because you were mentioned.
Reply to this email directly, view it on GitHub
<#319?email_source=notifications&email_token=AA26WTPQXPYCH7JHLKZR5J3PW4XVVA5CNFSM4HISDDM2YY3PNVWWK3TUL52HS4DFVREXG43VMVBW63LNMVXHJKTDN5WW2ZLOORPWSZGODWD2GVY#issuecomment-495428439>,
or mute the thread
<https://github.com/notifications/unsubscribe-auth/AA26WTNINABJCT75WTQPXJTPW4XVVANCNFSM4HISDDMQ>
.
|
I can't speak for the NWB community in general, but the way that I have it in my mind, the main purpose of the NWB is to make sure that everybody understands what happened during the acquisition. Every aspect of the experiment is logged in detail within the NWB. Of course you can add processed data on it as well, but the way the processing is done can vary vastly among labs. |
Buzsaki functions converted to work with the NWB file format.
The functions have the same input and produce the same structured outputs.
It is assumed that all the information of a recording has already been converted correctly to a NWB file and the functions get info from the appropriate fields.
Example calls of the functions are at the beginning of each file.
testing_BUZSAKI_NWB_functions_fidelity.m has calls for both existing Buzcode functions and the NWB counterparts that I used for easy comparison.
The functions were tested on this file:
https://drive.google.com/file/d/1ceoaieEpn7NVmU36o-yRTWwJFYjjWdJQ/view
Problem with this dataset:
The .map field in: behavior.events.map takes a long time to compute in this dataset since the trials are long (probably too long) and the default bin_size for the .map is set to 200 - Consider increasing the bin size