Attention
To run locally, the code for these interactive demos requires a Jupyter Notebook environment, and the Panel extension.
Cross#
stimupy.components.shapes.cross()
import param
class CrossParams(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")
cross_height = param.Integer(default=4, bounds=(1, 8), doc="")
cross_width = param.Integer(default=4, bounds=(1, 8), doc="")
cross_thickness_height = param.Number(default=1.0, bounds=(0.5, 3), step=0.1, doc="")
cross_thickness_width = param.Number(default=1.0, bounds=(0.5, 3), step=0.1, doc="")
cross_arm_ratio1 = param.Number(default=1.0, bounds=(0.1, 5.0), step=0.1, doc="")
cross_arm_ratio2 = param.Number(default=1.0, bounds=(0.1, 5.0), step=0.1, doc="")
rotation = param.Integer(default=0, bounds=(0, 360), doc="")
intensity_cross = param.Number(default=0.5, bounds=(0, 1), step=0.01, doc="")
intensity_background = param.Number(default=0., bounds=(0, 1), step=0.01, doc="")
def get_stimulus_params(self):
return {
"visual_size": (self.height, self.width),
"ppd": self.ppd,
"cross_size": (self.cross_height, self.cross_width),
"cross_thickness": (self.cross_thickness_height, self.cross_thickness_width),
"cross_arm_ratios": (self.cross_arm_ratio1, self.cross_arm_ratio2),
"rotation": self.rotation,
"intensity_cross": self.intensity_cross,
"intensity_background": self.intensity_background,
}
from stimupy.components.shapes import cross
from stimupy._docs.display_stimulus import InteractiveStimDisplay
# Create and display the interactive cross
cross_params = CrossParams()
disp = InteractiveStimDisplay(cross, cross_params)
disp.layout