Skip to content

Latest commit

 

History

History
99 lines (83 loc) · 4.91 KB

c_bar.md

File metadata and controls

99 lines (83 loc) · 4.91 KB
% ************************************************************
% Thi is the stimulus parameter file for retinotopy.
% Please change the parameters below.
% For bar/bard/barf/bari/bardf/barwindows stimuli.
% Programmed by Hiroshi Ban   November 20 2018
% ************************************************************

% "sparam" means "stimulus generation parameters"

%%% stimulus parameters
sparam.fieldSize   = 15; % stimulation field size in deg. circular region with sparam.fieldSize is stimulated.

sparam.ndivsL      = 18;  % number of bar subdivisions along bar's long axis
sparam.ndivsS      = 2;   % number of bar subdivisions along bar's short axis
sparam.width       = 1.5; % bar width in deg
sparam.phase       = 0;   % phase shift in deg, along bar's short axis

% rotation angles in deg, 0 = right horizontal meridian, counter-clockwise.
% when sparam.rotangles(1)=0, the bar emerges at the right hemifield and sweeps
% the visual field leftwards.
%
% following this parameter, stimulus presentation seuence is defined.
% for instance, is sparam.rotangles   = [0,45,90,135,180,225,270,315];,
% the bar sweeps visual field like
% 1. sparam.rotangles(1)=0   : right to left horizontally, then rest for sparam.rest_duration
% 2. sparam.rotangles(2)=45  : upper right to lower left at 45 deg direction, then rest for sparam.rest_duration
% 3. sparam.rotangles(3)=90  : upper to lower vertically, then rest for sparam.rest_duration
% 4. sparam.rotangles(4)=135 : upper left to lower right at 45 deg direction, then rest for sparam.rest_duration
% ...
% ... to sparam.rotangles(end)
sparam.rotangles   = [0,45,90,135,180,225,270,315,0];

sparam.steps       = 16; % steps in sweeping the visual field (from start to end)

sparam.dimratio    = 0.4; % luminance dim ratio for the checker-pattern change detection task

% checkerboard colors, this variable is only for c* stimulus presentation scripts (e.g. cretinotopy)
sparam.colors      = [ 128, 128, 128; % number of colors for compensating flickering checkerboard
                       255,   0,   0; % the first row is background
                         0, 255,   0; % the second to end are patch colors
                       255, 255,   0;
                         0,   0, 255;
                       255,   0, 255;
                         0, 255, 255;
                       255, 255, 255;
                         0,   0,   0;
                       255, 128,   0;
                       128,   0, 255;];

%%% RDS parameters, these are only for d* stimulus presentation scripts (e.g dretinotopy_fixtask)
sparam.RDSdepth = [ -12, 12, 5]; % binocular disparity in arcmins, [min, max, #steps(from min to max)]
sparam.RDSDense=0.5; % dot density in the RDS images to be generated (percentage)
sparam.RDSradius=0.05; % dot radius in deg
sparam.RDScolors=[255,0,128]; % dot colors in the RDS, [color1, color2, background (grayscale)]
sparam.RDSbackground=0; % 1 = with background, 0 = no background
sparam.RDStaskmagnitude=2; % ratio (x2, x3, etc against the sparam.RDSdepth([1,2])) of the depth maginitude in the change-detection task

%%% duration in msec for each cycle & repetitions
sparam.cycle_duration=40000; % msec
sparam.rest_duration =8000; % msec, rest after each cycle, stimulation = cycle_duration-rest_duration
sparam.numRepeats=1;

%%% object-image presentation parameters, only for i* object-image-based retinotopy stimuli (e.g. iretinotopy_fixtask)
sparam.flip_duration=250; % msec
sparam.nimg=120; % number of images to be presented at a frame
sparam.imRatio=[0.2,0.5]; % image magnification ratio, [min, max] (0.0-1.0), the image sizes are randomly selected whithin this range
sparam.imdepth=[-12,12]; % disparities (arcmins) added to the images, effective only in a stereo mode (e.g. shutter, dual, parallel etc)

%%% set number of frames to flip the screen
% Here, I set the number as large as I can to minimize vertical cynching error.
% the final 2 is for 2 times repetitions of flicker
% Set 1 if you want to flip the display at each vertical sync, but not recommended as it uses much CPU power
sparam.waitframes = 60*(sparam.cycle_duration./1000) / sparam.steps / ( (size(sparam.colors,1)-1)*2 );
%sparam.waitframes = Screen('FrameRate',0)*(sparam.cycle_duration./1000) / sparam.steps / ( (size(sparam.colors,1)-1)*2 );

%%% fixation period in msec before/after presenting the target stimuli, integer
% must set a value more than 1 TR for initializing the frame counting.
sparam.initial_fixation_time=[4000,4000];

%%% fixation size & color
sparam.fixtype=1; % 1: circular, 2: rectangular, 3: concentric fixation point
sparam.fixsize=4; % radius in pixels
sparam.fixcolor=[255,255,255];

%%% background color
sparam.bgcolor=sparam.colors(1,:); %[0,0,0];

%%% RGB for background patches
% 1x3 matrices
sparam.patch_color1=[255,255,255];
sparam.patch_color2=[0,0,0];

%%% for converting degree to pixels
run(fullfile(fileparts(mfilename('fullpath')),'sizeparams'));
%sparam.pix_per_cm=57.1429;
%sparam.vdist=65;
%sparam.ipd=6.5;