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

run_conversion fails to add data when in-memory nwbfile is passed. Feature or bug? #1159

Open
h-mayorquin opened this issue Dec 16, 2024 · 2 comments
Labels

Comments

@h-mayorquin
Copy link
Collaborator

h-mayorquin commented Dec 16, 2024

Summary: when using converter.run_conversion and the nwbfile argument is used to pass an in-memory nwbfile then the data from the converter is not added. This sounds like a bug to me but I don't know if this was intended behavior at some point.

What do you think? @pauladkisson @weiglszonja @bendichter @alessandratrapani

The reason for this behavior is found on these lines that only call add_to_nwbfile if no nwbfile is provided.

if no_nwbfile_provided:
self.add_to_nwbfile(nwbfile=nwbfile_out, metadata=metadata, conversion_options=conversion_options)

For a concrete example, see the following:

from neuroconv.tools.testing.mock_interfaces import MockRecordingInterface, MockSortingInterface, MockImagingInterface
from neuroconv import ConverterPipe
from tempfile import TemporaryDirectory



imaging_interface = MockImagingInterface()
recording_interface = MockRecordingInterface()
sorting_interface = MockSortingInterface()

nwbfile = imaging_interface.create_nwbfile()

converter = ConverterPipe(data_interfaces=[recording_interface, sorting_interface])

with TemporaryDirectory() as tmpdir:
    tmp_path = Path(tmpdir)
    nwbfile_path = tmp_path / "test_conversion.nwb"
    converter.run_conversion(nwbfile_path=nwbfile_path, nwbfile=nwbfile)
    
    from pynwb import NWBHDF5IO 
    with NWBHDF5IO(str(nwbfile_path), 'r') as io:
        nwbfile = io.read()
        assert nwbfile.units is not None
        assert len(nwbfile.aquisition) > 1
        

Both assertions fail no matter the order. In other words, neither the recording interface nor sorting interface data are added when calling run conversion.

Relevant: the existence of this behavior is used in our testing here:

nwbfile = converter.create_nwbfile(metadata=metadata, conversion_options=conversion_options)
backend_configuration = converter.get_default_backend_configuration(nwbfile=nwbfile, backend=backend)
converter.run_conversion(
nwbfile_path=nwbfile_path,
nwbfile=nwbfile,
overwrite=True,
metadata=metadata,
backend_configuration=backend_configuration,
conversion_options=conversion_options,
)

Where the test would fail if null behavior were to change as the converter would try to add the data again.

@h-mayorquin h-mayorquin changed the title run_conversion fails to add data when in-memory nwbfile is passed run_conversion fails to add data when in-memory nwbfile is passed. Feature or bug? Dec 16, 2024
@pauladkisson
Copy link
Member

Seems like a bug to me.

@weiglszonja
Copy link
Contributor

I agree with @pauladkisson, the intended behavior should be to write data from the converter and the in-memory nwbfile. Maybe it has something to do with append mode that it was designed this way?

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

No branches or pull requests

3 participants