Attention
To run locally, the code for these interactive demos requires a Jupyter Notebook environment, and the Panel extension.
Wedge#
stimupy.components.angulars.wedge()
import param
class WedgeParams(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")
rotation = param.Integer(default=0, bounds=(0, 360), doc="Rotation in degrees")
# Wedge geometry parameters
angle = param.Integer(default=45, bounds=(1, 90), doc="Wedge angle in degrees")
radius = param.Number(default=3, bounds=(1, 6), step=0.1, doc="Outer radius in degrees")
inner_radius = param.Number(default=0, bounds=(0, 3), step=0.1, doc="Inner radius in degrees")
# Intensity parameters
intensity_wedge = param.Number(default=0.5, bounds=(0, 1), step=0.01, doc="Wedge intensity")
intensity_background = param.Number(default=0.0, bounds=(0, 1), step=0.01, doc="Background intensity")
# Additional parameters
origin = param.Selector(default="mean", objects=["mean", "corner", "center"], doc="Origin")
add_mask = param.Boolean(default=False, doc="Add mask to visualization")
def get_stimulus_params(self):
return {
"visual_size": (self.height, self.width),
"ppd": self.ppd,
"angle": self.angle,
"radius": self.radius,
"rotation": self.rotation,
"inner_radius": self.inner_radius,
"intensity_wedge": self.intensity_wedge,
"intensity_background": self.intensity_background,
"origin": self.origin,
}
from stimupy.components.angulars import wedge
from stimupy._docs.display_stimulus import InteractiveStimDisplay
# Create and display the interactive wedge
wedge_params = WedgeParams()
disp = InteractiveStimDisplay(wedge, wedge_params)
disp.layout