forked from brain-score/vision
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmodel_interface.py
95 lines (78 loc) · 4.35 KB
/
model_interface.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
"""
The :class:`~brainscore.model_interface.BrainModel` interface is the central communication point
between benchmarks and models.
"""
from enum import Enum
from brainio.stimuli import StimulusSet
from typing import List, Tuple, Union
class BrainModel:
"""
The BrainModel interface defines an API for models to follow.
Benchmarks will use this interface to treat models as an experimental subject
without needing to know about the details of the model implementation.
"""
RecordingTarget = Enum('RecordingTarget', " ".join(['V1', 'V2', 'V4', 'IT']))
"""
location to record from
"""
Task = Enum('Task', " ".join(['passive', 'probabilities', 'label']))
"""
task to perform
"""
@property
def identifier(self) -> str:
"""
The unique identifier for this model.
:return: e.g. `'CORnet-S'`, or `'alexnet'`
"""
raise NotImplementedError()
def visual_degrees(self) -> int:
"""
The visual degrees this model covers as a single scalar.
:return: e.g. `8`, or `10`
"""
raise NotImplementedError()
def look_at(self, stimuli: Union[StimulusSet, List[str]], number_of_trials=1):
"""
Digest a set of stimuli and return requested outputs. Which outputs to return is instructed by the
:meth:`~brainscore.model_interface.BrainMode.start_task` and
:meth:`~brainscore.model_interface.BrainModel.start_recording` methods.
:param stimuli: A set of stimuli, passed as either a :class:`~brainio.stimuli.StimulusSet`
or a list of image file paths
:param number_of_trials: The number of repeated trials of the stimuli that the model should average over.
E.g. 10 or 35. Non-stochastic models can likely ignore this parameter.
:return: recordings or task behaviors as instructed
"""
raise NotImplementedError()
def start_task(self, task: Task, fitting_stimuli):
"""
Instructs the model to begin one of the tasks specified in :data:`~brainscore.model_interface.BrainModel.Task`.
For all followings call of :meth:`~brainscore.model_interface.BrainModel.look_at`, the model returns the
expected outputs for the specified task.
:param task: The task the model should perform, and thus which outputs it should return
:param fitting_stimuli: A set of stimuli for the model to learn on, e.g. image-label pairs
"""
raise NotImplementedError()
def start_recording(self, recording_target: RecordingTarget, time_bins=List[Tuple[int]]):
"""
Instructs the model to begin recording in a specified
:data:`~brainscore.model_interface.BrainModel.RecordingTarget` and return the specified `time_bins`.
For all followings call of :meth:`~brainscore.model_interface.BrainModel.look_at`, the model returns the
corresponding recordings. These recordings are a :class:`~brainio.assemblies.NeuroidAssembly` with exactly
3 dimensions:
- `presentation`: the presented stimuli (cf. stimuli argument of
:meth:`~brainscore.model_interface.BrainModel.look_at`). If a :class:`~brainio.stimuli.StimulusSet`
was passed, the recordings should contain all of the :class:`~brainio.stimuli.StimulusSet` columns as
coordinates on this dimension. The `stimulus_id` coordinate is required in either case.
- `neuroid`: the recorded neuroids (neurons or mixtures thereof). They should all be part of the
specified :data:`~brainscore.model_interface.BrainModel.RecordingTarget`. The coordinates of this
dimension should again include as much information as is available, at the very least a `neuroid_id`.
- `time_bins`: the time bins of each recording slice. This dimension should contain at least 2 coordinates:
`time_bin_start` and `time_bin_end`, where one `time_bin` is the bin between start and end.
For instance, a 70-170ms time_bin would be marked as `time_bin_start=70` and `time_bin_end=170`.
If only one time_bin is requested, the model may choose to omit this dimension.
:param recording_target: which location to record from
:param time_bins: which time_bins to record as a list of integer tuples,
e.g. `[(50, 100), (100, 150), (150, 200)]` or `[(70, 170)]`
"""
raise NotImplementedError()