-
Notifications
You must be signed in to change notification settings - Fork 25
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
NeuroMLDBModel current amplitudes that are multiple of rheobase #222
Comments
I think you are using the wrong type of waveform/protocol combination. If you use the logic below you can query the NML-DB server to get appropriate waveforms that are amenable to
long_squares = [ w for w in wlist if w['Protocol_ID'] == 'LONG_SQUARE' ]
#variable_names = [ w["Variable_Name"] for w in wlist if w["Protocol_ID"] == "LONG_SQUARE" ]
applied_current_injections = [ w for w in wlist if w["Protocol_ID"] == "LONG_SQUARE" and w["Variable_Name"] == "Current" ]
#import pdb; pdb.set_trace()
currents = [ w for w in wlist if w["Protocol_ID"] == "LONG_SQUARE" and w["Variable_Name"] == "Voltage" ]
in_current_filter = [ w for w in wlist if w["Protocol_ID"] == "SQUARE" and w["Variable_Name"] == "Voltage" ]
rheobases = []
for wl in long_squares:
wid = wl['ID']
url = str("https://neuroml-db.org/api/waveform?id=")+str(wid)
waves = requests.get(url)
temp = json.loads(waves.text)
if temp['Spikes'] >= 1:
rheobases.append(temp)
if len(rheobases) == 0:
return None
in_current = []
for check in in_current_filter:
amp = get_waveform_current_amplitude(check)
if amp < 0 * pq.nA:
in_current.append(amp)
rheobase_current = get_waveform_current_amplitude(rheobases[0])
druckmann2013_standard_current = get_waveform_current_amplitude(currents[-2])
druckmann2013_strong_current = get_waveform_current_amplitude(currents[-1]) |
@russelljjarvis Justas had pointed me specifically to |
The code I am proposing uses |
@russelljjarvis It does? I see that |
Sorry no, you are right, I used to call those methods indirectly with the three lines below but then I realized that they would re-download waveforms every time a waveform was needed which would slow down the batch process I was designing. Therefore I get the waveforms myself once using code that is very similar, but then I hard assign those waveforms to the model. The functionality is there by I bypassed it, because I needed it to work with a different pre-existing code for querying the NML-DB waveforms.
self.standard = self.model.nmldb_model.get_druckmann2013_standard_current()
self.strong = self.model.nmldb_model.get_druckmann2013_strong_current()
self.ir_currents = self.model.nmldb_model.get_druckmann2013_input_resistance_currents() These lines https://github.com/russelljjarvis/AllenDruckmannData/blob/master/dm_test_interoperable.py#L126-#L128 The code below is acting on a neuroml-db static backend model. Since I am supplying a pre-made model, and if type(model) is type(None):
self.model = model_dict[model_id]
self.model_id = model_id
if self.model_id not in self.predicted:
self.predicted[self.model_id] = [None for i in range(38)] # There are 38 tests
self.standard = self.model.nmldb_model.get_druckmann2013_standard_current()
self.strong = self.model.nmldb_model.get_druckmann2013_strong_current()
self.ir_currents = self.model.nmldb_model.get_druckmann2013_input_resistance_currents()
else:
self.model = model
self.standard = model.druckmann2013_standard_current
self.strong = model.druckmann2013_strong_current
self.ir_currents = model.druckmann2013_input_resistance_currents https://github.com/russelljjarvis/AllenEFELDruckmanData/blob/master/neuromldb.py#L109 What I should have said instead is if these lines of code are executed instead: self.standard = self.model.nmldb_model.get_druckmann2013_standard_current()
self.strong = self.model.nmldb_model.get_druckmann2013_strong_current()
self.ir_currents = self.model.nmldb_model.get_druckmann2013_input_resistance_currents() They properly set up the neuroml-db static model class in a way, that makes it able to call It's a bit complicated to understand, but when I call get_waveform_by_current. I am still adding currents to the models lookup table, because the last thing that happens is that method is this call: return self.fetch_waveform_as_AnalogSignal(w["ID"]) |
def not_necessary_for_program_completion(DMTNMLO):
current = DMTNMLO.model.nmldb_model.get_druckmann2013_standard_current()
DMTNMLO.model.nmldb_model.get_waveform_by_current(current)
temp0 = np.mean(DMTNMLO.model.nmldb_model.get_waveform_by_current(DMTNMLO.model.nmldb_model.get_druckmann2013_strong_current()))
temp1 = np.mean(DMTNMLO.model.nmldb_model.get_waveform_by_current(DMTNMLO.model.nmldb_model.get_druckmann2013_standard_current()))
assert temp0 != temp1
return
_ = not_necessary_for_program_completion(DMTNMLO) This code works as an example. |
It looks like I really need to add more documentation on the API. I'll work on that when I find spare moments. For the question:
In this line: neuronunit/neuronunit/neuromldb.py Line 38 in 1c0e4b2
the For cell models, that |
@JustasB
The code for loading waveforms by current amplitude has the following problem:
leads to:
Currents that are expressed as a multiple of rheobase will need their own handling. Is the rheobase stored somewhere in the class or elsewhere in the database? If so, I can add a conversion from "NUMxRB" to the true value.
The text was updated successfully, but these errors were encountered: