Dim arrStim(140), Typecount(3),arrtmp(28) As Integer Dim i, k, flag As Integer Dim bools As Boolean For i = 1 To UBound(arrtmp) If i<21 Then k=1 arrtmp(i)=k Else If i<25 Then k=2 arrtmp(i)=k Else k=3 arrtmp(i)=k End If End If Next For i=1 To 5 Do bools=True RandomizeArray arrtmp,1,UBound(arrtmp) If i<>1 And i<>5 Then If arrtmp(1)=2 Or arrtmp(1)=3 Then If arrtmp(1)=flag Then bools=False Else For k=1 To 27 If arrtmp(k)=2 Or arrtmp(k)=3 Then If arrtmp(k)=arrtmp(k+1) Then bools=False Exit For End If End If Next End If Else For k=1 To 27 If arrtmp(k)=2 Or arrtmp(k)=3 Then If arrtmp(k)=arrtmp(k+1) Then bools=False Exit For End If End If Next End If ElseIf i=1 Then If arrtmp(1)=2 Or arrtmp(1)=3 Or arrtmp(2)=2 Or arrtmp(2)=3 Then bools=False Else For k=1 To 27 If arrtmp(k)=2 Or arrtmp(k)=3 Then If arrtmp(k)=arrtmp(k+1) Then bools=False Exit For End If End If Next End If ElseIf i=5 Then If arrtmp(27)=2 Or arrtmp(27)=3 Or arrtmp(28)=2 Or arrtmp(28)=3 Then bools=False ElseIf arrtmp(1)=2 Or arrtmp(1)=3 Then If arrtmp(1)=flag Then bools=False Else For k=1 To 27 If arrtmp(k)=2 Or arrtmp(k)=3 Then If arrtmp(k)=arrtmp(k+1) Then bools=False Exit For End If End If Next End If Else For k=1 To 27 If arrtmp(k)=2 Or arrtmp(k)=3 Then If arrtmp(k)=arrtmp(k+1) Then bools=False Exit For End If End If Next End If End If Loop Until bools=True For k=1 To 28 arrStim((i-1)*28+k)=arrtmp(k) Next flag=arrtmp(28) Next For i=1 To UBound(arrStim) TrialList.SetNested CStr(i), "list" & arrStim(i) Next TrialList.Reset 要求:有三种实验材料,A材料100个、BC材料各20个。BC不能呈现在首尾的前后两个刺激上。BC同种材料不能重复呈现,BC可以挨着呈现。对A材料不反应,反应位错;对B材料按“f”键进行反应,C材料按“j”键进行反应。实验过程为:注视点800毫秒→刺激界面(无限时间) →反馈界面。设计要求: 1)请用“化整为零+随机打乱判断”法进行设计。 对以上编码进行修改
时间: 2023-12-12 08:04:55 浏览: 31
以下是修改后的代码:
Dim arrStim(140), Typecount(3), arrtmp(28) As Integer
Dim i, k, flag As Integer
Dim bools As Boolean
'设置实验材料
Typecount(1) = 100 'A材料100个
Typecount(2) = 20 'B材料20个
Typecount(3) = 20 'C材料20个
'生成随机序列
For i = 1 To UBound(arrtmp)
If i <= Typecount(2) Then '前20个为B材料
arrtmp(i) = 2
ElseIf i > Typecount(2) And i <= Typecount(2) + Typecount(3) Then '21-40为C材料
arrtmp(i) = 3
Else '41-140为A材料
arrtmp(i) = 1
End If
Next
'打乱随机序列并判断
For i = 1 To 5
Do
bools = True
RandomizeArray arrtmp, 1, UBound(arrtmp)
If i <> 1 And i <> 5 Then '2-4行不能为B或C材料
If arrtmp(1) = 2 Or arrtmp(1) = 3 Then
If arrtmp(1) = flag Then
bools = False
Else
For k = 1 To 27
If arrtmp(k) = 2 Or arrtmp(k) = 3 Then
If arrtmp(k) = arrtmp(k + 1) Then
bools = False
Exit For
End If
End If
Next
End If
Else
For k = 1 To 27
If arrtmp(k) = 2 Or arrtmp(k) = 3 Then
If arrtmp(k) = arrtmp(k + 1) Then
bools = False
Exit For
End If
End If
Next
End If
ElseIf i = 1 Then '第1行不能为B或C材料,第2行也不能为B或C材料
If arrtmp(1) = 2 Or arrtmp(1) = 3 Or arrtmp(2) = 2 Or arrtmp(2) = 3 Then
bools = False
Else
For k = 1 To 27
If arrtmp(k) = 2 Or arrtmp(k) = 3 Then
If arrtmp(k) = arrtmp(k + 1) Then
bools = False
Exit For
End If
End If
Next
End If
ElseIf i = 5 Then '第5行不能为B或C材料,倒数第2行也不能为B或C材料
If arrtmp(27) = 2 Or arrtmp(27) = 3 Or arrtmp(28) = 2 Or arrtmp(28) = 3 Then
bools = False
ElseIf arrtmp(1) = 2 Or arrtmp(1) = 3 Then '第1个刺激不能为B或C材料
If arrtmp(1) = flag Then
bools = False
Else
For k = 1 To 27
If arrtmp(k) = 2 Or arrtmp(k) = 3 Then
If arrtmp(k) = arrtmp(k + 1) Then
bools = False
Exit For
End If
End If
Next
End If
Else
For k = 1 To 27
If arrtmp(k) = 2 Or arrtmp(k) = 3 Then
If arrtmp(k) = arrtmp(k + 1) Then
bools = False
Exit For
End If
End If
Next
End If
End If
Loop Until bools = True
'将随机序列添加到实验材料列表中
For k = 1 To 28
arrStim((i - 1) * 28 + k) = arrtmp(k)
Next
flag = arrtmp(28) '记录上一行最后一个刺激的材料类型
Next
'将实验材料添加到TrialList中
For i = 1 To UBound(arrStim)
TrialList.SetNested CStr(i), "list" & arrStim(i)
Next
TrialList.Reset
相关推荐
![pdf](https://img-home.csdnimg.cn/images/20210720083512.png)
![pdf](https://img-home.csdnimg.cn/images/20210720083512.png)
![pdf](https://img-home.csdnimg.cn/images/20210720083512.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![doc](https://img-home.csdnimg.cn/images/20210720083327.png)
![txt](https://img-home.csdnimg.cn/images/20210720083642.png)
![pdf](https://img-home.csdnimg.cn/images/20210720083512.png)
![7z](https://img-home.csdnimg.cn/images/20210720083312.png)
![zip](https://img-home.csdnimg.cn/images/20210720083736.png)
![7z](https://img-home.csdnimg.cn/images/20210720083312.png)
![zip](https://img-home.csdnimg.cn/images/20210720083736.png)
![7z](https://img-home.csdnimg.cn/images/20210720083312.png)
![docx](https://img-home.csdnimg.cn/images/20210720083331.png)
![rar](https://img-home.csdnimg.cn/images/20210720083606.png)
![rar](https://img-home.csdnimg.cn/images/20210720083606.png)