rtPS (Các dịch vụ thăm dò thời gian thực): được thiết kế hỗ trợ các luồng dịch vụ thời gian thực mà tạo ra các gói dữ liệu kích thước thay đổi trên cơ sở định kỳ, như video MPEG.
Dịch vụ cung cấp các cơ hội yêu cầu unicast định kỳ thời gian thực, mà thỏa mãn các nhu cầu thời gian thực của luồng và cho phép SS chỉ ra kích thước cấp phát mong muốn. Dịch vụ này đòi hỏi overhead yêu cầu hơn UGS, nhưng hỗ trợ các kích thước cấp phát thay đổi để tối ưu hiệu quả truyền dữ liệu. BS sẽ cung cấp các cơ hội unicast định kỳ. SS bị cấm sử dụng các cơ hội yêu cầu cạnh tranh đối với kết nối đó. BS có thể đưa ra các cơ hội yêu cầu unicast được quy định bởi dịch vụ này dù là các yêu cầu chu kỳ hiện tại chưa hoàn thành. Điều này dẫn đến SS chỉ sử dụng các cơ hội yêu cầu unicast để đạt được các cơ hội truyền dẫn đường lên (SS vẫn có thể sử dụng các loại burst cấp phát dữ liệu tự nguyện cho truyền dẫn đường lên cũng được).
230 trang |
Chia sẻ: oanh_nt | Lượt xem: 1505 | Lượt tải: 0
Bạn đang xem trước 20 trang tài liệu Đồ án Nghiên cứu về công nghệ không dây WiMax và ứng dụng, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
cture1.ForeColor = &H80000005
Picture1.Line (td + 20, 1)-(td + 20, Picture1.ScaleHeight)
Picture1.ForeColor = &H8000000D
Picture1.Line (td, k)-(td + 10, ds - xu - dr * song_u(Round(x, 2)))
End If
k = ds - xu - dr * song_u(Round(x, 2))
x = Round(x, 2) + f
If td + 10 > Picture1.ScaleWidth Then
check = True
Else
td = td + 10
End If
If (check = True) Then Exit Do
Wend
Loop
k = ds - xp
td = sample
'Ve song EKG tu phai qua trai
Do While (td > 0)
x = 13.09
'Ve song u
While Round(x, 2) >= 12.9
If td Picture1.ScaleWidth Then
Picture1.ForeColor = &H80000005
Picture1.Line (td - 20, 1)-(td - 20, Picture1.ScaleHeight)
Picture1.ForeColor = &H8000000D
Picture1.Line (td, k)-(td - 10, ds - xu - dr * song_u(Round(x, 2)))
End If
k = ds - xu - dr * song_u(Round(x, 2))
x = Round(x, 2) - f
If td - 10 < 0 Then
Exit Sub
Else
td = td - 10
End If
Wend
x = 11.19
'Ve song t
While Round(x, 2) >= 9.8
If td Picture1.ScaleWidth Then
Picture1.ForeColor = &H80000005
Picture1.Line (td - 20, 1)-(td - 20, Picture1.ScaleHeight)
Picture1.ForeColor = &H8000000D
Picture1.Line (td, k)-(td - 10, ds - xt - dr * song_t(Round(x, 2)))
End If
k = ds - xt - dr * song_t(Round(x, 2))
x = Round(x, 2) - f
If td - 10 < 0 Then
Exit Sub
Else
td = td - 10
End If
Wend
x = 8.19
'Ve song s
While Round(x, 2) >= 8.03
If td Picture1.ScaleWidth Then
Picture1.ForeColor = &H80000005
Picture1.Line (td - 20, 1)-(td - 20, Picture1.ScaleHeight)
Picture1.ForeColor = &H8000000D
Picture1.Line (td, k)-(td - 10, ds - xs_v5 - dr * song_s_v5(Round(x, 2)))
End If
k = ds - xs_v5 - dr * song_s_v5(Round(x, 2))
x = x - f
If td - 10 < 0 Then
Exit Sub
Else
td = td - 10
End If
Wend
x = 6.21
'Ve song r
While Round(x, 2) >= 5.8
If td Picture1.ScaleWidth Then
Picture1.ForeColor = &H80000005
Picture1.Line (td - 20, 1)-(td - 20, Picture1.ScaleHeight)
Picture1.ForeColor = &H8000000D
Picture1.Line (td, k)-(td - 10, ds - xqrs - dr * song_qrs(Round(x, 2)))
End If
k = ds - xqrs - dr * song_qrs(Round(x, 2))
x = Round(x, 2) - f
If td - 10 < 0 Then
Exit Sub
Else
td = td - 10
End If
Wend
x = 3.91
'Ve song q
While Round(x, 2) >= 3.5
If td Picture1.ScaleWidth Then
Picture1.ForeColor = &H80000005
Picture1.Line (td - 20, 1)-(td - 20, Picture1.ScaleHeight)
Picture1.ForeColor = &H8000000D
Picture1.Line (td, k)-(td - 10, ds - xq - dr * song_q(Round(x, 2)))
End If
k = ds - xq - dr * song_q(Round(x, 2))
x = Round(x, 2) - f
If td - 10 < 0 Then
Exit Sub
Else
td = td - 10
End If
Wend
x = 1.99
'Ve song p
While Round(x, 2) >= 0.01
If td Picture1.ScaleWidth Then
Picture1.ForeColor = &H80000005
Picture1.Line (td - 20, 1)-(td - 20, Picture1.ScaleHeight)
Picture1.ForeColor = &H8000000D
Picture1.Line (td, k)-(td - 10, ds - dr * song_p(Round(x, 2)))
End If
k = ds - dr * song_p(Round(x, 2))
x = Round(x, 2) - f
If td - 10 < 0 Then
Exit Sub
Else
td = td - 10
End If
Wend
Loop
End Sub
Private Sub draw_ekg_v6(ByVal sample As Integer)
Dim k As Single
Dim x As Single
Dim td As Integer
Dim i As Integer
Dim check As Boolean
k = ds - xp
td = sample
check = False
Picture1.ForeColor = &H80000005
Picture1.Line (10, 1)-(10, Picture1.ScaleHeight)
'Ve song EKG tu trai qua phai
Do While (check = False)
x = 0.01
'Ve song p
While Round(x, 2) < 2
If td 0 Then
Picture1.ForeColor = &H80000005
Picture1.Line (td + 20, 1)-(td + 20, Picture1.ScaleHeight) 'Xoa truoc khi ve
Picture1.ForeColor = &H8000000D
Picture1.Line (td, k)-(td + 10, ds - dr * song_p(Round(x, 2))) 'Ve song
End If
k = ds - dr * song_p(Round(x, 2))
x = Round(x, 2) + f
If td + 10 > Picture1.ScaleWidth Then
check = True
Else
td = td + 10
End If
If (check = True) Then Exit Do
Wend
If (check = True) Then Exit Do
x = 3.5
'Ve song q
While Round(x, 2) < 3.92
If td 0 Then
Picture1.ForeColor = &H80000005
Picture1.Line (td + 20, 1)-(td + 20, Picture1.ScaleHeight)
Picture1.ForeColor = &H8000000D
Picture1.Line (td, k)-(td + 10, ds - xq - dr * song_q(Round(x, 2)))
End If
k = ds - xq - dr * song_q(Round(x, 2))
x = Round(x, 2) + f
If td + 10 > Picture1.ScaleWidth Then
check = True
Else
td = td + 10
End If
If (check = True) Then Exit Do
Wend
If (check = True) Then Exit Do
x = 5.8
'Ve song r
While Round(x, 2) < 6.22
If td 0 Then
Picture1.ForeColor = &H80000005
Picture1.Line (td + 20, 1)-(td + 20, Picture1.ScaleHeight)
Picture1.ForeColor = &H8000000D
Picture1.Line (td, k)-(td + 10, ds - xqrs - dr * song_qrs(Round(x, 2)))
End If
k = ds - xqrs - dr * song_qrs(Round(x, 2))
x = Round(x, 2) + f
If td + 10 > Picture1.ScaleWidth Then
check = True
Else
td = td + 10
End If
If (check = True) Then Exit Do
Wend
If (check = True) Then Exit Do
x = 8.03
'Ve song s
While Round(x, 2) < 8.2
If td 0 Then
Picture1.ForeColor = &H80000005
Picture1.Line (td + 20, 1)-(td + 20, Picture1.ScaleHeight)
Picture1.ForeColor = &H8000000D
Picture1.Line (td, k)-(td + 10, ds - xs_v6 - dr * song_s_v6(Round(x, 2)))
End If
k = ds - xs_v6 - dr * song_s_v6(Round(x, 2))
x = Round(x, 2) + f
If td + 10 > Picture1.ScaleWidth Then
check = True
Else
td = td + 10
End If
If (check = True) Then Exit Do
Wend
If (check = True) Then Exit Do
x = 9.8
'Ve song t
While Round(x, 2) < 11.2
If td 0 Then
Picture1.ForeColor = &H80000005
Picture1.Line (td + 20, 1)-(td + 20, Picture1.ScaleHeight)
Picture1.ForeColor = &H8000000D
Picture1.Line (td, k)-(td + 10, ds - xt - dr * song_t(Round(x, 2)))
End If
k = ds - xt - dr * song_t(Round(x, 2))
x = Round(x, 2) + f
If td + 10 > Picture1.ScaleWidth Then
check = True
Else
td = td + 10
End If
If (check = True) Then Exit Do
Wend
If (check = True) Then Exit Do
x = 12.9
'Ve song u
While Round(x, 2) < 13.1
If td 0 Then
Picture1.ForeColor = &H80000005
Picture1.Line (td + 20, 1)-(td + 20, Picture1.ScaleHeight)
Picture1.ForeColor = &H8000000D
Picture1.Line (td, k)-(td + 10, ds - xu - dr * song_u(Round(x, 2)))
End If
k = ds - xu - dr * song_u(Round(x, 2))
x = Round(x, 2) + f
If td + 10 > Picture1.ScaleWidth Then
check = True
Else
td = td + 10
End If
If (check = True) Then Exit Do
Wend
Loop
k = ds - xp
td = sample
'Ve song EKG tu phai qua trai
Do While (td > 0)
x = 13.09
'Ve song u
While Round(x, 2) >= 12.9
If td Picture1.ScaleWidth Then
Picture1.ForeColor = &H80000005
Picture1.Line (td - 20, 1)-(td - 20, Picture1.ScaleHeight)
Picture1.ForeColor = &H8000000D
Picture1.Line (td, k)-(td - 10, ds - xu - dr * song_u(Round(x, 2)))
End If
k = ds - xu - dr * song_u(Round(x, 2))
x = Round(x, 2) - f
If td - 10 < 0 Then
Exit Sub
Else
td = td - 10
End If
Wend
x = 11.19
'Ve song t
While Round(x, 2) >= 9.8
If td Picture1.ScaleWidth Then
Picture1.ForeColor = &H80000005
Picture1.Line (td - 20, 1)-(td - 20, Picture1.ScaleHeight)
Picture1.ForeColor = &H8000000D
Picture1.Line (td, k)-(td - 10, ds - xt - dr * song_t(Round(x, 2)))
End If
k = ds - xt - dr * song_t(Round(x, 2))
x = Round(x, 2) - f
If td - 10 < 0 Then
Exit Sub
Else
td = td - 10
End If
Wend
x = 8.19
'Ve song s
While Round(x, 2) >= 8.03
If td Picture1.ScaleWidth Then
Picture1.ForeColor = &H80000005
Picture1.Line (td - 20, 1)-(td - 20, Picture1.ScaleHeight)
Picture1.ForeColor = &H8000000D
Picture1.Line (td, k)-(td - 10, ds - xs_v6 - dr * song_s_v6(Round(x, 2)))
End If
k = ds - xs_v6 - dr * song_s_v6(Round(x, 2))
x = x - f
If td - 10 < 0 Then
Exit Sub
Else
td = td - 10
End If
Wend
x = 6.21
'Ve song r
While Round(x, 2) >= 5.8
If td Picture1.ScaleWidth Then
Picture1.ForeColor = &H80000005
Picture1.Line (td - 20, 1)-(td - 20, Picture1.ScaleHeight)
Picture1.ForeColor = &H8000000D
Picture1.Line (td, k)-(td - 10, ds - xqrs - dr * song_qrs(Round(x, 2)))
End If
k = ds - xqrs - dr * song_qrs(Round(x, 2))
x = Round(x, 2) - f
If td - 10 < 0 Then
Exit Sub
Else
td = td - 10
End If
Wend
x = 3.91
'Ve song q
While Round(x, 2) >= 3.5
If td Picture1.ScaleWidth Then
Picture1.ForeColor = &H80000005
Picture1.Line (td - 20, 1)-(td - 20, Picture1.ScaleHeight)
Picture1.ForeColor = &H8000000D
Picture1.Line (td, k)-(td - 10, ds - xq - dr * song_q(Round(x, 2)))
End If
k = ds - xq - dr * song_q(Round(x, 2))
x = Round(x, 2) - f
If td - 10 < 0 Then
Exit Sub
Else
td = td - 10
End If
Wend
x = 1.99
'Ve song p
While Round(x, 2) >= 0.01
If td Picture1.ScaleWidth Then
Picture1.ForeColor = &H80000005
Picture1.Line (td - 20, 1)-(td - 20, Picture1.ScaleHeight)
Picture1.ForeColor = &H8000000D
Picture1.Line (td, k)-(td - 10, ds - dr * song_p(Round(x, 2)))
End If
k = ds - dr * song_p(Round(x, 2))
x = Round(x, 2) - f
If td - 10 < 0 Then
Exit Sub
Else
td = td - 10
End If
Wend
Loop
End Sub
Private Sub draw_ekg_v4(ByVal sample As Integer)
Dim k As Single
Dim x As Single
Dim td As Integer
Dim i As Integer
Dim check As Boolean
k = ds - xp
td = sample
check = False
Picture1.ForeColor = &H80000005
Picture1.Line (td, 1)-(td, Picture1.ScaleHeight)
Picture1.Line (td + 10, 1)-(td + 10, Picture1.ScaleHeight)
Picture1.Line (td - 10, 1)-(td - 10, Picture1.ScaleHeight)
'Ve song EKG tu trai qua phai
Do While (check = False)
x = 1.5
'Ve song q
While Round(x, 2) < 1.9
If td 0 Then
Picture1.ForeColor = &H80000005
Picture1.Line (td + 20, 1)-(td + 20, Picture1.ScaleHeight)
Picture1.ForeColor = &H8000000D
Picture1.Line (td, k)-(td + 10, ds_v4 - xq_v4 - dr * song_q_v4(Round(x, 2)))
End If
k = ds_v4 - xq_v4 - dr * song_q_v4(Round(x, 2))
x = Round(x, 2) + f
If td + 10 > Picture1.ScaleWidth Then
check = True
Else
td = td + 10
End If
If (check = True) Then Exit Do
Wend
If (check = True) Then Exit Do
x = 1.09
'Ve song p
While Round(x, 2) < 1.81
If td 0 Then
Picture1.ForeColor = &H80000005
Picture1.Line (td + 20, 1)-(td + 20, Picture1.ScaleHeight) 'Xoa truoc khi ve
Picture1.ForeColor = &H8000000D
Picture1.Line (td, k)-(td + 10, ds_v4 - dr * song_p(Round(x, 2))) 'Ve song
End If
k = ds_v4 - dr * song_p(Round(x, 2))
x = Round(x, 2) + f
If td + 10 > Picture1.ScaleWidth Then
check = True
Else
td = td + 10
End If
If (check = True) Then Exit Do
Wend
If (check = True) Then Exit Do
x = 3.72
'Ve song q
While Round(x, 2) < 4.1
If td 0 Then
Picture1.ForeColor = &H80000005
Picture1.Line (td + 20, 1)-(td + 20, Picture1.ScaleHeight)
Picture1.ForeColor = &H8000000D
Picture1.Line (td, k)-(td + 10, ds_v4 - xq_v4 - dr * song_q_v4(Round(x, 2)))
End If
k = ds_v4 - xq_v4 - dr * song_q_v4(Round(x, 2))
x = Round(x, 2) + f
If td + 10 > Picture1.ScaleWidth Then
check = True
Else
td = td + 10
End If
If (check = True) Then Exit Do
Wend
If (check = True) Then Exit Do
x = 5.8
'Ve song r
While Round(x, 2) < 6.09
If td 0 Then
Picture1.ForeColor = &H80000005
Picture1.Line (td + 20, 1)-(td + 20, Picture1.ScaleHeight)
Picture1.ForeColor = &H8000000D
Picture1.Line (td, k)-(td + 10, ds_v4 - xqrs_v4 - dr * song_qrs_v4(Round(x, 2)))
End If
k = ds_v4 - xqrs_v4 - dr * song_qrs_v4(Round(x, 2))
x = Round(x, 2) + f
If td + 10 > Picture1.ScaleWidth Then
check = True
Else
td = td + 10
End If
If (check = True) Then Exit Do
Wend
If (check = True) Then Exit Do
x = 8.06
'Ve song s
While Round(x, 2) < 8.4
If td 0 Then
Picture1.ForeColor = &H80000005
Picture1.Line (td + 20, 1)-(td + 20, Picture1.ScaleHeight)
Picture1.ForeColor = &H8000000D
Picture1.Line (td, k)-(td + 10, ds_v4 - xs_v4 - dr * song_s_v4(Round(x, 2)))
End If
k = ds_v4 - xs_v4 - dr * song_s_v4(Round(x, 2))
x = Round(x, 2) + f
If td + 10 > Picture1.ScaleWidth Then
check = True
Else
td = td + 10
End If
If (check = True) Then Exit Do
Wend
If (check = True) Then Exit Do
x = 10.2
'Ve song t
While Round(x, 2) < 11.2
If td 0 Then
Picture1.ForeColor = &H80000005
Picture1.Line (td + 20, 1)-(td + 20, Picture1.ScaleHeight)
Picture1.ForeColor = &H8000000D
Picture1.Line (td, k)-(td + 10, ds_v4 - xt - dr * song_t(Round(x, 2)))
End If
k = ds_v4 - xt - dr * song_t(Round(x, 2))
x = Round(x, 2) + f
If td + 10 > Picture1.ScaleWidth Then
check = True
Else
td = td + 10
End If
If (check = True) Then Exit Do
Wend
If (check = True) Then Exit Do
x = 12.9
'Ve song u
While Round(x, 2) < 13.1
If td 0 Then
Picture1.ForeColor = &H80000005
Picture1.Line (td + 20, 1)-(td + 20, Picture1.ScaleHeight)
Picture1.ForeColor = &H8000000D
Picture1.Line (td, k)-(td + 10, ds_v4 - xu - dr * song_u(Round(x, 2)))
End If
k = ds_v4 - xu - dr * song_u(Round(x, 2))
x = Round(x, 2) + f
If td + 10 > Picture1.ScaleWidth Then
check = True
Else
td = td + 10
End If
If (check = True) Then Exit Do
Wend
Loop
k = ds - xp
td = sample
'Ve song EKG tu phai qua trai
Do While (td > 0)
x = 13.09
'Ve song u
While Round(x, 2) >= 12.9
If td Picture1.ScaleWidth Then
Picture1.ForeColor = &H80000005
Picture1.Line (td - 20, 1)-(td - 20, Picture1.ScaleHeight)
Picture1.ForeColor = &H8000000D
Picture1.Line (td, k)-(td - 10, ds_v4 - xu - dr * song_u(Round(x, 2)))
End If
k = ds_v4 - xu - dr * song_u(Round(x, 2))
x = Round(x, 2) - f
If td - 10 < 0 Then
Exit Sub
Else
td = td - 10
End If
Wend
x = 11.19
'Ve song t
While Round(x, 2) >= 10.2
If td Picture1.ScaleWidth Then
Picture1.ForeColor = &H80000005
Picture1.Line (td - 20, 1)-(td - 20, Picture1.ScaleHeight)
Picture1.ForeColor = &H8000000D
Picture1.Line (td, k)-(td - 10, ds_v4 - xt - dr * song_t(Round(x, 2)))
End If
k = ds_v4 - xt - dr * song_t(Round(x, 2))
x = Round(x, 2) - f
If td - 10 < 0 Then
Exit Sub
Else
td = td - 10
End If
Wend
x = 8.39
'Ve song s
While Round(x, 2) >= 8.06
If td Picture1.ScaleWidth Then
Picture1.ForeColor = &H80000005
Picture1.Line (td - 20, 1)-(td - 20, Picture1.ScaleHeight)
Picture1.ForeColor = &H8000000D
Picture1.Line (td, k)-(td - 10, ds_v4 - xs_v4 - dr * song_s_v4(Round(x, 2)))
End If
k = ds_v4 - xs_v4 - dr * song_s_v4(Round(x, 2))
x = x - f
If td - 10 < 0 Then
Exit Sub
Else
td = td - 10
End If
Wend
x = 6.08
'Ve song r
While Round(x, 2) >= 5.8
If td Picture1.ScaleWidth Then
Picture1.ForeColor = &H80000005
Picture1.Line (td - 20, 1)-(td - 20, Picture1.ScaleHeight)
Picture1.ForeColor = &H8000000D
Picture1.Line (td, k)-(td - 10, ds_v4 - xqrs_v4 - dr * song_qrs_v4(Round(x, 2)))
End If
k = ds_v4 - xqrs_v4 - dr * song_qrs_v4(Round(x, 2))
x = Round(x, 2) - f
If td - 10 < 0 Then
Exit Sub
Else
td = td - 10
End If
Wend
x = 4.09
'Ve song q
While Round(x, 2) >= 3.72
If td Picture1.ScaleWidth Then
Picture1.ForeColor = &H80000005
Picture1.Line (td - 20, 1)-(td - 20, Picture1.ScaleHeight)
Picture1.ForeColor = &H8000000D
Picture1.Line (td, k)-(td - 10, ds_v4 - xq_v4 - dr * song_q_v4(Round(x, 2)))
End If
k = ds_v4 - xq_v4 - dr * song_q_v4(Round(x, 2))
x = Round(x, 2) - f
If td - 10 < 0 Then
Exit Sub
Else
td = td - 10
End If
Wend
x = 1.8
'Ve song p
While Round(x, 2) >= 1.09
If td Picture1.ScaleWidth Then
Picture1.ForeColor = &H80000005
Picture1.Line (td - 20, 1)-(td - 20, Picture1.ScaleHeight)
Picture1.ForeColor = &H8000000D
Picture1.Line (td, k)-(td - 10, ds_v4 - dr * song_p(Round(x, 2)))
End If
k = ds_v4 - dr * song_p(Round(x, 2))
x = Round(x, 2) - f
If td - 10 < 0 Then
Exit Sub
Else
td = td - 10
End If
Wend
x = 1.89
'Ve song q
While Round(x, 2) >= 1.5
If td Picture1.ScaleWidth Then
Picture1.ForeColor = &H80000005
Picture1.Line (td - 20, 1)-(td - 20, Picture1.ScaleHeight)
Picture1.ForeColor = &H8000000D
Picture1.Line (td, k)-(td - 10, ds_v4 - xq_v4 - dr * song_q_v4(Round(x, 2)))
End If
k = ds_v4 - xq_v4 - dr * song_q_v4(Round(x, 2))
x = Round(x, 2) - f
If td - 10 < 0 Then
Exit Sub
Else
td = td - 10
End If
Wend
Loop
End Sub
Private Sub draw_ekg_v3(ByVal sample As Integer)
Dim k As Single
Dim x As Single
Dim td As Integer
Dim i As Integer
Dim check As Boolean
k = ds_v3 - xp_v3
td = sample
check = False
Picture1.ForeColor = &H80000005
Picture1.Line (10, 1)-(10, Picture1.ScaleHeight)
'Ve song EKG tu trai qua phai
Do While (check = False)
x = 1.55
'Ve song p
While Round(x, 2) < 2.1
If td 0 Then
Picture1.ForeColor = &H80000005
Picture1.Line (td + 20, 1)-(td + 20, Picture1.ScaleHeight) 'Xoa truoc khi ve
Picture1.ForeColor = &H8000000D
Picture1.Line (td, k)-(td + 10, ds_v3 - dr * song_p_v3(Round(x, 2))) 'Ve song
End If
k = ds_v3 - dr * song_p_v3(Round(x, 2))
x = Round(x, 2) + f
If td + 10 > Picture1.ScaleWidth Then
check = True
Else
td = td + 10
End If
If (check = True) Then Exit Do
Wend
If (check = True) Then Exit Do
x = 3.7
'Ve song q
While Round(x, 2) < 3.91
If td 0 Then
Picture1.ForeColor = &H80000005
Picture1.Line (td + 20, 1)-(td + 20, Picture1.ScaleHeight)
Picture1.ForeColor = &H8000000D
Picture1.Line (td, k)-(td + 10, ds_v3 - xq_v3 - dr * song_q_v3(Round(x, 2)))
End If
k = ds_v3 - xq_v3 - dr * song_q_v3(Round(x, 2))
x = Round(x, 2) + f
If td + 10 > Picture1.ScaleWidth Then
check = True
Else
td = td + 10
End If
If (check = True) Then Exit Do
Wend
If (check = True) Then Exit Do
x = 5.98
'Ve song r
While Round(x, 2) < 6.06
If td 0 Then
Picture1.ForeColor = &H80000005
Picture1.Line (td + 20, 1)-(td + 20, Picture1.ScaleHeight)
Picture1.ForeColor = &H8000000D
Picture1.Line (td, k)-(td + 10, ds_v3 - xqrs_v3 - dr * song_qrs_v3(Round(x, 2)))
End If
k = ds_v3 - xqrs_v3 - dr * song_qrs_v3(Round(x, 2))
x = Round(x, 2) + f
If td + 10 > Picture1.ScaleWidth Then
check = True
Else
td = td + 10
End If
If (check = True) Then Exit Do
Wend
If (check = True) Then Exit Do
x = 8.02
'Ve song s
While Round(x, 2) < 8.3
If td 0 Then
Picture1.ForeColor = &H80000005
Picture1.Line (td + 20, 1)-(td + 20, Picture1.ScaleHeight)
Picture1.ForeColor = &H8000000D
Picture1.Line (td, k)-(td + 10, ds_v3 - xs_v3 - dr * song_s_v3(Round(x, 2)))
End If
k = ds_v3 - xs_v3 - dr * song_s_v3(Round(x, 2))
x = Round(x, 2) + f
If td + 10 > Picture1.ScaleWidth Then
check = True
Else
td = td + 10
End If
If (check = True) Then Exit Do
Wend
If (check = True) Then Exit Do
x = 10.17
'Ve song t
While Round(x, 2) < 10.6
If td 0 Then
Picture1.ForeColor = &H80000005
Picture1.Line (td + 20, 1)-(td + 20, Picture1.ScaleHeight)
Picture1.ForeColor = &H8000000D
Picture1.Line (td, k)-(td + 10, ds_v3 - xt_v3 - dr * song_t_v3(Round(x, 2)))
End If
k = ds_v3 - xt_v3 - dr * song_t_v3(Round(x, 2))
x = Round(x, 2) + f
If td + 10 > Picture1.ScaleWidth Then
check = True
Else
td = td + 10
End If
If (check = True) Then Exit Do
Wend
If (check = True) Then Exit Do
x = 12.35
'Ve song u
While Round(x, 2) < 12.65
If td 0 Then
Picture1.ForeColor = &H80000005
Picture1.Line (td + 20, 1)-(td + 20, Picture1.ScaleHeight)
Picture1.ForeColor = &H8000000D
Picture1.Line (td, k)-(td + 10, ds_v3 - xu_v3 - dr * song_u_v3(Round(x, 2)))
End If
k = ds_v3 - xu_v3 - dr * song_u_v3(Round(x, 2))
x = Round(x, 2) + f
If td + 10 > Picture1.ScaleWidth Then
check = True
Else
td = td + 10
End If
If (check = True) Then Exit Do
Wend
Loop
k = ds_v3 - xp_v3
td = sample
'Ve song EKG tu phai qua trai
Do While (td > 0)
x = 12.64
'Ve song u
While Round(x, 2) >= 12.35
If td Picture1.ScaleWidth Then
Picture1.ForeColor = &H80000005
Picture1.Line (td - 20, 1)-(td - 20, Picture1.ScaleHeight)
Picture1.ForeColor = &H8000000D
Picture1.Line (td, k)-(td - 10, ds_v3 - xu_v3 - dr * song_u_v3(Round(x, 2)))
End If
k = ds_v3 - xu_v3 - dr * song_u_v3(Round(x, 2))
x = Round(x, 2) - f
If td - 10 < 0 Then
Exit Sub
Else
td = td - 10
End If
Wend
x = 10.5
'Ve song t
While Round(x, 2) >= 10.17
If td Picture1.ScaleWidth Then
Picture1.ForeColor = &H80000005
Picture1.Line (td - 20, 1)-(td - 20, Picture1.ScaleHeight)
Picture1.ForeColor = &H8000000D
Picture1.Line (td, k)-(td - 10, ds_v3 - xt_v3 - dr * song_t_v3(Round(x, 2)))
End If
k = ds_v3 - xt_v3 - dr * song_t_v3(Round(x, 2))
x = Round(x, 2) - f
If td - 10 < 0 Then
Exit Sub
Else
td = td - 10
End If
Wend
x = 8.29
'Ve song s
While Round(x, 2) >= 8.02
If td Picture1.ScaleWidth Then
Picture1.ForeColor = &H80000005
Picture1.Line (td - 20, 1)-(td - 20, Picture1.ScaleHeight)
Picture1.ForeColor = &H8000000D
Picture1.Line (td, k)-(td - 10, ds_v3 - xs_v3 - dr * song_s_v3(Round(x, 2)))
End If
k = ds_v3 - xs_v3 - dr * song_s_v3(Round(x, 2))
x = x - f
If td - 10 < 0 Then
Exit Sub
Else
td = td - 10
End If
Wend
x = 6.06
'Ve song r
While Round(x, 2) >= 5.98
If td Picture1.ScaleWidth Then
Picture1.ForeColor = &H80000005
Picture1.Line (td - 20, 1)-(td - 20, Picture1.ScaleHeight)
Picture1.ForeColor = &H8000000D
Picture1.Line (td, k)-(td - 10, ds_v3 - xqrs_v3 - dr * song_qrs_v3(Round(x, 2)))
End If
k = ds_v3 - xqrs_v3 - dr * song_qrs_v3(Round(x, 2))
x = Round(x, 2) - f
If td - 10 < 0 Then
Exit Sub
Else
td = td - 10
End If
Wend
x = 3.9
'Ve song q
While Round(x, 2) >= 3.7
If td Picture1.ScaleWidth Then
Picture1.ForeColor = &H80000005
Picture1.Line (td - 20, 1)-(td - 20, Picture1.ScaleHeight)
Picture1.ForeColor = &H8000000D
Picture1.Line (td, k)-(td - 10, ds_v3 - xq_v3 - dr * song_q_v3(Round(x, 2)))
End If
k = ds_v3 - xq_v3 - dr * song_q_v3(Round(x, 2))
x = Round(x, 2) - f
If td - 10 < 0 Then
Exit Sub
Else
td = td - 10
End If
Wend
x = 2.19
'Ve song p
While Round(x, 2) >= 1.55
If td Picture1.ScaleWidth Then
Picture1.ForeColor = &H80000005
Picture1.Line (td - 20, 1)-(td - 20, Picture1.ScaleHeight)
Picture1.ForeColor = &H8000000D
Picture1.Line (td, k)-(td - 10, ds_v3 - dr * song_p_v3(Round(x, 2)))
End If
k = ds_v3 - dr * song_p_v3(Round(x, 2))
x = Round(x, 2) - f
If td - 10 < 0 Then
Exit Sub
Else
td = td - 10
End If
Wend
Loop
End Sub
Private Sub draw_ekg_v1(ByVal sample As Integer)
Dim k As Single
Dim x As Single
Dim td As Integer
Dim i As Integer
Dim check As Boolean
k = ds_v1 - xp_v1
td = sample
check = False
Picture1.ForeColor = &H80000005
Picture1.Line (td + 10, 1)-(td + 10, Picture1.ScaleHeight)
'Ve song EKG tu trai qua phai
Do While (check = False)
x = 1.55
'Ve song p
While Round(x, 2) < 2.1
If td 0 Then
Picture1.ForeColor = &H80000005
Picture1.Line (td + 20, 1)-(td + 20, Picture1.ScaleHeight) 'Xoa truoc khi ve
Picture1.ForeColor = &H8000000D
Picture1.Line (td, k)-(td + 10, ds_v1 - dr * song_p_v1(Round(x, 2))) 'Ve song
End If
k = ds_v1 - dr * song_p_v1(Round(x, 2))
x = Round(x, 2) + f
If td + 10 > Picture1.ScaleWidth Then
check = True
Else
td = td + 10
End If
If (check = True) Then Exit Do
Wend
If (check = True) Then Exit Do
x = 3.7
'Ve song q
While Round(x, 2) < 3.91
If td 0 Then
Picture1.ForeColor = &H80000005
Picture1.Line (td + 20, 1)-(td + 20, Picture1.ScaleHeight)
Picture1.ForeColor = &H8000000D
Picture1.Line (td, k)-(td + 10, ds_v1 - xq_v1 - dr * song_q_v1(Round(x, 2)))
End If
k = ds_v1 - xq_v1 - dr * song_q_v1(Round(x, 2))
x = Round(x, 2) + f
If td + 10 > Picture1.ScaleWidth Then
check = True
Else
td = td + 10
End If
If (check = True) Then Exit Do
Wend
If (check = True) Then Exit Do
x = 5.96
'Ve song r
While Round(x, 2) < 6.1
If td 0 Then
Picture1.ForeColor = &H80000005
Picture1.Line (td + 20, 1)-(td + 20, Picture1.ScaleHeight)
Picture1.ForeColor = &H8000000D
Picture1.Line (td, k)-(td + 10, ds_v1 - xqrs_v1 - dr * song_qrs_v1(Round(x, 2)))
End If
k = ds_v1 - xqrs_v1 - dr * song_qrs_v1(Round(x, 2))
x = Round(x, 2) + f
If td + 10 > Picture1.ScaleWidth Then
check = True
Else
td = td + 10
End If
If (check = True) Then Exit Do
Wend
If (check = True) Then Exit Do
x = 8.02
'Ve song s
While Round(x, 2) < 8.3
If td 0 Then
Picture1.ForeColor = &H80000005
Picture1.Line (td + 20, 1)-(td + 20, Picture1.ScaleHeight)
Picture1.ForeColor = &H8000000D
Picture1.Line (td, k)-(td + 10, ds_v1 - xs_v1 - dr * song_s_v1(Round(x, 2)))
End If
k = ds_v1 - xs_v1 - dr * song_s_v1(Round(x, 2))
x = Round(x, 2) + f
If td + 10 > Picture1.ScaleWidth Then
check = True
Else
td = td + 10
End If
If (check = True) Then Exit Do
Wend
If (check = True) Then Exit Do
x = 10.17
'Ve song t
While Round(x, 2) < 10.6
If td 0 Then
Picture1.ForeColor = &H80000005
Picture1.Line (td + 20, 1)-(td + 20, Picture1.ScaleHeight)
Picture1.ForeColor = &H8000000D
Picture1.Line (td, k)-(td + 10, ds_v1 - xt_v1 - dr * song_t_v1(Round(x, 2)))
End If
k = ds_v1 - xt_v1 - dr * song_t_v1(Round(x, 2))
x = Round(x, 2) + f
If td + 10 > Picture1.ScaleWidth Then
check = True
Else
td = td + 10
End If
If (check = True) Then Exit Do
Wend
If (check = True) Then Exit Do
x = 12.35
'Ve song u
While Round(x, 2) < 12.65
If td 0 Then
Picture1.ForeColor = &H80000005
Picture1.Line (td + 20, 1)-(td + 20, Picture1.ScaleHeight)
Picture1.ForeColor = &H8000000D
Picture1.Line (td, k)-(td + 10, ds_v1 - xu_v1 - dr * song_u_v1(Round(x, 2)))
End If
k = ds_v1 - xu_v1 - dr * song_u_v1(Round(x, 2))
x = Round(x, 2) + f
If td + 10 > Picture1.ScaleWidth Then
check = True
Else
td = td + 10
End If
If (check = True) Then Exit Do
Wend
Loop
k = ds_v1 - xp_v1
td = sample
'Ve song EKG tu phai qua trai
Do While (td > 0)
x = 12.64
'Ve song u
While Round(x, 2) >= 12.35
If td Picture1.ScaleWidth Then
Picture1.ForeColor = &H80000005
Picture1.Line (td - 20, 1)-(td - 20, Picture1.ScaleHeight)
Picture1.ForeColor = &H8000000D
Picture1.Line (td, k)-(td - 10, ds_v1 - xu_v1 - dr * song_u_v1(Round(x, 2)))
End If
k = ds_v1 - xu_v1 - dr * song_u_v1(Round(x, 2))
x = Round(x, 2) - f
If td - 10 < 0 Then
Exit Sub
Else
td = td - 10
End If
Wend
x = 10.5
'Ve song t
While Round(x, 2) >= 10.17
If td Picture1.ScaleWidth Then
Picture1.ForeColor = &H80000005
Picture1.Line (td - 20, 1)-(td - 20, Picture1.ScaleHeight)
Picture1.ForeColor = &H8000000D
Picture1.Line (td, k)-(td - 10, ds_v1 - xt_v1 - dr * song_t_v1(Round(x, 2)))
End If
k = ds_v1 - xt_v1 - dr * song_t_v1(Round(x, 2))
x = Round(x, 2) - f
If td - 10 < 0 Then
Exit Sub
Else
td = td - 10
End If
Wend
x = 8.3
'Ve song s
While Round(x, 2) >= 8.02
If td Picture1.ScaleWidth Then
Picture1.ForeColor = &H80000005
Picture1.Line (td - 20, 1)-(td - 20, Picture1.ScaleHeight)
Picture1.ForeColor = &H8000000D
Picture1.Line (td, k)-(td - 10, ds_v1 - xs_v1 - dr * song_s_v1(Round(x, 2)))
End If
k = ds_v1 - xs_v1 - dr * song_s_v1(Round(x, 2))
x = x - f
If td - 10 < 0 Then
Exit Sub
Else
td = td - 10
End If
Wend
x = 6.1
'Ve song r
While Round(x, 2) >= 5.96
If td Picture1.ScaleWidth Then
Picture1.ForeColor = &H80000005
Picture1.Line (td - 20, 1)-(td - 20, Picture1.ScaleHeight)
Picture1.ForeColor = &H8000000D
Picture1.Line (td, k)-(td - 10, ds_v1 - xqrs_v1 - dr * song_qrs_v1(Round(x, 2)))
End If
k = ds_v1 - xqrs_v1 - dr * song_qrs_v1(Round(x, 2))
x = Round(x, 2) - f
If td - 10 < 0 Then
Exit Sub
Else
td = td - 10
End If
Wend
x = 3.9
'Ve song q
While Round(x, 2) >= 3.7
If td Picture1.ScaleWidth Then
Picture1.ForeColor = &H80000005
Picture1.Line (td - 20, 1)-(td - 20, Picture1.ScaleHeight)
Picture1.ForeColor = &H8000000D
Picture1.Line (td, k)-(td - 10, ds_v1 - xq_v1 - dr * song_q_v1(Round(x, 2)))
End If
k = ds_v1 - xq_v1 - dr * song_q_v1(Round(x, 2))
x = Round(x, 2) - f
If td - 10 < 0 Then
Exit Sub
Else
td = td - 10
End If
Wend
x = 2.19
'Ve song p
While Round(x, 2) >= 1.55
If td Picture1.ScaleWidth Then
Picture1.ForeColor = &H80000005
Picture1.Line (td - 20, 1)-(td - 20, Picture1.ScaleHeight)
Picture1.ForeColor = &H8000000D
Picture1.Line (td, k)-(td - 10, ds_v1 - dr * song_p_v1(Round(x, 2)))
End If
k = ds_v1 - dr * song_p_v1(Round(x, 2))
x = Round(x, 2) - f
If td - 10 < 0 Then
Exit Sub
Else
td = td - 10
End If
Wend
Loop
End Sub
Private Sub Command1_Click()
Unload Me
End Sub
Private Sub Command2_Click()
If val_speed > 0 Then
val_speed = val_speed - 1
Text5.Text = val_speed * 10 + 10 & " mm/s"
Timer1.Interval = val_speed * 20 + 1
End If
End Sub
Private Sub Command7_Click()
If val_speed < 4 Then
val_speed = val_speed + 1
Text5.Text = val_speed * 10 + 10 & " mm/s"
Timer1.Interval = val_speed * 20 + 1
End If
End Sub
Private Sub Command4_Click()
If f_nt < 0.07 Then
f_nt = f_nt + 0.01
cal_td_nt = calculate_td_nt
Text3.Text = Round(f_nt * 100 - 3) * 10
End If
End Sub
Private Sub Command5_Click()
If f_nt > 0.05 Then
f_nt = f_nt - 0.01
cal_td_nt = calculate_td_nt
Text3.Text = Round(f_nt * 100 - 3) * 10
End If
End Sub
Private Sub Command6_Click()
If Combo1.Text = " I" Then
Combo1.Text = "II"
ElseIf Combo1.Text = "II" Then
Combo1.Text = "III"
ElseIf Combo1.Text = "III" Then
Combo1.Text = "V1"
ElseIf Combo1.Text = "V1" Then
Combo1.Text = "V2"
ElseIf Combo1.Text = "V2" Then
Combo1.Text = "V3"
ElseIf Combo1.Text = "V3" Then
Combo1.Text = "V4"
ElseIf Combo1.Text = "V4" Then
Combo1.Text = "V5"
ElseIf Combo1.Text = "V5" Then
Combo1.Text = "V6"
ElseIf Combo1.Text = "V6" Then
Combo1.Text = "aVF"
ElseIf Combo1.Text = "aVF" Then
Combo1.Text = "aVL"
ElseIf Combo1.Text = "aVL" Then
Combo1.Text = "aVR"
Else
Combo1.Text = " I"
End If
End Sub
Private Sub Form_Load()
dr = 1500
f_nt = 0.06
val_speed = 2
Combo1.AddItem " I"
Combo1.AddItem "II"
Combo1.AddItem "III"
Combo1.AddItem "V1"
Combo1.AddItem "V2"
Combo1.AddItem "V3"
Combo1.AddItem "V4"
Combo1.AddItem "V5"
Combo1.AddItem "V6"
Combo1.AddItem "aVF"
Combo1.AddItem "aVL"
Combo1.AddItem "aVR"
Combo1.Text = " I"
change
End Sub
Private Sub change()
cal_td = calculate_td
cal_td_v = calculate_td_v
cal_td_nt = calculate_td_nt
cal_td_aVF = calculate_td_aVF
cal_td_aVL = calculate_td_aVL
cal_td_aVR = calculate_td_aVR
cal_td_i = calculate_td_i
cal_td_iii = calculate_td_iii
cal_td_v5 = calculate_td_v5
cal_td_v4 = calculate_td_v4
cal_td_v3 = calculate_td_v3
cal_td_v1 = calculate_td_v1
xp = dr * song_p(0.01)
xq = xp - dr * song_q(3.5)
xqrs = xp - dr * song_qrs(5)
xs = xp - dr * song_s(7.5)
xt = xp - dr * song_t(9.5)
xu = xp - dr * song_u(12)
xp_v3 = dr * song_p_v3(1.2)
xq_v3 = xp_v3 - dr * song_q_v3(3.5)
xqrs_v3 = xp_v3 - dr * song_qrs_v3(5)
xs_v3 = xp_v3 - dr * song_s_v3(7.5)
xt_v3 = xp_v3 - dr * song_t_v3(9.5)
xu_v3 = xp_v3 - dr * song_u_v3(12)
xp_v1 = dr * song_p_v1(1.2)
xq_v1 = xp_v1 - dr * song_q_v1(3.5)
xqrs_v1 = xp_v1 - dr * song_qrs_v1(5.5)
xs_v1 = xp_v1 - dr * song_s_v1(7.5)
xt_v1 = xp_v1 - dr * song_t_v1(9.5)
xu_v1 = xp_v1 - dr * song_u_v1(12)
xs_aVF = xp - dr * song_s_aVF(3.3)
xs_aVL = xp - dr * song_s_aVL(8.4)
xs_i = xp - dr * song_s_i(7.5)
xs_v5 = xp - dr * song_s_v5(7.5)
xs_v6 = xp - dr * song_s_v6(7.5)
xq_v4 = xp - dr * song_q_v4(3)
xqrs_v4 = xp - dr * song_qrs_v4(5.5)
xs_v4 = xp - dr * song_s_v4(7.5)
xp_aVR = dr * song_p_aVR(0.8)
xq_aVR = xp_aVR - dr * song_q_aVR(3.5)
xs_aVR = xp_aVR - dr * song_s_aVR(5.5)
xt_aVR = xp_aVR - dr * song_t_aVR(10)
xu_aVR = xp_aVR - dr * song_u_aVR(12)
xp_iii = dr * song_p_iii(1.2)
xq_iii = xp_iii - dr * song_q_iii(3.5)
xqrs_iii = xp_iii - dr * song_qrs_iii(5.5)
xs_iii = xp_iii - dr * song_s_iii(8.5)
xt_iii = xp_iii - dr * song_t_iii(10)
xp_v = dr * song_p_v(1.65)
xq_v = xp_v - dr * song_q(3.5)
xqrs_v = xp_v - dr * song_qrs_v(5.5)
xs_v = xp_v - dr * song_s_v(7.8)
xt_v = xp_v - dr * song_t_v(9.8)
xu_v = xp_v - dr * song_u(12.5)
End Sub
Private Sub Slider2_Change()
dr = 500 * Slider2.Value
change
End Sub
Private Sub Timer1_Timer()
Static tdd As Integer
If Combo1.Text = "II" Then
draw_ekg (tdd)
If tdd >= cal_td Then
tdd = cal_td / 10
Else
tdd = tdd + cal_td / 10
End If
ElseIf Combo1.Text = "V2" Then
draw_ekg_v (tdd)
If tdd >= cal_td_v Then
tdd = cal_td_v / 10
Else
tdd = tdd + cal_td_v / 10
End If
ElseIf Combo1.Text = "aVF" Then
draw_ekg_aVF (tdd)
If tdd >= cal_td_aVF Then
tdd = cal_td_aVF / 10
Else
tdd = tdd + cal_td_aVF / 10
End If
ElseIf Combo1.Text = "aVL" Then
draw_ekg_aVL (tdd)
If tdd >= cal_td_aVL Then
tdd = cal_td_aVL / 10
Else
tdd = tdd + cal_td_aVL / 10
End If
ElseIf Combo1.Text = "aVR" Then
draw_ekg_aVR (tdd)
If tdd >= cal_td_aVR Then
tdd = cal_td_aVR / 10
Else
tdd = tdd + cal_td_aVR / 10
End If
ElseIf Combo1.Text = " I" Then
draw_ekg_i (tdd)
If tdd >= cal_td_i Then
tdd = cal_td_i / 10
Else
tdd = tdd + cal_td_i / 10
End If
ElseIf Combo1.Text = "III" Then
draw_ekg_iii (tdd)
If tdd >= cal_td_iii Then
tdd = cal_td_iii / 10
Else
tdd = tdd + cal_td_iii / 10
End If
ElseIf Combo1.Text = "V5" Then
draw_ekg_v5 (tdd)
If tdd >= cal_td_v5 Then
tdd = cal_td_v5 / 10
Else
tdd = tdd + cal_td_v5 / 10
End If
ElseIf Combo1.Text = "V6" Then
draw_ekg_v6 (tdd)
If tdd >= cal_td_v5 Then
tdd = cal_td_v5 / 10
Else
tdd = tdd + cal_td_v5 / 10
End If
ElseIf Combo1.Text = "V4" Then
draw_ekg_v4 (tdd)
If tdd >= cal_td_v4 Then
tdd = cal_td_v4 / 10
Else
tdd = tdd + cal_td_v4 / 10
End If
ElseIf Combo1.Text = "V3" Then
draw_ekg_v3 (tdd)
If tdd >= cal_td_v3 Then
tdd = cal_td_v3 / 10
Else
tdd = tdd + cal_td_v3 / 10
End If
ElseIf Combo1.Text = "V1" Then
draw_ekg_v1 (tdd)
If tdd >= cal_td_v1 Then
tdd = cal_td_v1 / 10
Else
tdd = tdd + cal_td_v1 / 10
End If
End If
End Sub
Private Sub Timer2_Timer()
Static tdd As Integer
nhip_tho (tdd)
If tdd >= cal_td_nt Then
tdd = cal_td_nt / 10
Else
tdd = tdd + cal_td_nt / 10
End If
End Sub
Private Function calculate_td() As Integer
Dim m As Integer
Dim x As Single
x = 0.01
While Round(x, 2) < 2
x = Round(x, 2) + f
m = m + 1
Wend
x = 3.5
While Round(x, 2) < 3.92
x = Round(x, 2) + f
m = m + 1
Wend
x = 5.8
While Round(x, 2) < 6.22
x = Round(x, 2) + f
m = m + 1
Wend
x = 8.1
While Round(x, 2) < 8.27
x = Round(x, 2) + f
m = m + 1
Wend
x = 9.07
While Round(x, 2) < 11.2
x = Round(x, 2) + f
m = m + 1
Wend
x = 12.9
While Round(x, 2) < 13.1
x = Round(x, 2) + f
m = m + 1
Wend
calculate_td = 10 * m
End Function
Private Function calculate_td_aVF() As Integer
Dim m As Integer
Dim x As Single
x = 0.01
While Round(x, 2) < 2
x = Round(x, 2) + f
m = m + 1
Wend
x = 3.33
While Round(x, 2) < 4.17
x = Round(x, 2) + f
m = m + 1
Wend
x = 5.8
While Round(x, 2) < 6.22
x = Round(x, 2) + f
m = m + 1
Wend
x = 3.77
While Round(x, 2) < 3.9
x = Round(x, 2) + f
m = m + 1
Wend
x = 9.07
While Round(x, 2) < 11.2
x = Round(x, 2) + f
m = m + 1
Wend
x = 12.9
While Round(x, 2) < 13.1
x = Round(x, 2) + f
m = m + 1
Wend
calculate_td_aVF = 10 * m
End Function
Private Function calculate_td_v() As Integer
Dim m As Integer
Dim x As Single
x = 1.65
While Round(x, 2) < 2
x = Round(x, 2) + f_v
m = m + 1
Wend
x = 3.7
While Round(x, 2) < 3.92
x = Round(x, 2) + f_v
m = m + 1
Wend
x = 5.97
While Round(x, 2) < 6.04
x = Round(x, 2) + f_v
m = m + 1
Wend
x = 8.02
While Round(x, 2) < 8.15
x = Round(x, 2) + f_v
m = m + 1
Wend
x = 10
While Round(x, 2) < 10.5
x = Round(x, 2) + f_v
m = m + 1
Wend
x = 12.9
While Round(x, 2) < 13.1
x = Round(x, 2) + f_v
m = m + 1
Wend
calculate_td_v = 10 * m
End Function
Private Function calculate_td_aVL() As Integer
Dim m As Integer
Dim x As Single
x = 0.01
While Round(x, 2) < 2
x = Round(x, 2) + f
m = m + 1
Wend
x = 3.5
While Round(x, 2) < 3.92
x = Round(x, 2) + f
m = m + 1
Wend
x = 5.8
While Round(x, 2) < 6.22
x = Round(x, 2) + f
m = m + 1
Wend
x = 8.03
While Round(x, 2) < 8.4
x = Round(x, 2) + f
m = m + 1
Wend
x = 9.07
While Round(x, 2) < 11.2
x = Round(x, 2) + f
m = m + 1
Wend
x = 12.9
While Round(x, 2) < 13.1
x = Round(x, 2) + f
m = m + 1
Wend
calculate_td_aVL = 10 * m
End Function
Private Function calculate_td_aVR() As Integer
Dim m As Integer
Dim x As Single
x = 1.35
While Round(x, 2) < 2.1
x = Round(x, 2) + f
m = m + 1
Wend
x = 3.6
While Round(x, 2) < 4.1
x = Round(x, 2) + f
m = m + 1
Wend
x = 5.8
While Round(x, 2) < 6.3
x = Round(x, 2) + f
m = m + 1
Wend
x = 10.25
While Round(x, 2) < 10.5
x = Round(x, 2) + f
m = m + 1
Wend
x = 12.3
While Round(x, 2) < 12.6
x = Round(x, 2) + f
m = m + 1
Wend
calculate_td_aVR = 10 * m
End Function
Private Function calculate_td_i() As Integer
Dim m As Integer
Dim x As Single
x = 0.01
While Round(x, 2) < 2
x = Round(x, 2) + f
m = m + 1
Wend
x = 3.5
While Round(x, 2) < 3.92
x = Round(x, 2) + f
m = m + 1
Wend
x = 5.8
While Round(x, 2) < 6.22
x = Round(x, 2) + f
m = m + 1
Wend
x = 8.03
While Round(x, 2) < 8.45
x = Round(x, 2) + f
m = m + 1
Wend
x = 9.07
While Round(x, 2) < 11.2
x = Round(x, 2) + f
m = m + 1
Wend
x = 12.9
While Round(x, 2) < 13.1
x = Round(x, 2) + f
m = m + 1
Wend
calculate_td_i = 10 * m
End Function
Private Function calculate_td_iii() As Integer
Dim m As Integer
Dim x As Single
x = 1.5
While Round(x, 2) < 2.4
x = Round(x, 2) + f
m = m + 1
Wend
x = 3.65
While Round(x, 2) < 3.92
x = Round(x, 2) + f
m = m + 1
Wend
x = 5.97
While Round(x, 2) < 6.11
x = Round(x, 2) + f
m = m + 1
Wend
x = 8.07
While Round(x, 2) < 8.5
x = Round(x, 2) + f
m = m + 1
Wend
x = 10.2
While Round(x, 2) < 10.6
x = Round(x, 2) + f
m = m + 1
Wend
calculate_td_iii = 10 * m
End Function
Private Function calculate_td_v5() As Integer
Dim m As Integer
Dim x As Single
x = 0.01
While Round(x, 2) < 2
x = Round(x, 2) + f
m = m + 1
Wend
x = 3.5
While Round(x, 2) < 3.92
x = Round(x, 2) + f
m = m + 1
Wend
x = 5.8
While Round(x, 2) < 6.22
x = Round(x, 2) + f
m = m + 1
Wend
x = 8.03
While Round(x, 2) < 8.2
x = Round(x, 2) + f
m = m + 1
Wend
x = 9.8
While Round(x, 2) < 11.2
x = Round(x, 2) + f
m = m + 1
Wend
x = 12.9
While Round(x, 2) < 13.1
x = Round(x, 2) + f
m = m + 1
Wend
calculate_td_v5 = 10 * m
End Function
Private Function calculate_td_v4() As Integer
Dim m As Integer
Dim x As Single
x = 1.5
While Round(x, 2) < 1.9
x = Round(x, 2) + f
m = m + 1
Wend
x = 1.09
While Round(x, 2) < 1.81
x = Round(x, 2) + f
m = m + 1
Wend
x = 3.72
While Round(x, 2) < 4.1
x = Round(x, 2) + f
m = m + 1
Wend
x = 5.8
While Round(x, 2) < 6.09
x = Round(x, 2) + f
m = m + 1
Wend
x = 8.06
While Round(x, 2) < 8.4
x = Round(x, 2) + f
m = m + 1
Wend
x = 10.2
While Round(x, 2) < 11.2
x = Round(x, 2) + f
m = m + 1
Wend
x = 12.9
While Round(x, 2) < 13.1
x = Round(x, 2) + f
m = m + 1
Wend
calculate_td_v4 = 10 * m
End Function
Private Function calculate_td_v3() As Integer
Dim m As Integer
Dim x As Single
x = 1.55
While Round(x, 2) < 2.2
x = Round(x, 2) + f
m = m + 1
Wend
x = 3.7
While Round(x, 2) < 3.91
x = Round(x, 2) + f
m = m + 1
Wend
x = 5.98
While Round(x, 2) < 6.06
x = Round(x, 2) + f
m = m + 1
Wend
x = 8.02
While Round(x, 2) < 8.3
x = Round(x, 2) + f
m = m + 1
Wend
x = 10.17
While Round(x, 2) < 10.51
x = Round(x, 2) + f
m = m + 1
Wend
x = 12.35
While Round(x, 2) < 12.65
x = Round(x, 2) + f
m = m + 1
Wend
calculate_td_v3 = 10 * m
End Function
Private Function calculate_td_v1() As Integer
Dim m As Integer
Dim x As Single
x = 1.55
While Round(x, 2) < 2.2
x = Round(x, 2) + f
m = m + 1
Wend
x = 3.7
While Round(x, 2) < 3.91
x = Round(x, 2) + f
m = m + 1
Wend
x = 5.96
While Round(x, 2) < 6.1
x = Round(x, 2) + f
m = m + 1
Wend
x = 8.02
While Round(x, 2) < 8.3
x = Round(x, 2) + f
m = m + 1
Wend
x = 10.17
While Round(x, 2) < 10.51
x = Round(x, 2) + f
m = m + 1
Wend
x = 12.35
While Round(x, 2) < 12.65
x = Round(x, 2) + f
m = m + 1
Wend
calculate_td_v1 = 10 * m
End Function
Private Function calculate_td_nt() As Integer
Dim m As Integer
Dim x As Single
x = 0
While Round(x, 2) < 2 * pi
x = Round(x, 2) + f_nt
m = m + 1
Wend
calculate_td_nt = 10 * m
End Function
Private Sub Timer3_Timer()
Randomize
Text1.Text = 80 + Int((4 * Rnd))
End Sub
‘ Form SpO2
Const pi = 3.14159265
Const l = 1
Const f = 0.01 'Dieu tan so cua song
Const ds = 2500 'Dieu chinh vi tri cua song
Const dr = 4000 'Dieu chinh bien do cua song
Dim xt As Integer, xu As Integer
Dim cal_td As Integer
Private Sub Form_Load()
ProgressBar1.Orientation = ccOrientationVertical
xt = dr * song_t(1)
xu = xt - dr * song_u(6)
cal_td = calculate_td
End Sub
Private Sub Timer1_Timer()
Static tdd As Integer
draw_SpO2 (tdd)
If tdd >= cal_td Then
tdd = cal_td / 10
Else
tdd = tdd + cal_td / 10
End If
End Sub
Private Sub Timer2_Timer()
Randomize
Text1.Text = 78 + Int((4 * Rnd))
Randomize
Text2.Text = 97 + Int((3 * Rnd))
ProgressBar1.Value = Val(Text2.Text) - 95
End Sub
Private Function song_t(ByVal x As Single) As Single
Dim a As Single, b As Single, t1 As Single, t2 As Single, harm2 As Single
Dim i As Integer, n As Integer
a = 0.25
x = x - 0.15 - 0.045
b = (2 * l) / 0.45
n = 100
t1 = 1 / l
t2 = 0
For i = 1 To n
harm2 = (((Sin((pi / (2 * b)) * (b - (2 * i)))) / (b - (2 * i)) + (Sin((pi / (2 * b)) * (b + (2 * i)))) / (b + (2 * i))) * (2 / pi)) * Cos((i * pi * x) / l)
t2 = t2 + harm2
Next
song_t = a * (t1 + t2)
End Function
Private Function song_u(ByVal x As Single) As Single
Dim a As Single, b As Single, u1 As Single, u2 As Single, harm4 As Single
Dim i As Integer, n As Integer
a = 0.08
x = x - 0.433
b = (2 * l) / 0.35
n = 100
u1 = 1 / l
u2 = 0
For i = 1 To n
harm4 = (((Sin((pi / (2 * b)) * (b - (2 * i)))) / (b - (2 * i)) + (Sin((pi / (2 * b)) * (b + (2 * i)))) / (b + (2 * i))) * (2 / pi)) * Cos((i * pi * x) / l)
u2 = u2 + harm4
Next
song_u = a * (u1 + u2)
End Function
Private Sub draw_SpO2(ByVal sample As Integer)
Dim k As Single
Dim x As Single
Dim td As Integer
Dim i As Integer
Dim check As Boolean
k = ds - xt
td = sample
check = False
Picture1.ForeColor = &H80000005
Picture1.Line (td, 1)-(td, Picture1.ScaleHeight)
Picture1.Line (td + 10, 1)-(td + 10, Picture1.ScaleHeight)
'
'Ve song tu trai qua phai
Do While (check = False)
x = 1.9
'Ve song t
While Round(x, 2) < 2.37
If td 0 Then
Picture1.ForeColor = &H80000005
Picture1.Line (td + 20, 1)-(td + 20, Picture1.ScaleHeight) 'Xoa truoc khi ve
Picture1.ForeColor = &HFF80FF
Picture1.Line (td, k)-(td + 10, ds - dr * song_t(Round(x, 2))) 'Ve song
End If
k = ds - dr * song_t(Round(x, 2))
x = Round(x, 2) + f
If td + 10 > Picture1.ScaleWidth Then
check = True
Else
td = td + 10
End If
If (check = True) Then Exit Do
Wend
If (check = True) Then Exit Do
x = 6.43
'Ve song u
While Round(x, 2) < 6.75
If td 0 Then
Picture1.ForeColor = &H80000005
Picture1.Line (td + 20, 1)-(td + 20, Picture1.ScaleHeight)
Picture1.ForeColor = &HFF80FF
Picture1.Line (td, k)-(td + 10, ds - xu - dr * song_u(Round(x, 2)))
End If
k = ds - xu - dr * song_u(Round(x, 2))
x = Round(x, 2) + f
If td + 10 > Picture1.ScaleWidth Then
check = True
Else
td = td + 10
End If
If (check = True) Then Exit Do
Wend
Loop
k = ds - xt
td = sample
'Ve song tu phai qua trai
Do While (td > 0)
x = 6.74
'Ve song u
While Round(x, 2) >= 6.43
If td Picture1.ScaleWidth Then
Picture1.ForeColor = &H80000005
Picture1.Line (td - 20, 1)-(td - 20, Picture1.ScaleHeight)
Picture1.ForeColor = &HFF80FF
Picture1.Line (td, k)-(td - 10, ds - xu - dr * song_u(Round(x, 2)))
End If
k = ds - xu - dr * song_u(Round(x, 2))
x = Round(x, 2) - f
If td - 10 < 0 Then
Exit Sub
Else
td = td - 10
End If
Wend
x = 2.36
'Ve song t
While Round(x, 2) >= 1.9
If td Picture1.ScaleWidth Then
Picture1.ForeColor = &H80000005
Picture1.Line (td - 20, 1)-(td - 20, Picture1.ScaleHeight)
Picture1.ForeColor = &HFF80FF
Picture1.Line (td, k)-(td - 10, ds - dr * song_t(Round(x, 2)))
End If
k = ds - dr * song_t(Round(x, 2))
x = Round(x, 2) - f
If td - 10 < 0 Then
Exit Sub
Else
td = td - 10
End If
Wend
Loop
End Sub
Private Function calculate_td() As Integer
Dim m As Integer
Dim x As Single
x = 1.9
While Round(x, 2) < 2.37
x = Round(x, 2) + f
m = m + 1
Wend
x = 6.43
While Round(x, 2) < 6.75
x = Round(x, 2) + f
m = m + 1
Wend
calculate_td = 10 * m
End Function
‘ Form NIBP
Dim val_cycle As Byte
Dim val_Pump As Byte
Private Sub Command1_Click()
If Label_Status.Caption = "IDLE" Then
Select Case val_cycle
Case 0:
Label10.Caption = "Manual"
val_cycle = 1
Case 1:
Label10.Caption = "1min"
val_cycle = 2
Case 2:
Label10.Caption = "2min"
val_cycle = 3
Case 3:
Label10.Caption = "3min"
val_cycle = 4
Case 4:
Label10.Caption = "4min"
val_cycle = 5
Case 5:
Label10.Caption = "5min"
val_cycle = 6
Case 6:
Label10.Caption = "10min"
val_cycle = 7
Case 7:
Label10.Caption = "15min"
val_cycle = 8
Case 8:
Label10.Caption = "30min"
val_cycle = 0
End Select
End If
End Sub
Private Sub Command10_Click()
If Label_Status.Caption = "IDLE" Then
Select Case val_Pump
Case 0:
Label14.Caption = "100mHg"
val_Pump = 1
Case 1:
Label14.Caption = "120mHg"
val_Pump = 2
Case 2:
Label14.Caption = "140mHg"
val_Pump = 3
Case 3:
Label14.Caption = "160mHg"
val_Pump = 4
Case 4:
Label14.Caption = "180mHg"
val_Pump = 0
End Select
End If
End Sub
Private Sub Command2_Click()
Label_Status.Caption = "IDLE"
Text1.Text = "---"
Text2.Text = "---"
Text3.Text = "---"
Text4.Text = "---"
End Sub
Private Sub Command3_Click()
Label_Status.Caption = "MEASURE"
Timer1.Enabled = True
Text1.Text = "---"
Text2.Text = "---"
Text3.Text = "---"
Text4.Text = "---"
End Sub
Private Sub Command4_Click()
Unload Me
End Sub
Private Sub Command9_Click()
If Label_Status.Caption = "IDLE" Then
If Label12.Caption = "Neonate" Then
Label12.Caption = "Adult"
Label14.Caption = "170mHg"
Else
Label12.Caption = "Neonate"
Label14.Caption = "140mHg"
End If
End If
End Sub
Private Sub Form_Load()
val_cycle = 1
val_Pump = 1
End Sub
Private Sub Timer1_Timer()
If Label_Status.Caption = "MEASURE" Then
If Label12.Caption = "Neonate" Then
Timer1.Enabled = True
Select Case val_Pump
Case 0:
Label14.Caption = "0mHg"
val_Pump = 1
Case 1:
Label14.Caption = "20mHg"
val_Pump = 2
Case 2:
Label14.Caption = "40mHg"
val_Pump = 3
Case 3:
Label14.Caption = "60mHg"
val_Pump = 4
Case 4:
Label14.Caption = "80mHg"
val_Pump = 5
Case 5:
Label14.Caption = "100mHg"
val_Pump = 6
Case 6:
Label14.Caption = "120mHg"
val_Pump = 7
Case 7:
Label14.Caption = "140mHg"
val_Pump = 8
Case 8:
Label14.Caption = "120mHg"
val_Pump = 9
Case 9:
Label14.Caption = "100mHg"
val_Pump = 10
Case 10:
Label14.Caption = "80mHg"
val_Pump = 11
Case 11:
Label14.Caption = "60mHg"
val_Pump = 12
Case 12:
Label14.Caption = "40mHg"
val_Pump = 13
Case 13:
Label14.Caption = "20mHg"
Timer1.Enabled = False
Text1.Text = "110"
Text2.Text = "77"
Text3.Text = "88"
Text4.Text = "80"
val_Pump = 1
End Select
Else
Label12.Caption = "Adult"
Select Case val_Pump
Case 0:
Label14.Caption = "0mHg"
val_Pump = 1
Case 1:
Label14.Caption = "20mHg"
val_Pump = 2
Case 2:
Label14.Caption = "40mHg"
val_Pump = 3
Case 3:
Label14.Caption = "60mHg"
val_Pump = 4
Case 4:
Label14.Caption = "80mHg"
val_Pump = 5
Case 5:
Label14.Caption = "100mHg"
val_Pump = 6
Case 6:
Label14.Caption = "120mHg"
val_Pump = 7
Case 7:
Label14.Caption = "140mHg"
val_Pump = 8
Case 8:
Label14.Caption = "160mHg"
val_Pump = 9
Case 9:
Label14.Caption = "170mHg"
val_Pump = 10
Case 10:
Label14.Caption = "160mHg"
val_Pump = 11
Case 11:
Label14.Caption = "140mHg"
val_Pump = 12
Case 12:
Label14.Caption = "120mHg"
val_Pump = 13
Case 13:
Label14.Caption = "100mHg"
val_Pump = 14
Case 14:
Label14.Caption = "80mHg"
val_Pump = 15
Case 15:
Label14.Caption = "60mHg"
val_Pump = 16
Case 16:
Label14.Caption = "40mHg"
val_Pump = 17
Case 17:
Label14.Caption = "30mHg"
Timer1.Enabled = False
Text1.Text = "117"
Text2.Text = "79"
Text3.Text = "92"
Text4.Text = "80"
val_Pump = 1
End Select
End If
End If
End Sub
Các file đính kèm theo tài liệu này:
- DAN089.doc