-
Notifications
You must be signed in to change notification settings - Fork 4
/
runFovea.m
executable file
·169 lines (153 loc) · 5.74 KB
/
runFovea.m
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
% MATLAB script to run CriticalSpacing.m
% Copyright 2015,2016, Denis G. Pelli, [email protected]
% We recommend leaving the boilerplate header alone, and customizing by
% copying lines from the boilerplate to your customized section at the
% bottom and modifying it there. This facilitates comparison of scripts.
%% BOILERPLATE HEADER
clear o
% PROCEDURE
o.easyBoost=0.3; % Increase the log threshold parameter of easy trials by this much.
o.experimenter=''; % Put name here to skip the runtime question.
o.flipScreenHorizontally=0; % Set to 1 when using a mirror.
o.fractionEasyTrials=0;
o.observer=''; % Put name here to skip the runtime question.
o.permissionToChangeResolution=0; % Works for main screen only, due to Psychtoolbox bug.
o.getAlphabetFromDisk=1; % 1 makes the program more portable.
o.secsBeforeSkipCausesGuess=8;
o.takeSnapshot=0; % To illustrate your talk or paper.
o.task='identify';
o.textFont='Arial';
o.textSizeDeg=0.4;
o.thresholdParameter='spacing'; % 'spacing' or 'size'
o.trialsDesired=20; % Number of trials (i.e. responses) for the threshold estimate.
o.viewingDistanceCm=400; % Default for runtime question.
% SOUND & FEEDBACK
o.beepNegativeFeedback=0;
o.beepPositiveFeedback=1;
o.showProgressBar=1;
o.speakEachLetter=1;
o.speakEncouragement=0;
o.speakViewingDistance=0;
o.usePurring=0;
o.useSpeech=1;
% VISUAL STIMULUS
o.durationSec=inf; % duration of display of target and flankers
o.eccentricityXYDeg=[0 0]; % Distance of target from fixation.
% o.fixedSpacingOverSize=0; % Disconnect size & spacing.
o.fixedSpacingOverSize=1.4; % Requests size proportional to spacing, horizontally and vertically.
o.fourFlankers=0;
o.targetSizeIsHeight=nan; % depends on parameter
o.minimumTargetPix=6; % Minimum viewing distance depends soley on this & pixPerCm.
% o.flankingDirection='vertical'; % vertically arranged flankers for single target
o.flankingDirection='horizontal'; % horizontally arranged flankers for single target
% At nonzero eccentricty, choose a flankingDirection that is either
% "radial" or "tangential". At zero eccentricity, the flankingDirection
% must be "horizontal" or "vertical".
o.repeatedTargets=true; % Repeat targets for immunity to fixation errors.
o.maxFixationErrorXYDeg=[3 3]; % Repeat target letters enough to cope with this.
o.practicePresentations=3;
o.setTargetHeightOverWidth=false; % Stretch font to achieve a particular aspect ratio.
o.spacingDeg=nan;
o.targetDeg=nan;
% TARGET FONT
o.targetFont='Pelli';
o.alphabet='123456789';
o.borderLetter='$';
% FIXATION
o.isFixationBlankedNearTarget=1;
o.fixationMarkDeg=inf; % 0, 3, and inf are a typical values.
o.fixationThicknessDeg=0.02;
o.nearPointXYInUnitSquare=[0.5 0.5];
o.markTargetLocation=false; % 1 to mark target location
% QUEST threshold estimation
o.beta=nan;
o.measureBeta=0;
o.pThreshold=nan;
o.tGuess=nan;
o.tGuessSd=nan;
o.useQuest=1; % true(1) or false(0)
% DEBUGGING AIDS
o.frameTheTarget=0;
o.printScreenResolution=0;
o.printSizeAndSpacing=0;
o.showAlphabet=0;
o.showBounds=0;
o.showLineOfLetters=0;
o.speakSizeAndSpacing=0;
o.useFractionOfScreenToDebug=0;
% TO MEASURE BETA
% o.measureBeta=0;
% o.offsetToMeasureBeta=-0.4:0.1:0.2; % offset of t, i.e. log signal intensity
% o.trialsDesired=200;
% TO HELP CHILDREN
% o.fractionEasyTrials=0.2; % 0.2 adds 20% easy trials. 0 adds none.
% o.speakEncouragement=1; % 1 to say "good," "very good," or "nice" after every trial.
%% CUSTOM CODE
% RUN (measure two thresholds, interleaved)
o.useFractionOfScreenToDebug=0.3;
o.nearPointXYInUnitSquare=[0.5 0.5];
o.targetFont='Sloan';
o.alphabet='DHKNORSVZ'; % Sloan alphabet, excluding C
o.borderLetter='X';
% o.repeatedTargets=false;
o.thresholdParameter='spacing';
o.flankingDirection='horizontal'; % horizontally arranged flankers for single target
% At nonzero eccentricty, choose a flankingDirection that is either
% 'radial' or 'tangential'. At zero eccentricity, the flankingDirection
% must be 'horizontal' or 'vertical'.
o.eccentricityXYDeg=[30 0];
o.durationSec=0.2;
o.fourFlankers=0;
o.trialsDesired=40; % Number of trials (i.e. responses) for the threshold estimate.
o.fixationMarkDeg=3; % 0, 3, and inf are a typical values.
% TEST FOVEA
o.targetFont='Pelli';
o.alphabet='123456789';
o.borderLetter='$';
o.flankingDirection='horizontal'; % horizontally arranged flankers for single target
o.nearPointXYInUnitSquare=[0.5 0.5];
o.isFixationBlankedNearTarget=1;
o.fixedSpacingOverSize=1.4; % Requests size proportional to spacing, horizontally and vertically.
o.viewingDistanceCm=300; % Default for runtime question.
o.eccentricityXYDeg=[0 0];
for one=0:1
o.oneFlanker=one;
o=CriticalSpacing(o);
if o.quitExperiment
break;
end
end
% % TEST ALL ECCENTRICITIES
% ori=90; % re straight up.
% o.nearPointXYInUnitSquare=0.5-0.4*[sind(ori) cosd(ori)];
% o.fixedSpacingOverSize=1.4; % Requests size proportional to spacing, horizontally and vertically.
% o.viewingDistanceCm=25; % Default for runtime question.
% for ecc=[3 10 30 60]
% o.viewingDistanceCm=2*round(0.5*25*30/ecc);
% o.viewingDistanceCm=min(60,o.viewingDistanceCm);
% Speak(sprintf('Viewing distance %d centimeters.',o.viewingDistanceCm));
% for one=0:1
% o.oneFlanker=one;
% o.eccentricityXYDeg=ecc*[sind(ori) cosd(ori)];
% o=CriticalSpacing(o);
% if o.quitExperiment
% break;
% end
% end
% if o.quitExperiment
% break;
% end
% end
% TEST ALL MERIDIANS
% ecc=?
% o.oneFlanker=0;
% o.fixedSpacingOverSize=1.4; % Requests size proportional to spacing, horizontally and vertically.
% for i=1:2
% for ori=0:30:360 % re straight up.
% o.nearPointXYInUnitSquare=0.5-0.4*[sind(ori) cosd(ori)];
% o.eccentricityXYDeg=ecc*[cosd(ori) sind(oir)];
% o=CriticalSpacing(o);
% end
% end
% Results are printed in MATLAB's Command Window and saved in the
% CriticalSpacing/data/ folder.