Hi all,
I am using an MSExcel template (MAKESENS 1.0, it's free and available online) to calculate the Mann-Kandall test and Sen's slope for a trend analysis of a wind speed time series. So, I have 62 years of data and the template (VBA code) works fine if I don't have zero in the time series. However, if zero zero occurs then I get an error message "Run-time error '6': Overflow ". If I click debug, it shows that the red line line is an issue (I attached the code below, please see the red line at the end).
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
Private Function tiedSum(n As Integer, x() As Double) As Integer
'Calculates sum related to tied groups(= two or more equal values)
' for the variance of Mann-Kendall statistics S
'n = number of values in the array x including missing values
'Function tiedSum is called by subroutines Sen and MannKendallNorm
Dim m As Integer ' number of tied groups
Dim tval() As Double ' data values of tied groups
ReDim tvaldata:image/s3,"s3://crabby-images/cd90d/cd90d5e8d001b1bdf9418216880cb06c124ab2b8" alt="Thumbs down (n) (n)"
Dim t() As Integer, nt As Integer ' number of data in tied groups
ReDim tdata:image/s3,"s3://crabby-images/cd90d/cd90d5e8d001b1bdf9418216880cb06c124ab2b8" alt="Thumbs down (n) (n)"
Dim p, i As Integer 'indexes for the loops
Dim newValue As Boolean
Dim tSum As Integer
'Calculation of the number of tied groups m and the number of data
' in tied groups t()
m = 0
For i = 1 To n - 1
If x(i) <> MissingValue Then
newValue = True
If m > 0 Then
For p = 1 To m
If x(i) = tval(p) Then
newValue = False 'this value is alredy managed
Exit For
End If
Next p
End If
If newValue Then
nt = 1 'number of equal values x(i)
For p = i + 1 To n
If x(p) = x(i) Then
nt = nt + 1
End If
Next p
If nt > 1 Then ' new group only if nt>1
m = m + 1
t(m) = nt
tval(m) = x(i)
End If
End If
End If
Next i
'Calculating the sum related to tied groups for variance
tSum = 0
If m > 0 Then
For p = 1 To m
tSum = tSum + t(p) * (t(p) - 1) * (2 * t(p) + 5)
Next p
End If
tiedSum = tSum
End Function 'tiedSum
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
Please, can I get some hepl?
Thans,
Djordje
I am using an MSExcel template (MAKESENS 1.0, it's free and available online) to calculate the Mann-Kandall test and Sen's slope for a trend analysis of a wind speed time series. So, I have 62 years of data and the template (VBA code) works fine if I don't have zero in the time series. However, if zero zero occurs then I get an error message "Run-time error '6': Overflow ". If I click debug, it shows that the red line line is an issue (I attached the code below, please see the red line at the end).
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
Private Function tiedSum(n As Integer, x() As Double) As Integer
'Calculates sum related to tied groups(= two or more equal values)
' for the variance of Mann-Kendall statistics S
'n = number of values in the array x including missing values
'Function tiedSum is called by subroutines Sen and MannKendallNorm
Dim m As Integer ' number of tied groups
Dim tval() As Double ' data values of tied groups
ReDim tval
data:image/s3,"s3://crabby-images/cd90d/cd90d5e8d001b1bdf9418216880cb06c124ab2b8" alt="Thumbs down (n) (n)"
Dim t() As Integer, nt As Integer ' number of data in tied groups
ReDim t
data:image/s3,"s3://crabby-images/cd90d/cd90d5e8d001b1bdf9418216880cb06c124ab2b8" alt="Thumbs down (n) (n)"
Dim p, i As Integer 'indexes for the loops
Dim newValue As Boolean
Dim tSum As Integer
'Calculation of the number of tied groups m and the number of data
' in tied groups t()
m = 0
For i = 1 To n - 1
If x(i) <> MissingValue Then
newValue = True
If m > 0 Then
For p = 1 To m
If x(i) = tval(p) Then
newValue = False 'this value is alredy managed
Exit For
End If
Next p
End If
If newValue Then
nt = 1 'number of equal values x(i)
For p = i + 1 To n
If x(p) = x(i) Then
nt = nt + 1
End If
Next p
If nt > 1 Then ' new group only if nt>1
m = m + 1
t(m) = nt
tval(m) = x(i)
End If
End If
End If
Next i
'Calculating the sum related to tied groups for variance
tSum = 0
If m > 0 Then
For p = 1 To m
tSum = tSum + t(p) * (t(p) - 1) * (2 * t(p) + 5)
Next p
End If
tiedSum = tSum
End Function 'tiedSum
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
Please, can I get some hepl?
Thans,
Djordje