From b87d55e366a5c02dacf30f89c22a8fe07a466897 Mon Sep 17 00:00:00 2001 From: anilbey Date: Mon, 5 Feb 2024 13:47:02 +0100 Subject: [PATCH] Add default value for segx param, improve docs vcs: #minor (#127) * DOCS: add explanation on segx param * fix code style * add default value of segx to 0.5 --- bluecellulab/cell/core.py | 17 ++++++++++------- 1 file changed, 10 insertions(+), 7 deletions(-) diff --git a/bluecellulab/cell/core.py b/bluecellulab/cell/core.py index 194c0e50..5e536cf9 100644 --- a/bluecellulab/cell/core.py +++ b/bluecellulab/cell/core.py @@ -377,28 +377,31 @@ def add_ais_recording(self, dt: Optional[float] = None) -> None: self.add_recording("self.axonal[1](0.5)._ref_v", dt=dt) def add_voltage_recording( - self, section: "neuron.h.Section", segx: float, dt: Optional[float] = None + self, section: "neuron.h.Section", segx: float = 0.5, dt: Optional[float] = None ) -> None: """Add a voltage recording to a certain section at a given segment (segx). Args: section: Section to record from (Neuron section pointer). - segx: Segment x coordinate. - dt: Recording time step. If not provided, the recording step will default to the simulator's time step. + segx: Segment x coordinate. Specify a value between 0 and 1. + 0 is typically the end closest to the soma, 1 is the distal end. + dt: Recording time step. If not provided, the recording step will + default to the simulator's time step. """ var_name = f"neuron.h.{section.name()}({segx})._ref_v" self.add_recording(var_name, dt) def get_voltage_recording( - self, section: "neuron.h.Section", segx: float + self, section: "neuron.h.Section", segx: float = 0.5 ) -> np.ndarray: """Get a voltage recording for a certain section at a given segment (segx). Args: section: Section to record from (Neuron section pointer). - segx: Segment x coordinate. + segx: Segment x coordinate. Specify a value between 0 and 1. + 0 is typically the end closest to the soma, 1 is the distal end. Returns: A NumPy array containing the voltage recording values. @@ -419,14 +422,14 @@ def add_allsections_voltagerecordings(self): """Add a voltage recording to every section of the cell.""" all_sections = public_hoc_cell(self.cell).all for section in all_sections: - self.add_voltage_recording(section, segx=0.5, dt=self.record_dt) + self.add_voltage_recording(section, dt=self.record_dt) def get_allsections_voltagerecordings(self) -> dict[str, np.ndarray]: """Get all the voltage recordings from all the sections.""" all_section_voltages = {} all_sections = public_hoc_cell(self.cell).all for section in all_sections: - recording = self.get_voltage_recording(section, segx=0.5) + recording = self.get_voltage_recording(section) all_section_voltages[section.name()] = recording return all_section_voltages