Attention
To run locally, the code for these interactive demos requires a Jupyter Notebook environment, and the Panel extension.
Dipole#
stimupy.components.lines.dipole()
import param
class DipoleParams(param.Parameterized):
# Image size parameters
height = param.Integer(default=10, bounds=(1, 20), doc="Height in degrees")
width = param.Integer(default=10, bounds=(1, 20), doc="Width in degrees")
ppd = param.Integer(default=20, bounds=(1, 40), doc="Pixels per degree")
line_length = param.Number(default=3, bounds=(0, 6), step=0.01, doc="")
line_width = param.Number(default=0, bounds=(0, 3), step=0.01, doc="")
line_gap = param.Number(default=0.5, bounds=(0, 3), step=0.01, doc="")
rotation = param.Integer(default=0, bounds=(0, 360), doc="")
intensity_lines = param.Range(default=(0.0, 1.0), bounds=(0, 1), doc="Line intensity range (min, max)")
mask = param.Boolean(default=False, doc="")
def get_stimulus_params(self):
return {
"visual_size": (self.height, self.width),
"ppd": self.ppd,
"line_length": self.line_length,
"line_width": self.line_width,
"line_gap": self.line_gap,
"rotation": self.rotation,
"intensity_lines": self.intensity_lines,
}
from stimupy.components.lines import dipole
from stimupy._docs.display_stimulus import InteractiveStimDisplay
# Create and display the interactive dipole
dipole_params = DipoleParams()
disp = InteractiveStimDisplay(dipole, dipole_params)
disp.layout