From 771e750a8c2e4b0dbeaa59a60c48022d4ef81ec3 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?W=2E=20Garc=C3=ADa?= <70865364+ws-garcia@users.noreply.github.com> Date: Fri, 12 Apr 2024 01:18:51 -0400 Subject: [PATCH] v3.2.4 --- src/VBAexpressions.cls | 1462 +++++++++++++++++++--------------------- 1 file changed, 683 insertions(+), 779 deletions(-) diff --git a/src/VBAexpressions.cls b/src/VBAexpressions.cls index dc8dc5b..346f7ed 100644 --- a/src/VBAexpressions.cls +++ b/src/VBAexpressions.cls @@ -335,8 +335,8 @@ Private Sub Class_Initialize() InitCBbuffer UserDefFunctions '@-------------------------------------------------------------------- ' Populate linked index constructor - LIndexConstruc(0) = d_lCurly - LIndexConstruc(2) = d_rCurly + LIndexConstruc(0) = d_lSquareB + LIndexConstruc(2) = d_rSquareB '@-------------------------------------------------------------------- ' Populate building UDFs Dim UDFnames() As Variant @@ -658,8 +658,8 @@ Public Sub AddConstant(aValue As String, aKey As String) End Sub Private Sub AddExponentialPredictors(ByRef x() As Double, ByRef pExponents() As Long) - Dim i As Long - Dim j As Long + Dim I As Long + Dim J As Long Dim UB As Long Dim UB2 As Long Dim tmpData() As Double @@ -667,41 +667,41 @@ Private Sub AddExponentialPredictors(ByRef x() As Double, ByRef pExponents() As UB = UBound(x) UB2 = UBound(x, 2) tmpData = x - For i = 0 To UBound(pExponents) - If pExponents(i) > 1 Then 'Only not lineal degrees + For I = 0 To UBound(pExponents) + If pExponents(I) > 1 Then 'Only not lineal degrees UB2 = UB2 + 1 ReDim Preserve tmpData(0 To UB, 0 To UB2) - For j = 0 To UB - tmpData(j, UB2) = x(j, 0) ^ pExponents(i) - Next j + For J = 0 To UB + tmpData(J, UB2) = x(J, 0) ^ pExponents(I) + Next J End If - Next i + Next I x = tmpData Erase tmpData End Sub Private Sub AddIntersectionCol(ByRef x() As Double) - Dim i As Long - Dim j As Long + Dim I As Long + Dim J As Long Dim UB As Long Dim UB2 As Long UB = UBound(x) UB2 = UBound(x, 2) ReDim Preserve x(0 To UB, 0 To UB2 + 1) - For i = 0 To UB - For j = UB2 To 0 Step -1 - x(i, j + 1) = x(i, j) - If j = 0 Then - x(i, j) = 1 + For I = 0 To UB + For J = UB2 To 0 Step -1 + x(I, J + 1) = x(I, J) + If J = 0 Then + x(I, J) = 1 End If - Next j - Next i + Next J + Next I End Sub Private Sub AddPredictorsRelations(ByRef x() As Double, ByRef PredInteractions As Variant) - Dim i As Long - Dim j As Long + Dim I As Long + Dim J As Long Dim UB As Long Dim UB2 As Long Dim idx1 As Long @@ -712,16 +712,16 @@ Private Sub AddPredictorsRelations(ByRef x() As Double, ByRef PredInteractions A UB = UBound(x) UB2 = UBound(x, 2) tmpData = x - For i = 0 To UBound(PredInteractions) - tmpPredict = Split(PredInteractions(i), op_mult) + For I = 0 To UBound(PredInteractions) + tmpPredict = Split(PredInteractions(I), op_mult) idx1 = CLng(MidB(tmpPredict(LBound(tmpPredict)), 3)) idx2 = CLng(MidB(tmpPredict(LBound(tmpPredict) + 1), 3)) UB2 = UB2 + 1 ReDim Preserve tmpData(0 To UB, 0 To UB2) - For j = 0 To UB - tmpData(j, UB2) = x(j, idx1) * x(j, idx2) - Next j - Next i + For J = 0 To UB + tmpData(J, UB2) = x(J, idx1) * x(J, idx2) + Next J + Next I x = tmpData Erase tmpData End Sub @@ -813,18 +813,18 @@ err_Handler: End Function Private Function AFISHF_(p As Double, N1 As Double, N2 As Double) As Double - Dim v As Double, dv As Double, f As Double + Dim v As Double, dv As Double, F As Double - v = 0.5: dv = 0.5: f = 0 + v = 0.5: dv = 0.5: F = 0 Do While (dv > 0.000000000000001) - f = 1 / v - 1: dv = dv / 2 - If (FISHF_(f, N1, N2) > p) Then + F = 1 / v - 1: dv = dv / 2 + If (FISHF_(F, N1, N2) > p) Then v = v - dv Else v = v + dv End If Loop - AFISHF_ = f + AFISHF_ = F End Function Private Function aFloor(ByRef expression As String, ByRef fName As String) As String @@ -1093,7 +1093,7 @@ Public Function ArrayFromString(ByRef strArray As String) As String() Dim arrCapacity As Long Dim boolOpenArray As Boolean Dim curChar As String - Dim i As Long, j As Long + Dim I As Long, J As Long Dim NumCols As Long Dim NumRows As Long Dim OneDarr As Boolean @@ -1114,22 +1114,22 @@ Public Function ArrayFromString(ByRef strArray As String) As String() If MidB$(StrCopy, StrLen - 3) <> "}}" Then 'Missed "}" from input Exit Function End If - i = 1 + I = 1 aIndex = -1 arrCapacity = 128 ReDim tmpStr(0 To arrCapacity - 1) Do - curChar = MidB$(StrCopy, i, 2) + curChar = MidB$(StrCopy, I, 2) If curChar = d_lCurly Then OpenCBrackets = OpenCBrackets + 1 If (OpenCBrackets And 1) = 0 Then 'Takes care of array syntax - VectorStartPos = i + 2 + VectorStartPos = I + 2 End If Else If curChar = d_rCurly Then OpenCBrackets = OpenCBrackets - 1 If (OpenCBrackets And 1) Then 'End of vector - VectorEndPos = i + VectorEndPos = I aIndex = aIndex + 1 If aIndex > arrCapacity Then arrCapacity = arrCapacity * 2 @@ -1141,8 +1141,8 @@ Public Function ArrayFromString(ByRef strArray As String) As String() End If End If boolOpenArray = (OpenCBrackets > 0) - i = i + 2 - Loop While boolOpenArray Or (i <= StrLen) + I = I + 2 + Loop While boolOpenArray Or (I <= StrLen) NumRows = aIndex NumCols = UBound(tmpStr(aIndex)) inputIs2D = strArray Like "{{*}" & P_SEPARATORCHAR & "{*}*}" @@ -1152,15 +1152,15 @@ Public Function ArrayFromString(ByRef strArray As String) As String() Else '2D array ReDim OutStrArray(0 To NumRows, 0 To NumCols) End If - For i = 0 To NumRows - For j = 0 To NumCols + For I = 0 To NumRows + For J = 0 To NumCols If OneDarr Then - OutStrArray(j) = tmpStr(i)(j) + OutStrArray(J) = tmpStr(I)(J) Else - OutStrArray(i, j) = tmpStr(i)(j) + OutStrArray(I, J) = tmpStr(I)(J) End If - Next j - Next i + Next J + Next I ArrayFromString = OutStrArray End Function @@ -1173,7 +1173,7 @@ Public Function ArrayFromString2(ByRef strArray As String) As Variant() Dim arrCapacity As Long Dim boolOpenArray As Boolean Dim curChar As String - Dim i As Long + Dim I As Long Dim JaggedArrFlag As Boolean Dim NumRows As Long Dim StrCopy As String @@ -1191,29 +1191,29 @@ Public Function ArrayFromString2(ByRef strArray As String) As Variant() If MidB$(StrCopy, StrLen - 3) <> "}}" Then 'Missed "}" from input Exit Function End If - i = 1 + I = 1 aIndex = -1 arrCapacity = 128 ReDim tmpStr(0 To arrCapacity - 1) Do - curChar = MidB$(StrCopy, i, 2) + curChar = MidB$(StrCopy, I, 2) If curChar = d_lCurly Then OpenCBrackets = OpenCBrackets + 1 If Not JaggedArrFlag Then JaggedArrFlag = (OpenCBrackets > 2) End If If (OpenCBrackets And 1) = 0 Then 'Takes care of array syntax - VectorStartPos = i + 2 + VectorStartPos = I + 2 End If Else If curChar = d_rCurly Then OpenCBrackets = OpenCBrackets - 1 If (OpenCBrackets And 1) Then 'End of vector If Not JaggedArrFlag Then - VectorEndPos = i + VectorEndPos = I Else VectorStartPos = VectorStartPos - 2 - VectorEndPos = i + 2 + VectorEndPos = I + 2 End If aIndex = aIndex + 1 If aIndex > arrCapacity Then @@ -1234,8 +1234,8 @@ Public Function ArrayFromString2(ByRef strArray As String) As Variant() End If End If boolOpenArray = (OpenCBrackets > 0) - i = i + 2 - Loop While boolOpenArray Or (i <= StrLen) + I = I + 2 + Loop While boolOpenArray Or (I <= StrLen) NumRows = aIndex ReDim Preserve tmpStr(0 To aIndex) ArrayFromString2 = tmpStr @@ -1246,8 +1246,8 @@ End Function ''' ''' The array to operate. Private Function ArraySTR1DFrom2DArr(ByRef InputArray() As String) As String() - Dim i As Long, LB As Long, UB As Long - Dim j As Long, LB2 As Long, UB2 As Long + Dim I As Long, LB As Long, UB As Long + Dim J As Long, LB2 As Long, UB2 As Long Dim tmpData() As String LB = LBound(InputArray) @@ -1255,11 +1255,11 @@ Private Function ArraySTR1DFrom2DArr(ByRef InputArray() As String) As String() LB2 = LBound(InputArray, 2) UB2 = UBound(InputArray, 2) ReDim tmpData(0 To (UB - LB + 1) * (UB2 - LB2 + 1) - 1) - For i = LB To UB - For j = LB2 To UB2 - tmpData(i * (UB2 - LB2 + 1) + j) = InputArray(i, j) - Next j - Next i + For I = LB To UB + For J = LB2 To UB2 + tmpData(I * (UB2 - LB2 + 1) + J) = InputArray(I, J) + Next J + Next I ArraySTR1DFrom2DArr = tmpData End Function @@ -1268,8 +1268,8 @@ End Function ''' ''' The array to operate. Public Function ArrayToString(ByRef InputArray As Variant) As String - Dim i As Long, LB As Long, UB As Long - Dim j As Long, LB2 As Long, UB2 As Long + Dim I As Long, LB As Long, UB As Long + Dim J As Long, LB2 As Long, UB2 As Long Dim tmpData As String, MultiDimArr As Boolean Dim isJaggedArray As Boolean @@ -1288,33 +1288,33 @@ Public Function ArrayToString(ByRef InputArray As Variant) As String UB = LB End If End If - For i = LB To UB - If isJaggedArray And IsTwiceJaggedArr(InputArray, i) Then - If i = LB Then - tmpData = ArrayToString(InputArray(i)) + For I = LB To UB + If isJaggedArray And IsTwiceJaggedArr(InputArray, I) Then + If I = LB Then + tmpData = ArrayToString(InputArray(I)) Else - tmpData = tmpData & ArrayToString(InputArray(i)) + tmpData = tmpData & ArrayToString(InputArray(I)) End If Else If isJaggedArray Then - LB2 = LBound(InputArray(i)) - UB2 = UBound(InputArray(i)) + LB2 = LBound(InputArray(I)) + UB2 = UBound(InputArray(I)) End If - For j = LB2 To UB2 - If j = LB2 Then - tmpData = tmpData & d_lCurly & GetArrItm(InputArray, MultiDimArr, isJaggedArray, i, j) + For J = LB2 To UB2 + If J = LB2 Then + tmpData = tmpData & d_lCurly & GetArrItm(InputArray, MultiDimArr, isJaggedArray, I, J) Else - tmpData = tmpData & P_SEPARATORCHAR & GetArrItm(InputArray, MultiDimArr, isJaggedArray, i, j) + tmpData = tmpData & P_SEPARATORCHAR & GetArrItm(InputArray, MultiDimArr, isJaggedArray, I, J) End If - If j = UB2 Then + If J = UB2 Then tmpData = tmpData & d_rCurly End If - Next j + Next J End If - If i < UB Then + If I < UB Then tmpData = tmpData & P_SEPARATORCHAR End If - Next i + Next I ArrayToString = d_lCurly & tmpData & d_rCurly End If End Function @@ -1401,16 +1401,16 @@ Private Function ASTUDT_(p As Double, n As Double) As Double End Function Private Function average(ByRef expression As String, ByRef fName As String) As String - Dim g As Long + Dim G As Long Dim tmpData() As String Dim tmpEval As Double On Error GoTo err_Handler tmpEval = 0 tmpData() = SplitArgs(expression) - For g = LBound(tmpData) To UBound(tmpData) - tmpEval = tmpEval + CDbl(tmpData(g)) - Next g + For G = LBound(tmpData) To UBound(tmpData) + tmpEval = tmpEval + CDbl(tmpData(G)) + Next G tmpEval = tmpEval / (UBound(tmpData) - LBound(tmpData) + 1) average = CStr(tmpEval): Erase tmpData Exit Function @@ -1426,7 +1426,7 @@ Private Function betacf(x As Double, A As Double, B As Double) As Double Dim M2 As Long Dim aa As Double, c As Double Dim d As Double, del As Double - Dim h As Double, qab As Double + Dim H As Double, qab As Double Dim qam As Double, qap As Double fpmin = 1E-30 @@ -1437,7 +1437,7 @@ Private Function betacf(x As Double, A As Double, B As Double) As Double c = 1: d = 1 - qab * x / qap If Abs(d) < fpmin Then d = fpmin d = 1 / d - h = d + H = d Do While m <= 100 M2 = 2 * m aa = m * (B - m) * x / ((qam + M2) * (A + M2)) @@ -1446,7 +1446,7 @@ Private Function betacf(x As Double, A As Double, B As Double) As Double If Abs(d) < fpmin Then d = fpmin c = 1 + aa / c If Abs(c) < fpmin Then c = fpmin - d = 1 / d: h = h * d * c + d = 1 / d: H = H * d * c aa = -(A + m) * (qab + m) * x / ((A + M2) * (qap + M2)) ' // Next step of the recurrence (the odd one) d = 1 + aa * d @@ -1454,11 +1454,11 @@ Private Function betacf(x As Double, A As Double, B As Double) As Double c = 1 + aa / c If Abs(c) < fpmin Then c = fpmin d = 1 / d: del = d * c - h = h * del + H = H * del If Abs(del - 1#) < 0.0000003 Then Exit Do m = m + 1 Loop - betacf = h + betacf = H End Function ''' @@ -1504,15 +1504,15 @@ Private Function BETAINV_(p As Double, A As Double, B As Double) As Double Const EPS As Double = 0.00000001 Dim aL As Double Dim a1, b1 As Double - Dim j As Long + Dim J As Long Dim lna As Double, lnb As Double Dim pp As Double, t As Double Dim u As Double, err As Double - Dim x As Double, h As Double + Dim x As Double, H As Double Dim w As Double, afac As Double a1 = A - 1: b1 = B - 1 - j = 0 + J = 0 If p <= 0 Then BETAINV_ = 0 Exit Function @@ -1531,9 +1531,9 @@ Private Function BETAINV_(p As Double, A As Double, B As Double) As Double x = (2.30753 + t * 0.27061) / (1 + t * (0.99229 + t * 0.04481)) - t If p < 0.5 Then x = -x aL = (x * x - 3) / 6 - h = 2 / (1 / (2 * A - 1) + 1 / (2 * B - 1)) - w = (x * Sqr(aL + h) / h) - (1 / (2 * B - 1) - 1 / (2 * A - 1)) * _ - (aL + 5 / 6 - 2 / (3 * h)) + H = 2 / (1 / (2 * A - 1) + 1 / (2 * B - 1)) + w = (x * Sqr(aL + H) / H) - (1 / (2 * B - 1) - 1 / (2 * A - 1)) * _ + (aL + 5 / 6 - 2 / (3 * H)) x = A / (A + B * Exp(2 * w)) Else lna = Log(A / (A + B)): lnb = Log(B / (A + B)) @@ -1546,7 +1546,7 @@ Private Function BETAINV_(p As Double, A As Double, B As Double) As Double End If End If afac = -GAMMALN_(A) - GAMMALN_(B) + GAMMALN_(A + B) - Do While j < 10 + Do While J < 10 If x = 0 Or x = 1 Then BETAINV_ = x: Exit Function err = iBETA_(x, A, B) - p t = Exp(a1 * Log(x) + b1 * Log(1 - x) + afac) @@ -1555,8 +1555,8 @@ Private Function BETAINV_(p As Double, A As Double, B As Double) As Double x = x - t If x <= 0 Then x = 0.5 * (x + t) If x >= 1 Then x = 0.5 * (x + t + 1) - If Abs(t) < EPS * x And j > 0 Then Exit Do - j = j + 1 + If Abs(t) < EPS * x And J > 0 Then Exit Do + J = J + 1 Loop BETAINV_ = x End Function @@ -1821,8 +1821,8 @@ End Function Private Function Cholesky(ByRef A() As Double, ByRef el() As Double) As Double() Dim n As Long 'Rows Dim m As Long 'Columns - Dim i As Long - Dim j As Long + Dim I As Long + Dim J As Long Dim k As Long Dim pSum As Double @@ -1830,30 +1830,30 @@ Private Function Cholesky(ByRef A() As Double, ByRef el() As Double) As Double() m = UBound(A, 2) - LBound(A, 2) + 1 If m <> n Then Exit Function 'need square matrix el = A - For i = 0 To n - 1 - For j = i To n - 1 - pSum = el(i, j) - k = i - 1 + For I = 0 To n - 1 + For J = I To n - 1 + pSum = el(I, J) + k = I - 1 Do While k >= 0 - pSum = pSum - el(i, k) * el(j, k) + pSum = pSum - el(I, k) * el(J, k) k = k - 1 Loop - If i = j Then 'Check diagonal elements + If I = J Then 'Check diagonal elements If pSum <= 0 Then 'A, with rounding errors, is not positive-definite. Erase el 'Cholesky failed. Test for not initialized array needed. Exit Function End If - el(i, i) = Sqr(pSum) + el(I, I) = Sqr(pSum) Else - el(j, i) = pSum / el(i, i) + el(J, I) = pSum / el(I, I) End If - Next j - Next i - For i = 0 To n - 1 - For j = 0 To i - 1 - el(j, i) = 0 - Next j - Next i + Next J + Next I + For I = 0 To n - 1 + For J = 0 To I - 1 + el(J, I) = 0 + Next J + Next I Cholesky = el End Function @@ -1947,33 +1947,33 @@ End Function ''' Private Function CholeskyInverseMatrix_(ByRef el() As Double) As Double() Dim n As Long - Dim i As Long - Dim j As Long + Dim I As Long + Dim J As Long Dim k As Long Dim pSum As Double Dim ainv() As Double n = UBound(el) - LBound(el) + 1 ReDim ainv(0 To n - 1, 0 To n - 1) - For i = 0 To n - 1 - For j = 0 To i - pSum = IIf(i = j, 1, 0) - For k = i - 1 To j Step -1 - pSum = pSum - el(i, k) * ainv(j, k) + For I = 0 To n - 1 + For J = 0 To I + pSum = IIf(I = J, 1, 0) + For k = I - 1 To J Step -1 + pSum = pSum - el(I, k) * ainv(J, k) Next k - ainv(j, i) = pSum / el(i, i) - Next j - Next i - For i = n - 1 To 0 Step -1 - For j = 0 To i - pSum = IIf(i < j, 0, ainv(j, i)) - For k = i + 1 To n - 1 - pSum = pSum - el(k, i) * ainv(j, k) + ainv(J, I) = pSum / el(I, I) + Next J + Next I + For I = n - 1 To 0 Step -1 + For J = 0 To I + pSum = IIf(I < J, 0, ainv(J, I)) + For k = I + 1 To n - 1 + pSum = pSum - el(k, I) * ainv(J, k) Next k - ainv(i, j) = pSum / el(i, i) - ainv(j, i) = ainv(i, j) - Next j - Next i + ainv(I, J) = pSum / el(I, I) + ainv(J, I) = ainv(I, J) + Next J + Next I CholeskyInverseMatrix_ = ainv Erase ainv End Function @@ -2068,7 +2068,7 @@ End Function ''' NOTE: el() Stores the decomposition. ''' Private Sub CholeskySolve_(ByRef el() As Double, ByRef B() As Double, ByRef x() As Double) - Dim i As Long + Dim I As Long Dim k As Long Dim pSum As Double Dim n As Long @@ -2078,24 +2078,24 @@ Private Sub CholeskySolve_(ByRef el() As Double, ByRef B() As Double, ByRef x() e = UBound(B) - LBound(B) + 1 If e <> n Then Exit Sub 'bad lengths in Cholesky ReDim x(0 To n - 1) - For i = 0 To n - 1 'Solve L.y = b, storing y in x. - pSum = B(i) - k = i - 1 + For I = 0 To n - 1 'Solve L.y = b, storing y in x. + pSum = B(I) + k = I - 1 Do While k >= 0 - pSum = pSum - el(i, k) * x(k) + pSum = pSum - el(I, k) * x(k) k = k - 1 Loop - x(i) = pSum / el(i, i) - Next i - For i = n - 1 To 0 Step -1 'Solve LT.x = y - pSum = x(i) - k = i + 1 + x(I) = pSum / el(I, I) + Next I + For I = n - 1 To 0 Step -1 'Solve LT.x = y + pSum = x(I) + k = I + 1 Do While k < n - pSum = pSum - el(k, i) * x(k) + pSum = pSum - el(k, I) * x(k) k = k + 1 Loop - x(i) = pSum / el(i, i) - Next i + x(I) = pSum / el(I, I) + Next I End Sub Private Function Choose(ByRef expression As String, ByRef fName As String) As String @@ -2136,20 +2136,20 @@ End Function ''' NOTE: PolyFit helper ''' Private Function ColumnAvg(vArr() As Double, Optional colIndex As Long) As Double - Dim i As Long + Dim I As Long Dim n As Long Dim TDflag As Boolean Dim tmpResult As Double n = UBound(vArr) - LBound(vArr) + 1 TDflag = Is2Darray(vArr) - For i = 0 To n - 1 + For I = 0 To n - 1 If TDflag Then - tmpResult = tmpResult + vArr(i, colIndex) / n + tmpResult = tmpResult + vArr(I, colIndex) / n Else - tmpResult = tmpResult + vArr(i) / n + tmpResult = tmpResult + vArr(I) / n End If - Next i + Next I ColumnAvg = tmpResult End Function @@ -2159,7 +2159,7 @@ End Function Private Function Compute() As String Dim B As Long Dim t As Long - Dim i As Long + Dim I As Long Dim OperationIndex As Long Dim BaseIndex As Long Dim SkipToken As Boolean @@ -2187,9 +2187,9 @@ Private Function Compute() As String tmpResult() = Split(EvalTree(B).resulstMap, P_SEPARATORCHAR) '@-------------------------------------------------------------------- ' Loop all sub-expression tokens results - For i = LBound(tmpResult) To UBound(tmpResult) - tmpResult(i) = EvalTree(B).Storage(CLng(tmpResult(i))).EvalResult - Next i + For I = LBound(tmpResult) To UBound(tmpResult) + tmpResult(I) = EvalTree(B).Storage(CLng(tmpResult(I))).EvalResult + Next I If Not EvalTree(B).CompArrCluster Then 'Function Argument EvalTree(B).EvalResult = Join$(tmpResult, P_SEPARATORCHAR) Else 'Array function Argument @@ -2280,7 +2280,7 @@ End Function ''' Data sample containing the observations pairs (x,y). ''' Curve type ID. Private Function DataLinearization(ByRef samplesArr() As Double, cOption As Long) As Double() - Dim i As Long + Dim I As Long Dim LB As Long Dim UB As Long Dim LB2 As Long @@ -2292,19 +2292,19 @@ Private Function DataLinearization(ByRef samplesArr() As Double, cOption As Long LB2 = LBound(samplesArr, 2) UB2 = UBound(samplesArr, 2) ReDim tmpResult(LB To UB, LB2 To UB2) - For i = LB To UB + For I = LB To UB Select Case cOption Case 2, 3 'Exponential [y = a*e^(b*x) or y = a*b^x] - tmpResult(i, 1) = Log10(samplesArr(i, 1)) - tmpResult(i, 0) = samplesArr(i, 0) + tmpResult(I, 1) = Log10(samplesArr(I, 1)) + tmpResult(I, 0) = samplesArr(I, 0) Case 4 'Power [y = a*x^b] - tmpResult(i, 1) = Log10(samplesArr(i, 1)) - tmpResult(i, 0) = Log10(samplesArr(i, 0)) + tmpResult(I, 1) = Log10(samplesArr(I, 1)) + tmpResult(I, 0) = Log10(samplesArr(I, 0)) Case 5 'Logarithmic [y = a*ln(x) + b] - tmpResult(i, 1) = samplesArr(i, 1) - tmpResult(i, 0) = Log(samplesArr(i, 0)) 'LN + tmpResult(I, 1) = samplesArr(I, 1) + tmpResult(I, 0) = Log(samplesArr(I, 0)) 'LN End Select - Next i + Next I DataLinearization = tmpResult End Function @@ -2560,10 +2560,10 @@ End Function Public Sub DeclareUDF(ByRef UDFname As Variant, Optional ByRef UDFlib As String = "UserDefFunctions") If IsArray(UDFname) Then - Dim i As Long - For i = LBound(UDFname) To UBound(UDFname) - StoreUDF UserDefFunctions, CStr(UDFname(i)), UDFlib 'The Value member points to the function library - Next i + Dim I As Long + For I = LBound(UDFname) To UBound(UDFname) + StoreUDF UserDefFunctions, CStr(UDFname(I)), UDFlib 'The Value member points to the function library + Next I Else StoreUDF UserDefFunctions, CStr(UDFname), UDFlib End If @@ -2603,13 +2603,13 @@ Private Function Determinant(ByRef expression As String, ByRef fName As String) Dim aArray() As Double Dim pivotingIdx() As Long Dim d As Double 'Interchages parity - Dim i As Long + Dim I As Long aArray() = ToDblArray(ArrayFromString(tmpData(LB))) LUdecomp aArray(), pivotingIdx, d - For i = LBound(aArray) To UBound(aArray) - d = d * aArray(i, i) - Next i + For I = LBound(aArray) To UBound(aArray) + d = d * aArray(I, I) + Next I tmpEval = d Case Else tmpEval = e_ValueError @@ -2997,13 +2997,13 @@ err_Handler: d_lParenthesis & err.Description & d_rParenthesis End Function -Private Function FISHF_(f As Double, N1 As Double, N2 As Double) As Double +Private Function FISHF_(F As Double, N1 As Double, N2 As Double) As Double Dim x As Double, th As Double Dim A As Double, sth As Double Dim cth As Double, c As Double Dim k As Double - x = N2 / (N1 * f + N2) + x = N2 / (N1 * F + N2) If (REM_(N1, 2) = 0) Then FISHF_ = STATCOM(1 - x, N2, N1 + N2 - 4, N2 - 2) * (x ^ (N2 / 2)) Exit Function @@ -3012,7 +3012,7 @@ Private Function FISHF_(f As Double, N1 As Double, N2 As Double) As Double FISHF_ = 1 - STATCOM(x, N1, N1 + N2 - 4, N1 - 2) * ((1 - x) ^ (N1 / 2)) Exit Function End If - th = Atn(Sqr(N1 * f / N2)) + th = Atn(Sqr(N1 * F / N2)) A = th / PID2: sth = Sin(th): cth = Cos(th) If (N2 > 1) Then A = A + sth * cth * STATCOM(cth * cth, 2, N2 - 3, -1) / PID2 @@ -3172,31 +3172,31 @@ Private Function FormatNamedPredictors(ByRef strPredictorsNames As String, _ Dim savedPredNames() As String Dim s As Long Dim n As Long - Dim i As Long + Dim I As Long 'Split predictors names tmpData = Split(FormatLiteralString(strPredictorsNames, True), P_SEPARATORCHAR) n = UBound(tmpData) - LBound(tmpData) + 1 ReDim savedPredNames(0 To n - 1) - Do While i < n - If tmpData(i) <> vbNullString Then - If Not IsSavedPredictorName(tmpData(i), savedPredNames) Then - savedPredNames(s) = tmpData(i) + Do While I < n + If tmpData(I) <> vbNullString Then + If Not IsSavedPredictorName(tmpData(I), savedPredNames) Then + savedPredNames(s) = tmpData(I) s = s + 1 Else 'Duplicate predictor name Exit Function End If End If - i = i + 1 + I = I + 1 Loop tmpResult = strPredictorsInterList - For i = 0 To s - 1 + For I = 0 To s - 1 If namedToNominal Then - tmpResult = Replace(tmpResult, savedPredNames(i), "X" & CStr(i + 1)) + tmpResult = Replace(tmpResult, savedPredNames(I), "X" & CStr(I + 1)) Else - tmpResult = Replace(tmpResult, "X" & CStr(i + 1), savedPredNames(i)) + tmpResult = Replace(tmpResult, "X" & CStr(I + 1), savedPredNames(I)) End If - Next i + Next I Erase tmpData, savedPredNames If namedToNominal Then FormatNamedPredictors = FormatNumeredInteractions(tmpResult) @@ -3206,10 +3206,10 @@ Private Function FormatNamedPredictors(ByRef strPredictorsNames As String, _ End Function Private Function FormatNumeredInteractions(ByRef strPredictorsInterList As String) As String - Dim i As Long + Dim I As Long Dim n As Long Dim e As Long - Dim f As Long + Dim F As Long Dim u As String Dim v As String Dim tmpElem As String @@ -3218,21 +3218,21 @@ Private Function FormatNumeredInteractions(ByRef strPredictorsInterList As Strin tmpData = Split(FormatLiteralString(strPredictorsInterList, True), P_SEPARATORCHAR) n = UBound(tmpData) - LBound(tmpData) + 1 - For i = 0 To n - 1 - If Not tmpData(i) Like "[Xx]*#:[Xx]*#" Then Exit Function - tmpPredict = Split(tmpData(i), ChrW(58)) + For I = 0 To n - 1 + If Not tmpData(I) Like "[Xx]*#:[Xx]*#" Then Exit Function + tmpPredict = Split(tmpData(I), ChrW(58)) u = MidB(tmpPredict(0), 3) v = MidB(tmpPredict(1), 3) If Not IsNumeric(u) Or Not IsNumeric(v) Then Exit Function e = CLng(MidB(tmpPredict(0), 3)) - f = CLng(v) - If e > f Then + F = CLng(v) + If e > F Then tmpElem = tmpPredict(0) tmpPredict(0) = tmpPredict(1) tmpPredict(1) = tmpElem - tmpData(i) = Join(tmpPredict, ChrW(58)) + tmpData(I) = Join(tmpPredict, ChrW(58)) End If - Next i + Next I FormatNumeredInteractions = ToLiteralString(Join(tmpData, P_SEPARATORCHAR)) End Function @@ -3344,7 +3344,7 @@ Private Function fZeroMBM(ByRef aFunction As String, ByVal A As Double, _ Dim fa As Double, fb As Double Dim fc As Double, fd As Double Dim fEvalHelper As VBAexpressions - Dim i As Long + Dim I As Long Dim k As Double Dim segmentLen As Double Dim tmpFzeroEval As Double @@ -3364,12 +3364,12 @@ Private Function fZeroMBM(ByRef aFunction As String, ByVal A As Double, _ tmpVar() = Split(.CurrentVariables, "; ") varLB = LBound(tmpVar) If UBound(tmpVar) - varLB > 0 Then 'Reject multivariate functions - For i = varLB To UBound(tmpVar) - If Not IsConstant(tmpVar(i)) Then + For I = varLB To UBound(tmpVar) + If Not IsConstant(tmpVar(I)) Then varCounter = varCounter + 1 - varIdx = i + varIdx = I End If - Next i + Next I If varCounter > 1 Then fZeroMBM = e_ValueError Exit Function @@ -3464,7 +3464,7 @@ Private Function fZeroMRF(ByRef aFunction As String, ByVal A As Double, _ Dim fa As Double, fb As Double Dim fc As Double, fd As Double Dim fEvalHelper As VBAexpressions - Dim i As Long + Dim I As Long Dim k As Double, CK As Double Dim tmpVar() As String Dim toleranceFlag As Boolean @@ -3481,12 +3481,12 @@ Private Function fZeroMRF(ByRef aFunction As String, ByVal A As Double, _ tmpVar() = Split(.CurrentVariables, "; ") varLB = LBound(tmpVar) If UBound(tmpVar) - varLB > 0 Then 'Reject multivariate functions - For i = varLB To UBound(tmpVar) - If Not IsConstant(tmpVar(i)) Then + For I = varLB To UBound(tmpVar) + If Not IsConstant(tmpVar(I)) Then varCounter = varCounter + 1 - varIdx = i + varIdx = I End If - Next i + Next I If varCounter > 1 Then fZeroMRF = e_ValueError Exit Function @@ -3577,7 +3577,7 @@ End Function ''' ''' Value to compute the GAMMALN function from. Private Function GAMMALN_(x As Double) As Double - Dim j As Long + Dim J As Long Dim cof As Variant Dim ser As Double Dim xx As Double, y As Double @@ -3588,10 +3588,10 @@ Private Function GAMMALN_(x As Double) As Double y = x: xx = x tmp = x + 5.5 tmp = tmp - (xx + 0.5) * Log(tmp) - For j = LBound(cof) To UBound(cof) + For J = LBound(cof) To UBound(cof) y = y + 1 - ser = ser + cof(j) / (y) - Next j + ser = ser + cof(J) / (y) + Next J GAMMALN_ = Log(2.506628274631 * ser / xx) - tmp End Function @@ -3653,7 +3653,7 @@ Private Function get2DimArrayCopy(ByRef bArray() As Double) As Double() Dim tmpResult() As Double Dim isArray2D As Boolean Dim colDim As Long - Dim i As Long, j As Long + Dim I As Long, J As Long Dim LB As Long, UB As Long Dim LB2 As Long, UB2 As Long @@ -3667,15 +3667,15 @@ Private Function get2DimArrayCopy(ByRef bArray() As Double) As Double() End If ReDim tmpResult(0 To UB - LB, 0 To colDim) If isArray2D Then - For i = LB To UB - For j = LB2 To UB2 - tmpResult(0 + i - LB, 0 + j - LB2) = bArray(i, j) - Next j - Next i + For I = LB To UB + For J = LB2 To UB2 + tmpResult(0 + I - LB, 0 + J - LB2) = bArray(I, J) + Next J + Next I Else - For i = LB To UB - tmpResult(0 + i - LB, 0) = bArray(i) - Next i + For I = LB To UB + tmpResult(0 + I - LB, 0) = bArray(I) + Next I End If get2DimArrayCopy = tmpResult End Function @@ -3821,7 +3821,7 @@ Private Function GetArrItm(ByRef arr As Variant, ByRef MultiDimArr As Boolean, _ End Function Private Function GetCBItemIdx(ByRef cbBuffer As ClusterBuffer, ByRef ItemName As String) As Long - Dim i As Long + Dim I As Long Dim tmpResult As Boolean Dim tmpItemName As String @@ -3833,14 +3833,14 @@ Private Function GetCBItemIdx(ByRef cbBuffer As ClusterBuffer, ByRef ItemName As tmpItemName = ItemName End Select If cbBuffer.index > -1 Then - i = 0 + I = 0 Do - tmpResult = (cbBuffer.Storage(i).name = tmpItemName) - i = i + 1 - Loop While i <= cbBuffer.index And Not tmpResult + tmpResult = (cbBuffer.Storage(I).name = tmpItemName) + I = I + 1 + Loop While I <= cbBuffer.index And Not tmpResult End If If tmpResult Then - GetCBItemIdx = i - 1 + GetCBItemIdx = I - 1 Else GetCBItemIdx = -1 End If @@ -3897,9 +3897,11 @@ Private Function GetFunctionName(ByRef expression As String) As String For EFjCounter = LBound(FunctionsId) To UBound(FunctionsId) tmpPos = InStrB(1, ExpCopy, FunctionsId(EFjCounter)) If tmpPos Then - GFNbool = ValidFuntionName(ExpCopy, FunctionsId(EFjCounter), tmpPos) - If GFNbool Then - Exit For + If ExpCopy = FunctionsId(EFjCounter) Then + GFNbool = ValidFuntionName(ExpCopy, FunctionsId(EFjCounter), tmpPos) + If GFNbool Then + Exit For + End If End If End If Next EFjCounter @@ -3907,22 +3909,24 @@ Private Function GetFunctionName(ByRef expression As String) As String GetFunctionName = FunctionsName(EFjCounter) IsUDFFunction = False Else 'Check for UDFs - Dim i As Long - For i = 0 To UserDefFunctions.index - tmpPos = InStrB(1, ExpCopy, UserDefFunctions.Storage(i).name) + Dim I As Long + For I = 0 To UserDefFunctions.index + tmpPos = InStrB(1, ExpCopy, UserDefFunctions.Storage(I).name) If tmpPos Then - GFNbool = ValidFuntionName(ExpCopy, UserDefFunctions.Storage(i).name, tmpPos) - If GFNbool Then - Exit For + If ExpCopy = UserDefFunctions.Storage(I).name Then + GFNbool = ValidFuntionName(ExpCopy, UserDefFunctions.Storage(I).name, tmpPos) + If GFNbool Then + Exit For + End If End If End If - Next i + Next I IsUDFFunction = GFNbool If GFNbool Then - GetFunctionName = UserDefFunctions.Storage(i).name + GetFunctionName = UserDefFunctions.Storage(I).name Else - If expression Like "[A-Zaz]*{*}" Then 'Not defined function bypass - tmpPos = InStrB(1, expression, d_lCurly) + If expression Like "[A-Zaz]*[[]*[]]" Then 'Not defined function bypass + tmpPos = InStrB(1, expression, d_lSquareB) GetFunctionName = MidB$(expression, 1, tmpPos - 1) End If End If @@ -3933,9 +3937,9 @@ Private Function GetIndex(ByRef SubstStr As String) As Long Dim InitPos As Long Dim EndPos As Long - InitPos = InStrB(1, SubstStr, d_lCurly) + InitPos = InStrB(1, SubstStr, d_lSquareB) If InitPos Then - EndPos = InStrB(1, SubstStr, d_rCurly) + EndPos = InStrB(1, SubstStr, d_rSquareB) If EndPos Then GetIndex = MidB$(SubstStr, InitPos + 2, EndPos - InitPos - 2) Else @@ -4245,8 +4249,8 @@ Private Function GetPredInterArr(ByRef strPredictorsInterList As String, n As Lo Dim idx1 As Long Dim idx2 As Long Dim s As Long - Dim i As Long - Dim j As Long + Dim I As Long + Dim J As Long Dim m As Long Dim elemComb As Long Dim r As Double 'Sample of r elements @@ -4269,17 +4273,17 @@ Private Function GetPredInterArr(ByRef strPredictorsInterList As String, n As Lo idx1 = CLng(MidB(tmpPredict(LBound(tmpPredict)), 3)) idx2 = CLng(MidB(tmpPredict(LBound(tmpPredict) + 1), 3)) s = 0 - j = 0 + J = 0 Do While s < elemComb - i = 1 - j = j + 1 - Do While i <= j + I = 1 + J = J + 1 + Do While I <= J 'Check predictor "Xi.Xj" - If idx1 = i And idx2 = j Then + If idx1 = I And idx2 = J Then tmpResult(s) = True Exit Do End If - i = i + 1 + I = I + 1 s = s + 1 Loop Loop @@ -4297,26 +4301,26 @@ End Function Private Function GetPredInterNames(ByRef PredInterArr() As Boolean) As String Dim tmpResult As String Dim s As Long - Dim i As Long - Dim j As Long + Dim I As Long + Dim J As Long Dim elemComb As Long elemComb = UBound(PredInterArr) - LBound(PredInterArr) + 1 Do While s < elemComb - i = 1 - j = j + 1 - Do While i <= j + I = 1 + J = J + 1 + Do While I <= J 'Check predictor "Xi.Xj" If PredInterArr(s) Then If tmpResult <> vbNullString Then tmpResult = tmpResult & P_SEPARATORCHAR & _ - "X" & i & op_mult & "X" & j + "X" & I & op_mult & "X" & J Else - tmpResult = "X" & i & op_mult & "X" & j + tmpResult = "X" & I & op_mult & "X" & J End If End If - i = i + 1 + I = I + 1 s = s + 1 Loop Loop @@ -4445,7 +4449,7 @@ End Function ''' ''' Returns an array with all the sub expressions needed to -''' evaluate the given expression. A string such as {0} +''' evaluate the given expression. A string such as [0] ''' indicates that the current token should be evaluated using ''' the value or token residing at index 0 using functions ''' and arithmetic operators. @@ -4694,7 +4698,7 @@ Private Function GoodnessOfFit_(ByRef Polynomial As String, ByRef ObserArray() A Dim Rsquared As Double Dim seSquare As Double Dim stSquare As Double - Dim i As Long + Dim I As Long Dim n As Long n = UBound(ObserArray) - LBound(ObserArray) + 1 @@ -4702,11 +4706,11 @@ Private Function GoodnessOfFit_(ByRef Polynomial As String, ByRef ObserArray() A With exprHelper .Create Polynomial averageY = ColumnAvg(ObserArray, 1) 'Mean - For i = 0 To n - 1 - .Eval "x=" & CStr(ObserArray(i, 0)) - seSquare = seSquare + (ObserArray(i, 1) - CDbl(.Result)) ^ 2 'Partial sum squared regression - stSquare = stSquare + (averageY - ObserArray(i, 1)) ^ 2 'Partial total sum of squares - Next i + For I = 0 To n - 1 + .Eval "x=" & CStr(ObserArray(I, 0)) + seSquare = seSquare + (ObserArray(I, 1) - CDbl(.Result)) ^ 2 'Partial sum squared regression + stSquare = stSquare + (averageY - ObserArray(I, 1)) ^ 2 'Partial total sum of squares + Next I Rsquared = Round(1 - seSquare / stSquare, 4) End With GoodnessOfFit_ = Rsquared @@ -4783,15 +4787,15 @@ Private Function iBETAINV(p As Double, A As Double, B As Double) As Double Const EPS As Double = 0.00000001 Dim aL As Double Dim a1, b1 As Double - Dim j As Long + Dim J As Long Dim lna As Double, lnb As Double Dim pp As Double, t As Double Dim u As Double, err As Double - Dim x As Double, h As Double + Dim x As Double, H As Double Dim w As Double, afac As Double a1 = A - 1: b1 = B - 1 - j = 0 + J = 0 If p <= 0 Then iBETAINV = 0 Exit Function @@ -4810,9 +4814,9 @@ Private Function iBETAINV(p As Double, A As Double, B As Double) As Double x = (2.30753 + t * 0.27061) / (1 + t * (0.99229 + t * 0.04481)) - t If p < 0.5 Then x = -x aL = (x * x - 3) / 6 - h = 2 / (1 / (2 * A - 1) + 1 / (2 * B - 1)) - w = (x * Sqr(aL + h) / h) - (1 / (2 * B - 1) - 1 / (2 * A - 1)) * _ - (aL + 5 / 6 - 2 / (3 * h)) + H = 2 / (1 / (2 * A - 1) + 1 / (2 * B - 1)) + w = (x * Sqr(aL + H) / H) - (1 / (2 * B - 1) - 1 / (2 * A - 1)) * _ + (aL + 5 / 6 - 2 / (3 * H)) x = A / (A + B * Exp(2 * w)) Else lna = Log(A / (A + B)): lnb = Log(B / (A + B)) @@ -4825,17 +4829,17 @@ Private Function iBETAINV(p As Double, A As Double, B As Double) As Double End If End If afac = -GAMMALN_(A) - GAMMALN_(B) + GAMMALN_(A + B) - Do While j < 10 + Do While J < 10 If x = 0 Or x = 1 Then iBETAINV = x: Exit Function err = iBETA_(x, A, B) - p t = Exp(a1 * Log(x) + b1 * Log(1 - x) + afac) u = err / t - t = u / (1 - 0.5 * Min(1, u * (a1 / x - b1 / (1 - x)))) + t = u / (1 - 0.5 * MIN_(1, u * (a1 / x - b1 / (1 - x)))) x = x - t If x <= 0 Then x = 0.5 * (x + t) If x >= 1 Then x = 0.5 * (x + t + 1) - If Abs(t) < EPS * x And j > 0 Then Exit Do - j = j + 1 + If Abs(t) < EPS * x And J > 0 Then Exit Do + J = J + 1 Loop iBETAINV = x End Function @@ -5193,15 +5197,15 @@ Private Function IsPlusOrMinus(ByRef Char As String) As Boolean End Function Private Function IsSavedPredictorName(ByRef aName As String, ByRef aNamesList() As String) As Boolean - Dim i As Long + Dim I As Long Dim tmpResult As Boolean Dim n As Long n = UBound(aNamesList) - i = LBound(aNamesList) - Do While Not tmpResult And i <= n - tmpResult = (aName = aNamesList(i)) - i = i + 1 + I = LBound(aNamesList) + Do While Not tmpResult And I <= n + tmpResult = (aName = aNamesList(I)) + I = I + 1 Loop IsSavedPredictorName = tmpResult End Function @@ -5234,7 +5238,7 @@ Private Function JoinArrFunctArg(ByRef DecompArray() As String, ByRef MapedIdx() Dim tmpArray As String Dim MaxRowIndex As Long Dim MaxColIndex As Long - Dim i As Long, j As Long + Dim I As Long, J As Long Dim k As Long Dim UB As Long Dim wIdx As Long @@ -5249,42 +5253,42 @@ Private Function JoinArrFunctArg(ByRef DecompArray() As String, ByRef MapedIdx() MaxColIndex = 0 End If tmpArray = vbNullString - For i = 0 To MaxRowIndex + For I = 0 To MaxRowIndex If MapedIdx(k + 1) <> -3 And MaxColIndex > 0 Then - For j = 0 To MaxColIndex - If j = 0 Then + For J = 0 To MaxColIndex + If J = 0 Then tmpArray = tmpArray & d_lCurly & _ - DecompArray(j + (i * (MaxColIndex + 1)) + wIdx) + DecompArray(J + (I * (MaxColIndex + 1)) + wIdx) Else - tmpArray = tmpArray & P_SEPARATORCHAR & DecompArray(j + (i * (MaxColIndex + 1)) + wIdx) + tmpArray = tmpArray & P_SEPARATORCHAR & DecompArray(J + (I * (MaxColIndex + 1)) + wIdx) End If - If j = MaxColIndex Then + If J = MaxColIndex Then tmpArray = tmpArray & d_rCurly End If - Next j + Next J Else - If i = 0 Then - tmpArray = tmpArray & d_lCurly & DecompArray((i * (MaxColIndex + 1)) + wIdx) + If I = 0 Then + tmpArray = tmpArray & d_lCurly & DecompArray((I * (MaxColIndex + 1)) + wIdx) Else - tmpArray = tmpArray & DecompArray((i * (MaxColIndex + 1)) + wIdx) + tmpArray = tmpArray & DecompArray((I * (MaxColIndex + 1)) + wIdx) End If - If i = MaxRowIndex Then + If I = MaxRowIndex Then tmpArray = tmpArray & d_rCurly End If End If - If i < MaxRowIndex Then + If I < MaxRowIndex Then tmpArray = tmpArray & P_SEPARATORCHAR End If - Next i + Next I If MapedIdx(k + 1) <> -3 Then tmpArray = d_lCurly & tmpArray & d_rCurly If MaxColIndex > 0 Then - wIdx = wIdx + i * j + wIdx = wIdx + I * J Else - wIdx = wIdx + i + wIdx = wIdx + I End If Else - wIdx = wIdx + i + wIdx = wIdx + I End If tmpResult = tmpResult & tmpArray k = k + 1 @@ -5461,10 +5465,10 @@ Private Sub LUbkSub(ByRef A() As Double, ByRef indx() As Long, ByRef B() As Doub ' Numerical recipes in C: the art of scientific computing / William H. Press [et al.] ' - 2nd ed. (p.47) '----------------------------------------------------------------------------------------- - Dim i As Long + Dim I As Long Dim ii As Long Dim ip As Long - Dim j As Long + Dim J As Long Dim n As Long Dim pSum As Double Dim aLB As Long @@ -5476,26 +5480,26 @@ Private Sub LUbkSub(ByRef A() As Double, ByRef indx() As Long, ByRef B() As Doub bLB = LBound(B) n = aUB - aLB + 1 ii = 0 - For i = 1 To n - ip = indx(i) + For I = 1 To n + ip = indx(I) pSum = B(ip + bLB - 1) - B(ip + bLB - 1) = B(i + bLB - 1) + B(ip + bLB - 1) = B(I + bLB - 1) If ii Then - For j = ii To i - 1 - pSum = pSum - A(i + aLB - 1, j + aLB - 1) * B(j + bLB - 1) - Next j + For J = ii To I - 1 + pSum = pSum - A(I + aLB - 1, J + aLB - 1) * B(J + bLB - 1) + Next J ElseIf pSum Then - ii = i + ii = I End If - B(i + bLB - 1) = pSum - Next i - For i = n To 1 Step -1 - pSum = B(i + bLB - 1) - For j = i + 1 To n - pSum = pSum - A(i + aLB - 1, j + aLB - 1) * B(j + bLB - 1) - Next j - B(i + bLB - 1) = pSum / A(i + aLB - 1, i + aLB - 1) - Next i + B(I + bLB - 1) = pSum + Next I + For I = n To 1 Step -1 + pSum = B(I + bLB - 1) + For J = I + 1 To n + pSum = pSum - A(I + aLB - 1, J + aLB - 1) * B(J + bLB - 1) + Next J + B(I + bLB - 1) = pSum / A(I + aLB - 1, I + aLB - 1) + Next I End Sub ''' @@ -5515,9 +5519,9 @@ Private Sub LUdecomp(ByRef A() As Double, ByRef indx() As Long, _ ' - 2nd ed. (p.46-47) '----------------------------------------------------------------------------------------- Dim n As Long - Dim i As Long + Dim I As Long Dim imax As Long - Dim j As Long + Dim J As Long Dim k As Long Dim big As Double Dim dum As Double @@ -5533,59 +5537,59 @@ Private Sub LUdecomp(ByRef A() As Double, ByRef indx() As Long, _ ReDim vv(1 To n) ReDim indx(1 To n) d = 1 'No row interchanges yet - For i = 1 To n 'Loop rows to get the implicit scaling information + For I = 1 To n 'Loop rows to get the implicit scaling information big = 0 - For j = 1 To n - temp = Abs(A(i + aLB - 1, j + aLB - 1)) + For J = 1 To n + temp = Abs(A(I + aLB - 1, J + aLB - 1)) If temp > big Then big = temp - Next j + Next J If big = 0 Then 'a is a singular matrix Exit Sub End If 'No nonzero largest element - vv(i) = 1 / big 'Save the scaling - Next i - For j = 1 To n 'Loop over columns of Crout's method - For i = 1 To j - 1 - pSum = A(i + aLB - 1, j + aLB - 1) - For k = 1 To i - 1 - pSum = pSum - A(i + aLB - 1, k + aLB - 1) * A(k + aLB - 1, j + aLB - 1) + vv(I) = 1 / big 'Save the scaling + Next I + For J = 1 To n 'Loop over columns of Crout's method + For I = 1 To J - 1 + pSum = A(I + aLB - 1, J + aLB - 1) + For k = 1 To I - 1 + pSum = pSum - A(I + aLB - 1, k + aLB - 1) * A(k + aLB - 1, J + aLB - 1) Next k - A(i + aLB - 1, j + aLB - 1) = pSum - Next i + A(I + aLB - 1, J + aLB - 1) = pSum + Next I big = 0 'Initialize for search the largest pivot element - For i = j To n - pSum = A(i + aLB - 1, j + aLB - 1) - For k = 1 To j - 1 - pSum = pSum - A(i + aLB - 1, k + aLB - 1) * A(k + aLB - 1, j + aLB - 1) + For I = J To n + pSum = A(I + aLB - 1, J + aLB - 1) + For k = 1 To J - 1 + pSum = pSum - A(I + aLB - 1, k + aLB - 1) * A(k + aLB - 1, J + aLB - 1) Next k - A(i + aLB - 1, j + aLB - 1) = pSum - dum = vv(i) * Abs(pSum) + A(I + aLB - 1, J + aLB - 1) = pSum + dum = vv(I) * Abs(pSum) If dum >= big Then big = dum - imax = i + imax = I End If - Next i - If j <> imax Then 'Need rows interchange? + Next I + If J <> imax Then 'Need rows interchange? For k = 1 To n dum = A(imax + aLB - 1, k + aLB - 1) - A(imax + aLB - 1, k + aLB - 1) = A(j + aLB - 1, k + aLB - 1) - A(j + aLB - 1, k + aLB - 1) = dum + A(imax + aLB - 1, k + aLB - 1) = A(J + aLB - 1, k + aLB - 1) + A(J + aLB - 1, k + aLB - 1) = dum Next k d = -1 * d 'Change parity - vv(imax) = vv(j) 'Change scale factor + vv(imax) = vv(J) 'Change scale factor End If - indx(j) = imax - If A(j + aLB - 1, j + aLB - 1) = 0 Then 'Avoid division by zero in singular matrix - A(j + aLB - 1, j + aLB - 1) = Tiny + indx(J) = imax + If A(J + aLB - 1, J + aLB - 1) = 0 Then 'Avoid division by zero in singular matrix + A(J + aLB - 1, J + aLB - 1) = Tiny End If - If j <> n Then 'Divide by the pivot element - dum = 1 / A(j + aLB - 1, j + aLB - 1) - For i = j + 1 To n - A(i + aLB - 1, j + aLB - 1) = A(i + aLB - 1, j + aLB - 1) * dum - Next i + If J <> n Then 'Divide by the pivot element + dum = 1 / A(J + aLB - 1, J + aLB - 1) + For I = J + 1 To n + A(I + aLB - 1, J + aLB - 1) = A(I + aLB - 1, J + aLB - 1) * dum + Next I End If - Next j + Next J Erase vv End Sub @@ -5709,7 +5713,7 @@ Private Function LUsolve_(ByRef aArray() As Double, ByRef bArray() As Double) As End Function Private Function Max(ByRef expression As String, ByRef fName As String) As String - Dim g As Long + Dim G As Long Dim tmpData() As String Dim tmpEval As Double Dim compEval As Double @@ -5717,12 +5721,12 @@ Private Function Max(ByRef expression As String, ByRef fName As String) As Strin On Error GoTo err_Handler tmpData() = SplitArgs(expression) tmpEval = CDbl(tmpData(LBound(tmpData))) - For g = LBound(tmpData) + 1 To UBound(tmpData) - compEval = CDbl(tmpData(g)) + For G = LBound(tmpData) + 1 To UBound(tmpData) + compEval = CDbl(tmpData(G)) If compEval > tmpEval Then tmpEval = compEval End If - Next g + Next G Max = CStr(tmpEval): Erase tmpData Exit Function err_Handler: @@ -5732,16 +5736,16 @@ err_Handler: End Function Private Function MAX_(ParamArray aList() As Variant) As Double - Dim i As Long + Dim I As Long Dim tmpResult As Double Dim tmpEl As Double - i = LBound(aList) - tmpResult = CDbl(aList(i)) - For i = i + 1 To UBound(aList) - tmpEl = CDbl(aList(i)) + I = LBound(aList) + tmpResult = CDbl(aList(I)) + For I = I + 1 To UBound(aList) + tmpEl = CDbl(aList(I)) If tmpEl > tmpResult Then tmpResult = tmpEl - Next i + Next I MAX_ = tmpResult End Function @@ -5785,7 +5789,7 @@ err_Handler: End Function Private Function Min(ByRef expression As String, ByRef fName As String) As String - Dim g As Long + Dim G As Long Dim tmpData() As String Dim tmpEval As Double Dim compEval As Double @@ -5793,12 +5797,12 @@ Private Function Min(ByRef expression As String, ByRef fName As String) As Strin On Error GoTo err_Handler tmpData() = SplitArgs(expression) tmpEval = CDbl(tmpData(LBound(tmpData))) - For g = LBound(tmpData) + 1 To UBound(tmpData) - compEval = CDbl(tmpData(g)) + For G = LBound(tmpData) + 1 To UBound(tmpData) + compEval = CDbl(tmpData(G)) If compEval < tmpEval Then tmpEval = compEval End If - Next g + Next G Min = CStr(tmpEval): Erase tmpData Exit Function err_Handler: @@ -5868,8 +5872,8 @@ Private Function MInverse_(ByRef A() As Double, ByRef indx() As Long, _ '----------------------------------------------------------------------------------------- Dim y() As Double Dim col() As Double - Dim i As Long - Dim j As Long + Dim I As Long + Dim J As Long Dim aUB As Long Dim aLB As Long Dim n As Long @@ -5880,31 +5884,31 @@ Private Function MInverse_(ByRef A() As Double, ByRef indx() As Long, _ ReDim y(0 To n - 1, 0 To n - 1) ReDim col(1 To n) LUdecomp A, indx, d - For j = 1 To n - For i = 1 To n - col(i) = 0 - Next i - col(j) = 1 + For J = 1 To n + For I = 1 To n + col(I) = 0 + Next I + col(J) = 1 LUbkSub A, indx, col - For i = 1 To n - If Abs(col(i)) = 0 Then col(i) = 0 'Avoid VBA -0 value - y(i - 1, j - 1) = col(i) - Next i - Next j + For I = 1 To n + If Abs(col(I)) = 0 Then col(I) = 0 'Avoid VBA -0 value + y(I - 1, J - 1) = col(I) + Next I + Next J MInverse_ = y End Function Private Function MIN_(ParamArray aList() As Variant) As Double - Dim i As Long + Dim I As Long Dim tmpResult As Double Dim tmpEl As Double - i = LBound(aList) - tmpResult = CDbl(aList(i)) - For i = i + 1 To UBound(aList) - tmpEl = CDbl(aList(i)) + I = LBound(aList) + tmpResult = CDbl(aList(I)) + For I = I + 1 To UBound(aList) + tmpEl = CDbl(aList(I)) If tmpEl < tmpResult Then tmpResult = tmpEl - Next i + Next I MIN_ = tmpResult End Function @@ -5945,7 +5949,7 @@ err_Handler: End Function ''' -''' Performs a multiple linear regression over a model with more than to regressors/predictors. +''' Performs a multiple linear regression over a model with more than two regressors/predictors. ''' The parameters required by the functions are: ''' 1- X: the model NxK matrix with K regressors variables for all the N observations. ''' 2- Y: a Nx1 vector with N observations for the model. @@ -6053,7 +6057,7 @@ Private Function MLR_(x() As Double, y() As Double, Optional k As Long = -1, _ Dim p As Long Dim SSE As Double Dim SST As Double - Dim i As Long + Dim I As Long Dim tmpY() As Double If Not Is2Darray(y) Then @@ -6073,10 +6077,10 @@ Private Function MLR_(x() As Double, y() As Double, Optional k As Long = -1, _ yhat = ToDblArray(MMULT_(x, Betahat)) 'Predictions e = MSum_(tmpY, yhat, True) 'Residuals ymean = ColumnAvg(y) - For i = 0 To n - 1 - SSE = SSE + e(i, 0) ^ 2 - SST = SST + (y(i) - ymean) ^ 2 - Next i + For I = 0 To n - 1 + SSE = SSE + e(I, 0) ^ 2 + SST = SST + (y(I) - ymean) ^ 2 + Next I If n > p Then sigmaSquared = SSE / (n - p) 'Squared standard error Else @@ -6144,8 +6148,8 @@ Private Function MMULT_(ByRef A() As Double, ByRef B As Variant) As Variant Dim bLB As Long, bLB2 As Long Dim bUB As Long, bUB2 As Long Dim c() As Double - Dim i As Long - Dim j As Long, jj As Long + Dim I As Long + Dim J As Long, jj As Long Dim m As Long Dim n As Long Dim OutputIsArray As Boolean @@ -6160,9 +6164,9 @@ Private Function MMULT_(ByRef A() As Double, ByRef B As Variant) As Variant n = aUB2 - aLB2 + 1 m = bUB2 - bLB2 + 1 If m = n Then 'Require equal columns count - For i = 0 To n - 1 'Loop a() rows - pSum = pSum + A(aLB2 + i) * B(bLB2 + i) - Next i + For I = 0 To n - 1 'Loop a() rows + pSum = pSum + A(aLB2 + I) * B(bLB2 + I) + Next I OutputIsArray = False End If ElseIf (aIsVector And Not IsArray(B)) Or _ @@ -6172,34 +6176,34 @@ Private Function MMULT_(ByRef A() As Double, ByRef B As Variant) As Variant aLB = LBound(A): aUB = UBound(A) m = aUB - aLB + 1 ReDim c(0 To m - 1) - For i = 0 To m - 1 - c(i) = A(aLB + i) * B - Next i + For I = 0 To m - 1 + c(I) = A(aLB + I) * B + Next I Else aLB = LBound(A): aUB = UBound(A) aLB2 = LBound(A, 2): aUB2 = UBound(A, 2) n = aUB - aLB + 1 m = aUB2 - aLB2 + 1 ReDim c(0 To n - 1, 0 To m - 1) - For i = 0 To n - 1 - For j = 0 To m - 1 - c(i, j) = A(aLB + i, aLB2 + j) * B - Next j - Next i + For I = 0 To n - 1 + For J = 0 To m - 1 + c(I, J) = A(aLB + I, aLB2 + J) * B + Next J + Next I End If End If ElseIf aIsVector And IsArray(B) Then '1D array x 2D array VM_DOT_ A, B, aLB, aLB2, aUB, _ - aUB2, bLB2, bUB2, c, i, j, _ + aUB2, bLB2, bUB2, c, I, J, _ m, n, pSum, bLB, bUB, jj ElseIf Not aIsVector And Not bIsVector Then '2D array x 2D array MM_DOT_ A, B, aLB, aLB2, aUB, _ aUB2, bLB, bLB2, bUB, _ - bUB2, c, i, j, jj, m, n, pSum + bUB2, c, I, J, jj, m, n, pSum ElseIf Not aIsVector And bIsVector Then '2D array x 1D array MV_DOT_ A, B, aLB, aLB2, aUB, _ aUB2, bLB, bLB2, bUB, _ - bUB2, c, i, j, jj, m, n, pSum + bUB2, c, I, J, jj, m, n, pSum End If If OutputIsArray Then If IsArrayAllocated(c) Then @@ -6214,7 +6218,7 @@ End Function Private Sub MM_DOT_(ByRef A() As Double, ByRef B As Variant, ByRef aLB As Long, ByRef aLB2 As Long, ByRef aUB As Long, _ ByRef aUB2 As Long, ByRef bLB As Long, ByRef bLB2 As Long, ByRef bUB As Long, ByRef bUB2 As Long, _ - ByRef c() As Double, ByRef i As Long, ByRef j As Long, ByRef jj As Long, ByRef m As Long, _ + ByRef c() As Double, ByRef I As Long, ByRef J As Long, ByRef jj As Long, ByRef m As Long, _ ByRef n As Long, ByRef pSum As Double) aLB = LBound(A): aUB = UBound(A) @@ -6225,15 +6229,15 @@ Private Sub MM_DOT_(ByRef A() As Double, ByRef B As Variant, ByRef aLB As Long, m = bUB2 - bLB2 + 1 If Not (aUB2 - aLB2 + 1) <> (bUB - bLB + 1) Then ReDim c(0 To n - 1, 0 To m - 1) - For i = 0 To n - 1 - For j = 0 To m - 1 + For I = 0 To n - 1 + For J = 0 To m - 1 pSum = 0 For jj = 0 To aUB2 - aLB2 - pSum = pSum + A(aLB + i, aLB2 + jj) * B(bLB + jj, bLB2 + j) + pSum = pSum + A(aLB + I, aLB2 + jj) * B(bLB + jj, bLB2 + J) Next jj - c(i, j) = pSum - Next j - Next i + c(I, J) = pSum + Next J + Next I End If End Sub @@ -6274,7 +6278,7 @@ Private Function MNEG_(ByRef aMatrix() As Double) As Double() Dim mLB2 As Long Dim mUB As Long Dim mUB2 As Long - Dim i As Long, j As Long + Dim I As Long, J As Long Dim ii As Long, jj As Long Dim tmpResult() As Double @@ -6285,18 +6289,18 @@ Private Function MNEG_(ByRef aMatrix() As Double) As Double() mLB2 = LBound(aMatrix, 2) mUB2 = UBound(aMatrix, 2) ReDim tmpResult(0 To mUB - mLB, 0 To mUB2 - mLB2) - For i = mLB To mUB + For I = mLB To mUB jj = 0 - For j = mLB2 To mUB2 - If Abs(aMatrix(i, j)) Then tmpResult(ii, jj) = -1 * aMatrix(i, j) + For J = mLB2 To mUB2 + If Abs(aMatrix(I, J)) Then tmpResult(ii, jj) = -1 * aMatrix(I, J) jj = jj + 1 - Next j + Next J ii = ii + 1 - Next i + Next I Else ReDim tmpResult(0 To mUB - mLB) - For i = mLB To mUB - If Abs(aMatrix(i, j)) Then tmpResult(ii) = -1 * aMatrix(i) + For I = mLB To mUB + If Abs(aMatrix(I, J)) Then tmpResult(ii) = -1 * aMatrix(I) ii = ii + 1 Next End If @@ -6398,7 +6402,7 @@ err_Handler: End Function Private Function MROUND_(ByRef aArray() As Double, Optional nDigits As Long = 0) As Double() - Dim i As Long, j As Long + Dim I As Long, J As Long Dim LB1 As Long, LB2 As Long Dim UB1 As Long, UB2 As Long Dim tmpResult() As Double @@ -6407,17 +6411,17 @@ Private Function MROUND_(ByRef aArray() As Double, Optional nDigits As Long = 0) UB1 = UBound(aArray): LB1 = LBound(aArray) UB2 = UBound(aArray, 2): LB2 = LBound(aArray, 2) ReDim tmpResult(0 To UB1 - LB1, 0 To UB2 - LB2) - For i = LB1 To UB1 - For j = LB2 To UB2 - tmpResult(i - LB1, j - LB2) = Round(aArray(i, j), nDigits) - Next j - Next i + For I = LB1 To UB1 + For J = LB2 To UB2 + tmpResult(I - LB1, J - LB2) = Round(aArray(I, J), nDigits) + Next J + Next I Else UB1 = UBound(aArray): LB1 = LBound(aArray) ReDim tmpResult(0 To UB1 - LB1) - For i = LB1 To UB1 - tmpResult(i - LB1) = Round(aArray(i), nDigits) - Next i + For I = LB1 To UB1 + tmpResult(I - LB1) = Round(aArray(I), nDigits) + Next I End If MROUND_ = tmpResult End Function @@ -6471,8 +6475,8 @@ Private Function MSum_(ByRef A() As Double, ByRef B() As Double, _ Dim LBb2 As Long Dim m As Long Dim n As Long - Dim i As Long - Dim j As Long + Dim I As Long + Dim J As Long Dim pSum As Double Dim aFlag As Boolean Dim bFlag As Boolean @@ -6490,29 +6494,29 @@ Private Function MSum_(ByRef A() As Double, ByRef B() As Double, _ If UBb - LBb + 1 <> n Then Exit Function 'Required equal numbers of rows If UBound(B, 2) - LBb2 + 1 <> m Then Exit Function 'Required equal numbers of columns ReDim c(0 To n - 1, 0 To m - 1) - For i = 0 To n - 1 - For j = 0 To m - 1 + For I = 0 To n - 1 + For J = 0 To m - 1 If Not Difference Then - pSum = A(i + LBa, j + LBa2) + B(i + LBb, j + LBb2) + pSum = A(I + LBa, J + LBa2) + B(I + LBb, J + LBb2) Else - pSum = A(i + LBa, j + LBa2) - B(i + LBb, j + LBb2) + pSum = A(I + LBa, J + LBa2) - B(I + LBb, J + LBb2) End If - c(i, j) = pSum - Next j - Next i + c(I, J) = pSum + Next J + Next I Else If Not aFlag And Not bFlag Then 'Two vectors n = UBound(A) - LBa + 1 If UBb - LBb + 1 <> n Then Exit Function ReDim c(0 To n - 1) - For i = 0 To n - 1 + For I = 0 To n - 1 If Not Difference Then - pSum = A(i + LBa) + B(i + LBb) + pSum = A(I + LBa) + B(I + LBb) Else - pSum = A(i + LBa) - B(i + LBb) + pSum = A(I + LBa) - B(I + LBb) End If - c(i) = pSum - Next i + c(I) = pSum + Next I Else 'One vector and one 2D matrix Dim M2D() As Double Dim VECT1D() As Double @@ -6547,18 +6551,18 @@ Private Function MSum_(ByRef A() As Double, ByRef B() As Double, _ n = ubV1D - lbV1D + 1 If ubM2D - lbM2D + 1 <> n Then Exit Function ReDim c(0 To n - 1) - For i = 0 To n - 1 + For I = 0 To n - 1 If Not Difference Then - pSum = M2D(i + lbM2D, lb2M2D) + VECT1D(i + lbV1D) + pSum = M2D(I + lbM2D, lb2M2D) + VECT1D(I + lbV1D) Else 'Always compute A-B If Not invertedSumFlag Then - pSum = M2D(i + lbM2D, lb2M2D) - VECT1D(i + lbV1D) + pSum = M2D(I + lbM2D, lb2M2D) - VECT1D(I + lbV1D) Else - pSum = VECT1D(i + lbV1D) - M2D(i + lbM2D, lb2M2D) + pSum = VECT1D(I + lbV1D) - M2D(I + lbM2D, lb2M2D) End If End If - c(i) = pSum - Next i + c(I) = pSum + Next I End If End If End If @@ -6603,8 +6607,8 @@ Private Function MTranspose_(ByRef A() As Double) As Double() Dim UBa2 As Long Dim m As Long Dim n As Long - Dim i As Long - Dim j As Long + Dim I As Long + Dim J As Long Dim Is1Darray As Boolean Is1Darray = Not Is2Darray(A) @@ -6623,22 +6627,22 @@ Private Function MTranspose_(ByRef A() As Double) As Double() n = UBa - LBa + 1 m = UBa2 - LBa2 + 1 ReDim c(0 To m - 1, 0 To n - 1) - For i = 0 To n - 1 - For j = 0 To m - 1 + For I = 0 To n - 1 + For J = 0 To m - 1 If Not Is1Darray Then - c(j, i) = A(LBa + i, LBa2 + j) + c(J, I) = A(LBa + I, LBa2 + J) Else - c(j, i) = A(LBa + j) + c(J, I) = A(LBa + J) End If - Next j - Next i + Next J + Next I MTranspose_ = c End Function Private Sub MV_DOT_(ByRef A() As Double, ByVal B As Variant, ByVal aLB As Long, ByVal aLB2 As Long, _ ByVal aUB As Long, ByVal aUB2 As Long, ByVal bLB As Long, ByVal bLB2 As Long, _ - ByVal bUB As Long, ByVal bUB2 As Long, ByRef c() As Double, ByVal i As Long, _ - ByVal j As Long, ByVal jj As Long, ByVal m As Long, ByVal n As Long, ByRef pSum As Double) + ByVal bUB As Long, ByVal bUB2 As Long, ByRef c() As Double, ByVal I As Long, _ + ByVal J As Long, ByVal jj As Long, ByVal m As Long, ByVal n As Long, ByRef pSum As Double) aLB = LBound(A): aUB = UBound(A) aLB2 = LBound(A, 2): aUB2 = UBound(A, 2) @@ -6648,15 +6652,15 @@ Private Sub MV_DOT_(ByRef A() As Double, ByVal B As Variant, ByVal aLB As Long, m = bUB2 - bLB2 + 1 If Not (aUB2 - aLB2 + 1) <> (bUB - bLB + 1) Then ReDim c(0 To n - 1, 0 To m - 1) - For i = 0 To n - 1 - For j = 0 To m - 1 + For I = 0 To n - 1 + For J = 0 To m - 1 pSum = 0 For jj = 0 To aUB2 - aLB2 - pSum = pSum + A(aLB + i, aLB2 + jj) * B(bLB2 + j) + pSum = pSum + A(aLB + I, aLB2 + jj) * B(bLB2 + J) Next jj - c(i, j) = pSum - Next j - Next i + c(I, J) = pSum + Next J + Next I End If End Sub @@ -6816,16 +6820,16 @@ err_Handler: End Function Private Function OPsymbolInArgument(ByRef ArgDefStr As String, ByRef Pattrn As String) As Boolean - Dim i As Long + Dim I As Long Dim tmpResult As Boolean Dim LenStr As Long - i = 1 + I = 1 LenStr = LenB(ArgDefStr) Do - tmpResult = InStrB(1, MidB$(ArgDefStr, i, 2), Pattrn) - i = i + 2 - Loop While i <= LenStr And Not tmpResult + tmpResult = InStrB(1, MidB$(ArgDefStr, I, 2), Pattrn) + I = I + 2 + Loop While I <= LenStr And Not tmpResult OPsymbolInArgument = tmpResult End Function @@ -7075,7 +7079,7 @@ End Function Private Function PolyFit_(ByRef samplesArr() As Double, pDegree As Long, _ Optional stringOutput As Boolean = True) As Variant Dim observCount As Long - Dim i As Long + Dim I As Long Dim mLB As Long Dim mUB As Long Dim modelArray() As Double @@ -7090,15 +7094,15 @@ Private Function PolyFit_(ByRef samplesArr() As Double, pDegree As Long, _ 'Create arrays ReDim modelArray(0 To observCount - 1, 0 To 0) ReDim responseArray(0 To observCount - 1, 0 To 0) - For i = 0 To observCount - 1 - modelArray(i, 0) = samplesArr(i, 0) - responseArray(i, 0) = samplesArr(i, 1) - Next i + For I = 0 To observCount - 1 + modelArray(I, 0) = samplesArr(I, 0) + responseArray(I, 0) = samplesArr(I, 1) + Next I 'Create degrees vector ReDim pDegreesArr(0 To pDegree - 1) - For i = 0 To pDegree - 1 - pDegreesArr(i) = i + 1 - Next i + For I = 0 To pDegree - 1 + pDegreesArr(I) = I + 1 + Next I 'Add polynomial substitutions predictors AddExponentialPredictors modelArray, pDegreesArr 'Add columns of ones @@ -7119,26 +7123,26 @@ End Function ''' NOTE: PolyFit helper ''' Private Function PolyString(ByRef SolverResult() As Double, ByRef pDegree As Long) As String - Dim i As Long + Dim I As Long Dim tmpResult As String - For i = 0 To pDegree - If i = 0 Then - tmpResult = CStr(Round(SolverResult(i, 0), 4)) + For I = 0 To pDegree + If I = 0 Then + tmpResult = CStr(Round(SolverResult(I, 0), 4)) Else - If CDbl(SolverResult(i, 0)) > 0 Then + If CDbl(SolverResult(I, 0)) > 0 Then tmpResult = tmpResult & d_Space & op_plus _ - & d_Space & Round(SolverResult(i, 0), 4) + & d_Space & Round(SolverResult(I, 0), 4) Else - tmpResult = tmpResult & d_Space & Round(SolverResult(i, 0), 4) + tmpResult = tmpResult & d_Space & Round(SolverResult(I, 0), 4) End If - If i > 1 Then - tmpResult = tmpResult & "*x^" & i + If I > 1 Then + tmpResult = tmpResult & "*x^" & I Else tmpResult = tmpResult & "*x" End If End If - Next i + Next I PolyString = tmpResult End Function @@ -7306,7 +7310,7 @@ End Function '# QR DECOMPOSITION '/////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// Private Sub QR_(ByRef A As Variant, Optional PositiveDiag As Boolean = False) - Dim i As Long, j As Long + Dim I As Long, J As Long Dim k As Long Dim s As Double Dim nrm As Double @@ -7319,29 +7323,29 @@ Private Sub QR_(ByRef A As Variant, Optional PositiveDiag As Boolean = False) For k = 0 To n - 1 '// Compute 2-norm of k-th column without under/overflow. nrm = 0 - For i = k To m - 1 - nrm = QR_hypot(nrm, QR(i, k)) - Next i + For I = k To m - 1 + nrm = QR_hypot(nrm, QR(I, k)) + Next I If nrm <> 0 Then '// Form k-th Householder vector. If (QR(k, k) < 0) Then nrm = -nrm End If - For i = k To m - 1 - QR(i, k) = QR(i, k) / nrm - Next i + For I = k To m - 1 + QR(I, k) = QR(I, k) / nrm + Next I QR(k, k) = QR(k, k) + 1# '// Apply transformation to remaining columns. - For j = k + 1 To n - 1 + For J = k + 1 To n - 1 s = 0# - For i = k To m - 1 - s = s + QR(i, k) * QR(i, j) - Next i + For I = k To m - 1 + s = s + QR(I, k) * QR(I, J) + Next I s = -s / QR(k, k) - For i = k To m - 1 - QR(i, j) = QR(i, j) + s * QR(i, k) - Next i - Next j + For I = k To m - 1 + QR(I, J) = QR(I, J) + s * QR(I, k) + Next I + Next J End If rDiag(k) = -nrm signFlip(k) = (rDiag(k) < 0) And PositiveDiag @@ -7352,20 +7356,20 @@ End Sub ' @return Lower trapezoidal matrix whose columns define the reflections ' */ Private Function QR_getH() As Double() - Dim h() As Double - Dim i As Long, j As Long - - ReDim h(0 To m - 1, 0 To n - 1) - For i = 0 To m - 1 - For j = 0 To n - 1 - If i >= j Then - h(i, j) = QR(i, j) + Dim H() As Double + Dim I As Long, J As Long + + ReDim H(0 To m - 1, 0 To n - 1) + For I = 0 To m - 1 + For J = 0 To n - 1 + If I >= J Then + H(I, J) = QR(I, J) Else - h(i, j) = 0# + H(I, J) = 0# End If - Next j - Next i - QR_getH = h + Next J + Next I + QR_getH = H End Function ' /** Generate and return the (economy-sized) orthogonal factor @@ -7373,37 +7377,37 @@ End Function ' */ Private Function QR_getQ() As Double() Dim q() As Double - Dim i As Long, j As Long + Dim I As Long, J As Long Dim k As Long Dim s As Double ReDim q(0 To m - 1, 0 To n - 1) For k = m - 1 To 0 Step -1 q(k, k) = 1# - For j = k To n - 1 + For J = k To n - 1 If (QR(k, k) <> 0) Then s = 0# - For i = k To m - 1 - s = s + QR(i, k) * q(i, j) - Next i + For I = k To m - 1 + s = s + QR(I, k) * q(I, J) + Next I s = -s / QR(k, k) - For i = k To m - 1 - q(i, j) = q(i, j) + s * QR(i, k) - Next i + For I = k To m - 1 + q(I, J) = q(I, J) + s * QR(I, k) + Next I End If - Next j + Next J Next k - For i = 0 To m - 1 - For j = 0 To n - 1 - If Abs(q(i, j)) <> 0 Then - If signFlip(j) Then - q(i, j) = -1 * q(i, j) + For I = 0 To m - 1 + For J = 0 To n - 1 + If Abs(q(I, J)) <> 0 Then + If signFlip(J) Then + q(I, J) = -1 * q(I, J) End If Else - q(i, j) = 0 + q(I, J) = 0 End If - Next j - Next i + Next J + Next I QR_getQ = q End Function @@ -7412,32 +7416,32 @@ End Function ' */ Private Function QR_getR() As Double() Dim r() As Double - Dim i As Long, j As Long + Dim I As Long, J As Long ReDim r(0 To n - 1, 0 To n - 1) - For i = 0 To n - 1 - For j = 0 To n - 1 - If i < j Then - r(i, j) = QR(i, j) - ElseIf i = j Then - r(i, j) = rDiag(i) + For I = 0 To n - 1 + For J = 0 To n - 1 + If I < J Then + r(I, J) = QR(I, J) + ElseIf I = J Then + r(I, J) = rDiag(I) Else - r(i, j) = 0# + r(I, J) = 0# End If - If signFlip(i) And (r(i, j) <> 0) Then r(i, j) = -1 * r(i, j) - Next j - Next i + If signFlip(I) And (r(I, J) <> 0) Then r(I, J) = -1 * r(I, J) + Next J + Next I QR_getR = r End Function Private Function QR_hypot(ParamArray args() As Variant) As Double - Dim i As Long + Dim I As Long Dim sqrSum As Double - For i = LBound(args) To UBound(args) - sqrSum = sqrSum + (args(i) * args(i)) - Next i + For I = LBound(args) To UBound(args) + sqrSum = sqrSum + (args(I) * args(I)) + Next I QR_hypot = Sqr(sqrSum) End Function @@ -7445,12 +7449,12 @@ End Function ' @return true if R, and hence A, has full rank. ' */ Private Function QR_isFullRank() As Boolean - Dim j As Long + Dim J As Long Dim tmpResult As Boolean - Do While j < n And Not tmpResult - tmpResult = (rDiag(j) = 0) - j = j + 1 + Do While J < n And Not tmpResult + tmpResult = (rDiag(J) = 0) + J = J + 1 Loop QR_isFullRank = Not tmpResult End Function @@ -7468,7 +7472,7 @@ Private Function QR_solve(ByRef B() As Double) As Double() Exit Function '"Matrix is rank deficient." End If Dim x() As Double, nx As Long - Dim i As Long, j As Long, k As Long + Dim I As Long, J As Long, k As Long Dim s As Double, tmpResult() As Double ' // Copy right hand side @@ -7476,34 +7480,34 @@ Private Function QR_solve(ByRef B() As Double) As Double() nx = UBound(x, 2) - LBound(x, 2) + 1 ' // Compute Y = transpose(Q)*B For k = 0 To n - 1 - For j = 0 To nx - 1 + For J = 0 To nx - 1 s = 0 - For i = k To m - 1 - s = s + QR(i, k) * x(i, j) - Next i + For I = k To m - 1 + s = s + QR(I, k) * x(I, J) + Next I s = -s / QR(k, k) - For i = k To m - 1 - x(i, j) = x(i, j) + s * QR(i, k) - Next i - Next j + For I = k To m - 1 + x(I, J) = x(I, J) + s * QR(I, k) + Next I + Next J Next k ' // Solve R*X = Y For k = n - 1 To 0 Step -1 - For j = 0 To nx - 1 - x(k, j) = x(k, j) / rDiag(k) - Next j - For i = 0 To k - 1 - For j = 0 To nx - 1 - x(i, j) = x(i, j) - x(k, j) * QR(i, k) - Next j - Next i + For J = 0 To nx - 1 + x(k, J) = x(k, J) / rDiag(k) + Next J + For I = 0 To k - 1 + For J = 0 To nx - 1 + x(I, J) = x(I, J) - x(k, J) * QR(I, k) + Next J + Next I Next k ReDim tmpResult(0 To n - 1, 0 To nx - 1) - For i = 0 To n - 1 - For j = 0 To nx - 1 - tmpResult(i, j) = x(i, j) - Next j - Next i + For I = 0 To n - 1 + For J = 0 To nx - 1 + tmpResult(I, J) = x(I, J) + Next J + Next I QR_solve = tmpResult End Function @@ -7590,7 +7594,7 @@ End Function ''' Private Function RegressionString(ByRef SolverResult() As Double, Optional ByRef PredNames As Variant = -1, _ Optional ByRef PredInteractions As Variant = -1) As String - Dim i As Long + Dim I As Long Dim tmpResult As String Dim tmpNames() As String Dim strPNames As String @@ -7608,35 +7612,35 @@ Private Function RegressionString(ByRef SolverResult() As Double, Optional ByRef If Not IsNumeric(PredInteractions) Then n = UBound(PredInteractions) o = UBound(SolverResult) ReDim tmpNames(0 To o - 1) - For i = 0 To o - 1 + For I = 0 To o - 1 If m >= 0 And n >= 0 Then If s <= m Then - tmpNames(i) = PredNames(i) + tmpNames(I) = PredNames(I) s = s + 1 Else - tmpNames(i) = FormatNamedPredictors(strPNames, CStr(PredInteractions(i - s)), False) + tmpNames(I) = FormatNamedPredictors(strPNames, CStr(PredInteractions(I - s)), False) End If Else - If n + 1 - (o - i) >= 0 Then 'Save predictors relations without names - tmpNames(i) = PredInteractions(n + 1 - (o - i)) + If n + 1 - (o - I) >= 0 Then 'Save predictors relations without names + tmpNames(I) = PredInteractions(n + 1 - (o - I)) Else - tmpNames(i) = "X" & CStr(i + 1) + tmpNames(I) = "X" & CStr(I + 1) End If End If - Next i - For i = 0 To o - If i = 0 Then - tmpResult = CStr(Round(SolverResult(i, 0), 4)) + Next I + For I = 0 To o + If I = 0 Then + tmpResult = CStr(Round(SolverResult(I, 0), 4)) Else - If CDbl(SolverResult(i, 0)) > 0 Then + If CDbl(SolverResult(I, 0)) > 0 Then tmpResult = tmpResult & d_Space & op_plus _ - & d_Space & Round(SolverResult(i, 0), 4) + & d_Space & Round(SolverResult(I, 0), 4) Else - tmpResult = tmpResult & d_Space & Round(SolverResult(i, 0), 4) + tmpResult = tmpResult & d_Space & Round(SolverResult(I, 0), 4) End If - tmpResult = tmpResult & op_mult & tmpNames(i - 1) + tmpResult = tmpResult & op_mult & tmpNames(I - 1) End If - Next i + Next I RegressionString = tmpResult End Function @@ -7830,7 +7834,7 @@ Private Function RowColVectTransform(ByRef tVector As Variant) As Double() Dim vLB2 As Long Dim vUB As Long Dim fromRowToCol As Boolean - Dim i As Long, j As Long + Dim I As Long, J As Long Dim tmpResult() As Double If Not IsArray(tVector) Then Exit Function @@ -7839,17 +7843,17 @@ Private Function RowColVectTransform(ByRef tVector As Variant) As Double() fromRowToCol = Not Is2Darray(tVector) If fromRowToCol Then 'Transform row vector to column vector ReDim tmpResult(0 To vUB - vLB, 0 To 0) - For i = vLB To vUB - tmpResult(j, 0) = CDbl(tVector(i)) - j = j + 1 - Next i + For I = vLB To vUB + tmpResult(J, 0) = CDbl(tVector(I)) + J = J + 1 + Next I Else 'Transform column vector to row vector vLB2 = LBound(tVector, 2) ReDim tmpResult(0 To vUB - vLB) - For i = vLB To vUB - tmpResult(j) = CDbl(tVector(i, vLB2)) - j = j + 1 - Next i + For I = vLB To vUB + tmpResult(J) = CDbl(tVector(I, vLB2)) + J = J + 1 + Next I End If RowColVectTransform = tmpResult End Function @@ -8042,7 +8046,7 @@ Private Sub SORiteration(n As Long, ByRef A() As Double, ByRef B() As Double, _ ByRef x() As Double, iter As Long, tol As Double, omega As Double) ''' Hoffman, J. D. (2001). Numerical methods for engineers and scientists (2nd ed., rev.expanded). Marcel Dekker. Dim IT As Long - Dim i As Long, j As Long + Dim I As Long, J As Long Dim dxmax As Double Dim residual As Double Dim colLB As Long, rowLB As Long @@ -8051,14 +8055,14 @@ Private Sub SORiteration(n As Long, ByRef A() As Double, ByRef B() As Double, _ rowLB = LBound(A) For IT = 1 To iter dxmax = 0 - For i = 1 To n - residual = B(i + rowLB - 1) - For j = 1 To n - residual = residual - A(i + rowLB - 1, j + colLB - 1) * x(j + rowLB - 1) - Next j + For I = 1 To n + residual = B(I + rowLB - 1) + For J = 1 To n + residual = residual - A(I + rowLB - 1, J + colLB - 1) * x(J + rowLB - 1) + Next J If Abs(residual) > dxmax Then dxmax = Abs(residual) - x(i + rowLB - 1) = x(i + rowLB - 1) + omega * residual / A(i + rowLB - 1, i + colLB - 1) - Next i + x(I + rowLB - 1) = x(I + rowLB - 1) + omega * residual / A(I + rowLB - 1, I + colLB - 1) + Next I If dxmax < tol Then Exit For Next IT End Sub @@ -8072,18 +8076,18 @@ Private Function SplitArgs(ByRef args As String) As String() Dim LenArgsStr As Long Dim VectorOpenFlag As Boolean Dim OpenCBrackets As Long - Dim i As Long + Dim I As Long tmpPos = 1 LenArgsStr = LenB(args) Do VectorOpenFlag = (InStrB(tmpPos, args, d_lCurly) = tmpPos) If VectorOpenFlag Then 'Currrent argument is an array - i = tmpPos + I = tmpPos OpenCBrackets = 1 - Do While VectorOpenFlag And i <= LenArgsStr - i = i + 2 - curChar = MidB$(args, i, 2) + Do While VectorOpenFlag And I <= LenArgsStr + I = I + 2 + curChar = MidB$(args, I, 2) If curChar = d_lCurly Then OpenCBrackets = OpenCBrackets + 1 Else @@ -8094,8 +8098,8 @@ Private Function SplitArgs(ByRef args As String) As String() VectorOpenFlag = Not (curChar = d_rCurly) Or OpenCBrackets Loop SargStart = tmpPos - SargEnd = i + 2 - tmpPos = i + 4 + SargEnd = I + 2 + tmpPos = I + 4 Else SargStart = tmpPos curChar = MidB$(args, SargStart, 2) @@ -8131,8 +8135,8 @@ Private Function SplitArrBranch(ByRef Argument As String, ByRef outArr() As Stri Dim tmpArgs() As String Dim tmpResult() As Long Dim tmpOutArr() As String - Dim i As Long - Dim j As Long + Dim I As Long + Dim J As Long Dim k As Long Dim m As Long Dim n As Long @@ -8143,40 +8147,40 @@ Private Function SplitArrBranch(ByRef Argument As String, ByRef outArr() As Stri UB = UBound(tmpArgs) ReDim tmpResult(0 To 2 * (UB + 1)) ReDim outArr(0 To 0) - For i = 0 To UB - If tmpArgs(i) Like "{{*}}" Then ' Array - tmpArr() = ArrayFromString(tmpArgs(i)) + For I = 0 To UB + If tmpArgs(I) Like "{{*}}" Then ' Array + tmpArr() = ArrayFromString(tmpArgs(I)) If IsArrayAllocated(tmpArr) Then 'Transform success If Is2Darray(tmpArr) Then tmpOutArr = ArraySTR1DFrom2DArr(tmpArr) - tmpResult(j) = UBound(tmpArr) 'Rows in the array - tmpResult(j + 1) = UBound(tmpArr, 2) 'Columns in each row + tmpResult(J) = UBound(tmpArr) 'Rows in the array + tmpResult(J + 1) = UBound(tmpArr, 2) 'Columns in each row Else tmpOutArr = tmpArr - tmpResult(j) = UBound(tmpArr) - tmpResult(j + 1) = 0 + tmpResult(J) = UBound(tmpArr) + tmpResult(J + 1) = 0 End If - j = j + 2 'Worked array elements + J = J + 2 'Worked array elements Else GoTo Err_return End If Else - If tmpArgs(i) Like "{*}" Then ' Vector - tmpArr() = Split(MidB(tmpArgs(i), 3, LenB(tmpArgs(i)) - 4), P_SEPARATORCHAR) + If tmpArgs(I) Like "{*}" Then ' Vector + tmpArr() = Split(MidB(tmpArgs(I), 3, LenB(tmpArgs(I)) - 4), P_SEPARATORCHAR) If IsArrayAllocated(tmpArr) Then tmpOutArr = tmpArr - tmpResult(j) = UBound(tmpArr) - tmpResult(j + 1) = -3 - j = j + 2 + tmpResult(J) = UBound(tmpArr) + tmpResult(J + 1) = -3 + J = J + 2 Else GoTo Err_return End If Else ' Single data ReDim tmpArr(0 To 0) - tmpArr(0) = tmpArgs(i) + tmpArr(0) = tmpArgs(I) tmpOutArr = tmpArr - tmpResult(j) = -2 'Single data type - j = j + 1 + tmpResult(J) = -2 'Single data type + J = J + 1 End If End If m = UBound(outArr) @@ -8186,8 +8190,8 @@ Private Function SplitArrBranch(ByRef Argument As String, ByRef outArr() As Stri outArr(usedIdx) = tmpOutArr(k) usedIdx = usedIdx + 1 Next k - Next i - ReDim Preserve tmpResult(0 To j - 1) + Next I + ReDim Preserve tmpResult(0 To J - 1) ReDim Preserve outArr(0 To usedIdx - 1) nReturn: SplitArrBranch = tmpResult @@ -8233,14 +8237,14 @@ err_Handler: d_lParenthesis & err.Description & d_rParenthesis End Function -Private Function STATCOM(q As Double, i As Double, _ - j As Double, B As Double) As Double +Private Function STATCOM(q As Double, I As Double, _ + J As Double, B As Double) As Double Dim zz As Double Dim z As Double Dim k As Double - zz = 1: z = zz: k = i - Do While (k <= j) + zz = 1: z = zz: k = I + Do While (k <= J) zz = zz * q * k / (k - B) z = z + zz: k = k + 2 Loop @@ -8318,108 +8322,17 @@ Private Function STUDT_(ByVal t As Double, n As Double) As Double End If End Function -Private Function subTINV_(x1 As Double, x2 As Double) As Variant - If ((0 >= x1 Or Abs(x1) - Abs(Fix(x1)) <> 0) Or (0 >= x2 Or x2 >= 1)) Then - subTINV_ = False - Else - subTINV_ = GetPrecisionResult(subt_(x1, x2)) - End If -End Function - -Private Function subtprob_(y1 As Double, y2 As Double) As Double - Dim e As Double, rt1 As Double - Dim L As Double, n As Double - Dim s As Double, rt2 As Double - - L = Atn((y2 / Sqr(y1)) / 1) - n = Cos(L) ^ 2: s = 1 - For rt2 = y1 - 2 To 2 Step -2 - s = 1 + (rt2 - 1) / rt2 * n * s - Next rt2 - If REM_(y1, 2) = 0 Then - e = 0.5 - rt1 = Sin(L) / 2 - subtprob_ = rt1 - Else - e = 0.5 + L / pi - If 1 = y1 Then - rt1 = 0 - Else - rt1 = Cos(L) * Sin(L) / pi - End If - subtprob_ = MAX_(0, 1 - e - rt1 * s) - End If -End Function - -Private Function subt_(t As Double, r As Double) As Double - Dim e As Double, h As Double - Dim f As Double, i As Double - Dim inp1 As Double, inp2 As Double - Dim inp3 As Double, inp4 As Double - Dim inp5 As Double, inp6 As Double - Dim inp7 As Double, inp9 As Double - - If (0 >= r Or r >= 1) Then - subt_ = 0: Exit Function - End If - If (0.5 > r) Then - subt_ = -subt_(t, 1 - r): Exit Function - End If - e = subu_(r) - inp1 = e ^ 2 - inp2 = (27 * inp1 + 339) * inp1 + 930 - inp2 = inp2 * inp1 - 1782 - inp2 = ((inp2 * inp1 - 765) * inp1 + 17955) / 368640 - inp3 = (79 * inp1 + 776) * inp1 + 1482 - inp3 = inp3 * inp1 - 1920 - inp3 = (inp3 * inp1 - 945) / 92160 - inp4 = (((3 * inp1 + 19) * inp1 + 17) * inp1 - 15) / 384 - inp6 = ((5 * inp1 + 16) * inp1 + 3) / 96 - inp5 = (inp1 + 1) / 4 - inp7 = inp3 + inp2 / t - inp7 = (inp6 + (inp4 + inp7 / t) / t) - inp7 = e * (1 + (inp5 + inp7 / t) / t) - If (t <= (Log10(r) ^ 2) + 3) Then - Do - f = subtprob_(t, inp7) - inp9 = t + 1 - i = Log(inp9 / (t + inp7 * inp7)) - i = i + Log(t / inp9 / 2 / pi) - 1 + (1 / inp9 - 1 / t) - i = (f - r) / Exp((inp9 * i / 6) / 2) - inp7 = inp7 + i - h = RoundToPrecision(i, Abs(Fix(Log10(Abs(inp7)) - 6))) - Loop While (inp7 And 0 <> h) - End If - subt_ = inp7 -End Function - -Private Function subu_(p3 As Double) As Double - Dim p4 As Double - Dim e As Double - - p4 = -Log(4 * p3 * (1 - p3)) - e = -3.231081277E-09 + p4 * (3.657763036E-11 + 6.936233982E-13 * p4) - e = -0.00000104527497 + p4 * (8.360937017E-08 + p4 * e) - e = 0.000006841218299 + p4 * (0.000005824238515 + p4 * e) - e = -0.0008364353589 + p4 * (-0.0002250947176 + p4 * e) - e = Sqr(p4 * (1.570796288 + p4 * (0.03706987906 + p4 * e))) - If p3 > 0.5 Then - e = -e - End If - subu_ = e -End Function - Private Function SUM(ByRef expression As String, ByRef fName As String) As String - Dim g As Long + Dim G As Long Dim tmpData() As String Dim tmpEval As Double On Error GoTo err_Handler tmpEval = 0 tmpData() = SplitArgs(expression) - For g = LBound(tmpData) To UBound(tmpData) - tmpEval = tmpEval + CDbl(tmpData(g)) - Next g + For G = LBound(tmpData) To UBound(tmpData) + tmpEval = tmpEval + CDbl(tmpData(G)) + Next G SUM = CStr(tmpEval): Erase tmpData Exit Function err_Handler: @@ -8581,9 +8494,11 @@ End Function ''' ''' Receives the degrees of freedom and the confidence level to ''' compute the one-tailed or two-tailed t-value (Student t-value) -''' with up to 6 significant digits accuracy. Use the tOption -''' parameter to select from two and right one-tailed computation. -''' [(c) iCalculator™](https://www.icalculator.com/) +''' with full accuracy. Use the tOption parameter to select from +''' two and right one-tailed computation. +''' +''' (c) David M. Lane +''' https://onlinestatbook.com/2/calculators/inverse_t_dist.html ''' ''' Confidence level. ''' Shape parameter alpha. @@ -8618,28 +8533,37 @@ err_Handler: d_lParenthesis & err.Description & d_rParenthesis End Function -Private Function TINV_(confidence As Double, dof As Double, _ +Private Function TINV_(ByRef confidence As Double, dof As Double, _ Optional tOption As Single = 2) As Double + Dim x As Double Dim p As Double 'Probability If confidence > 1 And confidence < 100 Then 'Percentage entry confidence = confidence / 100 End If - p = (1 - confidence) + p = 1 - confidence If tOption = 1 Then - TINV_ = subTINV_(dof, p) + x = iBETAINV(2 * p, 0.5 * dof, 0.5) Else If tOption = 2 Then - TINV_ = subTINV_(dof, p / 2) + x = iBETAINV(p, 0.5 * dof, 0.5) End If End If + x = Sqr(dof * (1 - x) / x) + If confidence > 0 Then + TINV_ = x + Else + TINV_ = -x + End If End Function ''' ''' Receives the degrees of freedom and the Probability to -''' compute the one-tailed t-value (Student t-value) with up -''' to 6 significant digits accuracy. Parameter p can be passed -''' as 0 < p < 1, or 1 < p < 100 +''' compute the one-tailed t-value (Student t-value) with full +''' accuracy. Parameter p can be passed as 0 < p < 1, or 1 < p < 100 +''' +''' (c) David M. Lane +''' https://onlinestatbook.com/2/calculators/inverse_t_dist.html ''' ''' Probability. ''' Degrees of freedom. @@ -8673,21 +8597,14 @@ err_Handler: d_lParenthesis & err.Description & d_rParenthesis End Function -Private Function TINV_1T_(p As Double, dof As Double) As Double - Dim confidence As Double - - If p > 1 Then 'Percentage entry - p = p / 100 - End If - confidence = 1 - p - TINV_1T_ = TINV_(confidence, dof, 1) -End Function - ''' ''' Receives the degrees of freedom and the Probability to ''' compute the two-tailed t-value (Student t-value) with full ''' significant digits accuracy. Parameter p can be passed ''' as 0 < p < 1, or 1 < p < 100 +''' +''' (c) David M. Lane +''' https://onlinestatbook.com/2/calculators/inverse_t_dist.html ''' ''' Probability. ''' Degrees of freedom. @@ -8704,7 +8621,7 @@ Private Function TINV_2T(ByRef expression As String, ByRef fName As String) As S argsCount = UB - LB + 1 Select Case argsCount Case 2 - tmpEval = TINV_2T_( _ + tmpEval = TINV_( _ CDbl(tmpData(LB)), _ CDbl(tmpData(UB)) _ ) @@ -8720,24 +8637,9 @@ err_Handler: d_lParenthesis & err.Description & d_rParenthesis End Function -Private Function TINV_2T_(ByVal p As Double, dof As Long) As Double - Dim x As Double - - If p > 1 Then 'Percentage entry - p = p / 100 - End If - x = iBETAINV(p, 0.5 * dof, 0.5) - x = Sqr(dof * (1 - x) / x) - If p > 0 Then - TINV_2T_ = x - Else - TINV_2T_ = -x - End If -End Function - Public Function ToDblArray(ByRef aArray As Variant) As Double() - Dim i As Long, LB As Long, UB As Long - Dim j As Long, LB2 As Long, UB2 As Long + Dim I As Long, LB As Long, UB As Long + Dim J As Long, LB2 As Long, UB2 As Long Dim tmpResult() As Double Dim IsVector As Boolean @@ -8751,15 +8653,15 @@ Public Function ToDblArray(ByRef aArray As Variant) As Double() Else ReDim tmpResult(0 To UB - LB) End If - For i = LB To UB + For I = LB To UB If IsVector Then - tmpResult(i - LB) = CDbl(aArray(i)) + tmpResult(I - LB) = CDbl(aArray(I)) Else - For j = LB2 To UB2 - tmpResult(i - LB, j - LB2) = CDbl(aArray(i, j)) - Next j + For J = LB2 To UB2 + tmpResult(I - LB, J - LB2) = CDbl(aArray(I, J)) + Next J End If - Next i + Next I ToDblArray = tmpResult End Function @@ -8904,9 +8806,11 @@ Private Sub VariableAssignment(ByRef vString As String) fCurlyPos = InStrB(1, tmpVstring, d_lCurly) If fCurlyPos > 0 Then If InStrB(fCurlyPos + 1, tmpVstring, d_lCurly) - fCurlyPos = 2 Then 'Full array - tmpVstring = Replace(tmpVstring, d_rCurly & d_rCurly & P_SEPARATORCHAR, d_rCurly & d_rCurly & P_SEPARATORCHAR & P_SEPARATORCHAR) + tmpVstring = Replace(tmpVstring, d_rCurly & d_rCurly & P_SEPARATORCHAR, _ + d_rCurly & d_rCurly & P_SEPARATORCHAR & P_SEPARATORCHAR) Else 'Vector - tmpVstring = Replace(tmpVstring, d_rCurly & P_SEPARATORCHAR, d_rCurly & P_SEPARATORCHAR & P_SEPARATORCHAR) + tmpVstring = Replace(tmpVstring, d_rCurly & P_SEPARATORCHAR, _ + d_rCurly & P_SEPARATORCHAR & P_SEPARATORCHAR) End If Else tmpVstring = Replace(tmpVstring, P_SEPARATORCHAR, P_SEPARATORCHAR & P_SEPARATORCHAR) @@ -8936,7 +8840,7 @@ End Sub Private Sub VM_DOT_(ByRef A() As Double, ByRef B As Variant, ByRef aLB As Long, ByRef aLB2 As Long, _ ByRef aUB As Long, ByRef aUB2 As Long, ByRef bLB2 As Long, ByRef bUB2 As Long, _ - ByRef c() As Double, ByRef i As Long, ByRef j As Long, ByRef m As Long, _ + ByRef c() As Double, ByRef I As Long, ByRef J As Long, ByRef m As Long, _ ByRef n As Long, ByRef pSum As Double, ByRef bLB As Long, ByRef bUB As Long, ByRef jj As Long) aLB = 0: aUB = 0 @@ -8947,15 +8851,15 @@ Private Sub VM_DOT_(ByRef A() As Double, ByRef B As Variant, ByRef aLB As Long, m = bUB2 - bLB2 + 1 If Not (aUB2 - aLB2 + 1) <> (bUB - bLB + 1) Then ReDim c(0 To n - 1, 0 To m - 1) - For i = 0 To n - 1 - For j = 0 To m - 1 + For I = 0 To n - 1 + For J = 0 To m - 1 pSum = 0 For jj = 0 To aUB2 - aLB2 'Loop a() columns - pSum = pSum + A(aLB + jj) * B(bLB + jj, bLB2 + j) + pSum = pSum + A(aLB + jj) * B(bLB + jj, bLB2 + J) Next jj - c(i, j) = pSum - Next j - Next i + c(I, J) = pSum + Next J + Next I End If End Sub