Wedge

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