亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? 逐步回歸m2.bas

?? 數理統計程序集
?? BAS
字號:
Attribute VB_Name = "modMethod"
'逐步回歸
Option Explicit
'xy(1 To n, 1 To m+1):觀測數據,已知,n是觀測次數,m是自變量個數
'F1:指定的F臨界值,用于引入,已知
'F2:指定的F臨界值,用于剔出,已知
'    要求F1>=F2。如果F1=F2=0,則引入除線性相關外的全部變量
'F:F檢驗值,計算結果
'L:選出的重要變量的個數,計算結果
'b(0 To m):回歸系數,計算結果
'Ti(1 To m):各變量的t檢驗值,計算結果
Public Sub Strd(xy() As Double, F1 As Double, F2 As Double, F As Double, _
            L As Integer, b() As Single, Ti() As Single)
    Dim I As Integer, J As Integer, K As Integer
    Dim n As Integer, m As Integer, y As Integer
    Dim Imax As Integer, Imin As Integer
    Dim Ry12m As Double, Sy As Double, Syy As Double, V As Double, ss As Single
    Dim F12 As Double, K12 As Integer
    Dim Mx(1 To 101) As Double, Vx(1 To 101) As Double, Vyx(1 To 101) As Double
    Dim R(1 To 101, 1 To 101) As Double, Ri(1 To 101) As Double
    Dim d As Double, Sp As Integer, Q As Double, Vmax As Double, Vmin As Double
    Dim Bi As Double
    n = UBound(xy, 1)                       'N是觀測數據的組數,即x數組的行數
    y = UBound(xy, 2)                       'y是自變量+因變量的個數,即x數組的列數
    m = y - 1                               'm是自變量的個數
'求平均值,保存于Mx()
Debug.Print "平均數"
Debug.Print "X1", "X2", "X3", "X4", "Y"
    For I = 1 To y
        d = 0
        For K = 1 To n
            d = xy(K, I) + d
        Next K
        Mx(I) = d / n
Debug.Print Mx(I),
Next I
'計算離差矩陣,放在R的下三角部分
    For K = 1 To n
        For I = 1 To y
            d = xy(K, I) - Mx(I): Vx(I) = d
            For J = 1 To I
                R(I, J) = d * Vx(J) + R(I, J)
            Next J
        Next I
    Next K
    For I = 1 To y
        Syy = R(I, I)
        If Syy = 0 Then
            MsgBox "某變量為常數,無法計算相關系數!"
            Exit Sub
        Else
        Vx(I) = Sqr(Syy)
        End If
    Next I
'計算相關矩陣,放在R的上三角部分
    For I = 2 To y
        d = Vx(I)
        For J = 1 To I - 1
            R(J, I) = R(I, J) / (d * Vx(J))
        Next J
    Next I
Debug.Print ""
Debug.Print "標準差"
Debug.Print "X1", "X2", "X3", "X4", "Y"
    d = Sqr(1 / (n - 1))
    For I = 1 To y
        Vx(I) = d * Vx(I)
ss = Vx(I)
Debug.Print ss,
        Vyx(I) = R(I, y)
    Next I
Debug.Print ""
Debug.Print "相關系數"
    For I = 1 To y
        R(I, I) = 1: Vyx(I) = Vx(y) / Vx(I)
        For J = I + 1 To y
            R(J, I) = R(I, J)
        Next J
    Next I
For I = 1 To y
    For J = 1 To y
ss = R(I, J)
Debug.Print ss,
    Next J
    Debug.Print ""
Next I
'法方程已建立,下面進入逐步計算
'計算各變量的貢獻V,從已入選的變量中找出最小的V,從未選量中找出最大的V
L2:
    L = 0: Sp = 0: Q = 1
LStep:
    Sp = Sp + 1: Vmax = 0: Vmin = 10
    For I = 1 To m
        Ti(I) = 0: d = R(I, I)
        If d > 0.00000001 Then
            V = (R(y, I) / d) * R(I, y)
            If V < 0 Then
                Ti(I) = d
                If -V < Vmin Then
                    Vmin = -V: Imin = I
                End If
            Else
                If V > Vmax Then
                    Vmax = V: Imax = I
                End If
            End If
        End If
    Next I
    If L <> 0 Then
        d = 0
        For I = 1 To m
            If Ti(I) = 0 Then
                b(I) = 0: Ri(I) = 0
            Else
                Bi = R(I, y): b(I) = Vyx(I) * Bi
                d = d + b(I) * Mx(I)
                Ri(I) = Bi / Sqr(Ti(I) * Q + Bi ^ 2)
                Ti(I) = Bi / Sqr(Ti(I) * Q / (n - L - 1))
            End If
        Next I
        b(0) = Mx(y) - d
    End If
    F12 = (n - L - 1) * Vmin / Q
    If F12 < F2 Then
        L = L - 1: K = Imin: K12 = -K
    Else
        F12 = (n - L - 2) * Vmax / (Q - Vmax)
        If F12 <= (F1 + 0.00000001) Then
            GoTo L3
        Else
            L = L + 1: K = Imax: K12 = K
        End If
    End If
'下面對R矩陣的第K列作消去計算
    d = 1 / R(K, K): R(K, K) = 1
    For J = 1 To y
        R(K, J) = R(K, J) * d
    Next J
    For I = 1 To y
        If I = K Then
        Else
            d = R(I, K): R(I, K) = 0
            For J = 1 To y
                R(I, J) = R(I, J) - d * R(K, J)
            Next J
        End If
    Next I
    Q = R(y, y): Ry12m = Sqr(1 - Q)
    F = (n - L - 1) * (1 - Q) / (L * Q)
    Sy = Sqr(Syy * Q / (n - L - 1))
    GoTo LStep
L3:
    If L = 0 Then
        MsgBox "在當前的F1、F2下,不能選出重要的變量!"
        Exit Sub
    End If
    d = 0
    For I = 1 To m
        If Ti(I) = 0 Then
            b(I) = 0: Ri(I) = 0
        Else
            Bi = R(I, y): b(I) = Vyx(I) * Bi
            d = d + b(I) * Mx(I)
            Ri(I) = Bi / Sqr(Abs(Ti(I) * Q + Bi ^ 2))
            Ti(I) = Bi / Sqr(Abs(Ti(I) * Q / (n - L - 1)))
            Ti(I) = Abs(Ti(I))
        End If
    Next I
Debug.Print "最后的相關系數"
For I = 1 To y - 1
    For J = 1 To y
ss = R(I, J)
Debug.Print ss,
    Next J
    Debug.Print ""
Next I
    b(0) = Mx(y) - d
End Sub

'求正態分布的分位數
'Q:上側概率
'x:分位數
Public Sub PNorm(Q, x)
    Dim p As Double, y As Double, z As Double
    Dim b0 As Double, b1 As Double, b2 As Double
    Dim b3 As Double, b4 As Double, b5 As Double
    Dim b6 As Double, b7 As Double, b8 As Double
    Dim b9 As Double, b10 As Double, b As Double
    b0 = 1.570796288: b1 = 0.03706987906
    b2 = -0.0008364353589: b3 = -0.0002250947176
    b4 = 0.000006841218299: b5 = 0.000005824238515
    b6 = -0.00000104527497: b7 = 8.360937017E-08
    b8 = -3.231081277E-09: b9 = 3.657763036E-11
    b10 = 6.936233982E-13
    If Q = 0.5 Then
        x = 0: GoTo PN01
    End If
    If Q > 0.5 Then p = 1 - Q Else p = Q
    y = -Log(4 * p * (1 - p))
    b = y * (b9 + y * b10)
    b = y * (b8 + b): b = y * (b7 + b)
    b = y * (b6 + b): b = y * (b5 + b)
    b = y * (b4 + b): b = y * (b3 + b)
    b = y * (b2 + b): b = y * (b1 + b)
    z = y * (b0 + b): x = Sqr(z)
    If Q > 0.5 Then x = -x
PN01:
End Sub

'計算F分布的分布函數
'n1:自由度,已知
'n2:自由度,已知
'F:F值,已知
'p:下側概率,所求
'd:概率密度,所求
Public Sub F_DIST(n1 As Integer, n2 As Integer, F As Double, _
            p As Double, d As Double)
    Dim x As Double, U As Double, Lu As Double
    Dim IAI As Integer, IBI As Integer, nn1 As Integer, nn2 As Integer
    Dim I As Integer
    Const PI As Double = 3.14159265359
    If F = 0 Then
        p = 0: d = 0: Exit Sub
    End If
    x = n1 * F / (n2 + n1 * F)
    If (n1 \ 2) * 2 = n1 Then
        If (n2 \ 2) * 2 = n2 Then
            U = x * (1 - x): p = x: IAI = 2: IBI = 2
        Else
            U = x * Sqr(1 - x) / 2: p = 1 - Sqr(1 - x): IAI = 2: IBI = 1
        End If
    Else
        If (n2 \ 2) * 2 = n2 Then
            p = Sqr(x): U = p * (1 - x) / 2: IAI = 1: IBI = 2
        Else
            U = Sqr(x * (1 - x)) / PI
            p = 1 - 2 * Atn(Sqr((1 - x) / x)) / PI: IAI = 1: IBI = 1
        End If
    End If
    nn1 = n1 - 2: nn2 = n2 - 2
    If U = 0 Then
        d = U / F
        Exit Sub
    Else
        Lu = Log(U)
    End If
    If IAI = n1 Then GoTo LL1
    For I = IAI To nn1 Step 2
        p = p - 2 * U / I
        Lu = Lu + Log((1 + IBI / I) * x)
        U = Exp(Lu)
    Next I
LL1:
    If IBI = n2 Then
        d = U / F: Exit Sub
    End If
    For I = IBI To nn2 Step 2
        p = p + 2 * U / I
        Lu = Lu + Log((1 + n1 / I) * (1 - x))
        U = Exp(Lu)
    Next I
    d = U / F
End Sub

'計算F分布的分位數
'n1:自由度,已知
'n2:自由度,已知
'Q:上側概率,已知
'F:分位數,所求
Public Sub PF_DIST(n1 As Integer, n2 As Integer, _
                Q As Double, F As Double)
    Dim DF12 As Double, DF22 As Double, a As Double, b As Double
    Dim A1 As Double, b1 As Double, p As Double, YQ As Double
    Dim E As Double, FO As Double, pp As Double, d As Double
    Dim GA1 As Double, GA2 As Double, GA3 As Double
    Dim K As Integer
    DF12 = n1 / 2: DF22 = n2 / 2
    a = 2 / (9 * n1): A1 = 1 - a
    b = 2 / (9 * n2): b1 = 1 - b
    p = 1 - Q: PNorm Q, YQ
    E = b1 * b1 - b * YQ * YQ
    If E > 0.8 Then
        FO = ((A1 * b1 + YQ * Sqr(A1 * A1 * b + a * E)) / E) ^ 3
    Else
        lnGamma DF12 + DF22, GA1
        lnGamma DF12, GA2
        lnGamma DF22, GA3
        FO = (2 / n2) * (GA1 - GA2 - GA3 + 0.69315 + (DF22 - 1) * Log(n2) _
            - DF22 * Log(n1) - Log(Q))
        FO = Exp(FO)
    End If
    For K = 1 To 30
        F_DIST n1, n2, FO, pp, d
        If d = 0 Then
            F = FO: Exit Sub
        End If
        F = FO - (pp - p) / d
        If Abs(FO - F) < 0.000001 * Abs(F) Then Exit Sub Else FO = F
    Next K
End Sub

'計算GAMMA函數
'x:自變量
'z:GAMMA函數值
Public Sub GAMMA(x As Double, z As Double)
    Dim H As Double, y As Double, y1 As Double
    H = 1: y = x
LL1:
    If y = 2 Then
        z = H
        Exit Sub
    ElseIf y < 2 Then
        H = H / y: y = y + 1: GoTo LL1
    ElseIf y >= 3 Then
        y = y - 1: H = H * y: GoTo LL1
    End If
    y = y - 2
    y1 = y * (0.005159 + y * 0.001606)
    y1 = y * (0.004451 + y1)
    y1 = y * (0.07211 + y1)
    y1 = y * (0.082112 + y1)
    y1 = y * (0.41174 + y1)
    y1 = y * (0.422787 + y1)
    H = H * (0.999999 + y1)
    z = H
End Sub

'求Gamma函數的對數LogGamma(x)
'x:自變量
'G:Gamma函數的對數
Public Sub lnGamma(x As Double, G As Double)
    Dim y As Double, z As Double, a As Double
    Dim b As Double, b1 As Double, n As Integer
    Dim I As Integer
    If x < 8 Then
        y = x + 8: n = -1
    Else
        y = x: n = 1
    End If
    z = 1 / (y * y)
    a = (y - 0.5) * Log(y) - y + 0.9189385
    b1 = (0.0007663452 * z - 0.0005940956) * z
    b1 = (b1 + 0.0007936431) * z
    b1 = (b1 - 0.002777778) * z
    b = (b1 + 0.0833333) / y
    G = a + b
    If n >= 0 Then Exit Sub
    y = y - 1: a = y
    For I = 1 To 7
        a = a * (y - I)
    Next I
    G = G - Log(a)
End Sub

'計算t分布的分布函數
'n:自由度,已知
'T:t值,已知
'pp:下側概率,所求
'dd:概率密度,所求
Public Sub T_Dist(n As Integer, t As Double, pp As Double, dd As Double)
    Dim Sign As Integer, TT As Double, x As Double
    Dim p As Double, U As Double, GA1 As Double, GA2 As Double
    Dim IBI As Integer, n2 As Integer, I As Integer
    Const PI As Double = 3.14159265359
    If t = 0 Then
        Call GAMMA(n / 2, GA1): Call GAMMA(n / 2 + 0.5, GA2): pp = 0.5
        dd = GA2 / (Sqr(n * PI) * GA1): Exit Sub
    End If
    If t < 0 Then Sign = -1 Else Sign = 1
    TT = t * t: x = TT / (n + TT)
    If (n \ 2) * 2 = n Then                 'n為偶數
        p = Sqr(x): U = p * (1 - x) / 2
        IBI = 2
    Else                                    'n為奇數
        U = Sqr(x * (1 - x)) / PI
        p = 1 - 2 * Atn(Sqr((1 - x) / x)) / PI
        IBI = 1
    End If
    If IBI = n Then GoTo LL1 Else n2 = n - 2
    For I = IBI To n2 Step 2
        p = p + 2 * U / I
        U = U * (1 + I) / I * (1 - x)
    Next I
LL1:
    dd = U / Abs(t)
    pp = 0.5 + Sign * p / 2
End Sub

'求t分布的分位數
'n:自由度,已知
'Q:上側概率(<=0.5),已知
'T:分位數,所求
Public Sub PT_DIST(n As Integer, Q As Double, t As Double)
    Dim PIS As Double, DFR2 As Double, c As Double
    Dim Q2 As Double, p As Double, YQ As Double, E As Double
    Dim GA1 As Double, GA2 As Double, GA3 As Double
    Dim T0 As Double, pp As Double, d As Double
    Dim K As Integer
    Const PI As Double = 3.14159265359
    PIS = Sqr(PI): DFR2 = n / 2
    If n = 1 Then
        t = Tan(PI * (0.5 - Q)): Exit Sub
    End If
    If n = 2 Then
        If Q > 0.5 Then c = -1 Else c = 1
        Q2 = (1 - 2 * Q) ^ 2
        t = Sqr(2 * Q2 / (1 - Q2)) * c
        Exit Sub
    End If
    p = 1 - Q: PNorm Q, YQ              '正態分布分位數
    E = (1 - 1 / (4 * n)) ^ 2 - YQ * YQ / (2 * n)
    If E > 0.5 Then
        T0 = YQ / Sqr(E)
    Else
        lnGamma DFR2, GA1: lnGamma DFR2 + 0.5, GA2
        GA3 = Exp((GA1 - GA2) / n)
        T0 = Sqr(n) / (PIS * Q * n) ^ (1 / n) / GA3
    End If
    For K = 1 To 30
        T_Dist n, T0, pp, d
        If d = 0 Then
            t = T0: Exit Sub
        End If
        t = T0 - (pp - p) / d
        If Abs(T0 - t) < 0.000001 * Abs(t) Then _
            Exit Sub Else T0 = t
    Next K
End Sub







?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久蜜臀精品av| 91精品国产综合久久婷婷香蕉| 精品国内二区三区| 久久99精品久久久久久久久久久久 | 在线观看欧美日本| 一区二区成人在线观看| 6080日韩午夜伦伦午夜伦| 毛片av一区二区| 久久久久久久久久电影| 777色狠狠一区二区三区| 日日夜夜免费精品视频| 精品国产成人在线影院| 福利一区二区在线观看| 亚洲视频一区二区在线| 欧美日韩大陆在线| 精品一区二区在线视频| 国产色婷婷亚洲99精品小说| 日本黄色一区二区| 人妖欧美一区二区| 国产精品人成在线观看免费| 91久久精品网| 国产一区在线不卡| 亚洲卡通动漫在线| 欧美一区二区福利在线| 成人免费视频app| 亚洲一区二区精品久久av| 欧美v日韩v国产v| 91美女片黄在线观看| 美国十次综合导航| 一色桃子久久精品亚洲| 欧美精品日日鲁夜夜添| 国产成人精品亚洲777人妖| 亚洲国产aⅴ成人精品无吗| 精品国产一区二区三区忘忧草| 99免费精品视频| 久色婷婷小香蕉久久| 亚洲欧美日韩综合aⅴ视频| 8x8x8国产精品| 色综合久久久久综合99| 久久97超碰色| 亚洲国产成人av好男人在线观看| 久久男人中文字幕资源站| 欧美日韩免费不卡视频一区二区三区| 国产精品一区二区果冻传媒| 五月婷婷另类国产| 亚洲欧洲日产国产综合网| 日韩欧美一级二级| 欧美日韩三级一区二区| av在线不卡免费看| 黄色日韩三级电影| 日韩一区精品字幕| 一区二区三区影院| 中文字幕一区二区三区四区| 日韩欧美一级在线播放| 欧美区一区二区三区| 91丨九色porny丨蝌蚪| 国产成人午夜99999| 蜜桃av一区二区| 五月天久久比比资源色| 一区二区久久久久| 中文字幕欧美一| 中文字幕av免费专区久久| 亚洲精品在线观看网站| 91精品国产91久久综合桃花 | 蜜桃av一区二区在线观看| 一区二区激情视频| 亚洲日本免费电影| 国产精品电影一区二区三区| 国产亚洲综合av| 久久久久国产一区二区三区四区 | 精品国产不卡一区二区三区| 欧美一区二区三区在线电影| 精品视频一区 二区 三区| 欧美色视频在线| 欧美色网一区二区| 欧美中文字幕一二三区视频| 色视频欧美一区二区三区| 本田岬高潮一区二区三区| 成人丝袜视频网| 成人精品视频一区二区三区| 成人激情av网| 成人精品国产一区二区4080| www.欧美色图| 色婷婷一区二区| 欧美日韩国产小视频| 欧美日韩高清一区| 日韩一区二区三区av| 欧美成人a在线| 国产欧美一区二区三区鸳鸯浴 | 欧美视频在线观看一区| 欧美日韩专区在线| 在线成人av影院| 欧美va亚洲va国产综合| 国产农村妇女精品| 亚洲色图欧洲色图| 亚洲成av人片一区二区三区| 日本成人在线电影网| 精品一区二区免费在线观看| 国产成人av电影在线观看| 成人午夜av在线| 欧洲中文字幕精品| 5858s免费视频成人| 2024国产精品| 自拍偷拍亚洲综合| 黄一区二区三区| 国产在线日韩欧美| 99久久免费视频.com| 在线视频观看一区| 精品日产卡一卡二卡麻豆| 亚洲国产激情av| 国产精品99久久久| 91免费视频大全| 日韩免费福利电影在线观看| 日本一区二区电影| 亚洲福利视频导航| 国产成人一级电影| 欧美日韩中字一区| 国产欧美精品一区二区三区四区 | 亚洲视频免费看| 日韩在线播放一区二区| 国产传媒日韩欧美成人| 欧美色中文字幕| 国产日韩欧美精品电影三级在线 | 亚洲va国产va欧美va观看| 国产在线精品视频| 欧美在线你懂的| 久久久精品中文字幕麻豆发布| 一区二区国产视频| 国产iv一区二区三区| 欧美日韩国产高清一区二区三区 | 精品999久久久| 亚洲一区二区免费视频| 国产精品一区二区三区网站| 欧美日韩三级视频| 亚洲色图欧洲色图| 国产黄色91视频| 日韩三级精品电影久久久| 亚洲精品一二三四区| 国产精品一区在线| 自拍av一区二区三区| 国产精品一品二品| 欧美一区二区视频免费观看| 亚洲黄色性网站| 国产ts人妖一区二区| 欧美xxxxxxxx| 日韩av成人高清| 欧美日韩一级片在线观看| 国产精品久久看| 国产成人av电影在线| 久久青草欧美一区二区三区| 免费av网站大全久久| 欧美系列日韩一区| 亚洲美女在线一区| 波波电影院一区二区三区| 国产色产综合色产在线视频| 久久精品二区亚洲w码| 欧美一区二区三区视频免费播放| 亚洲永久精品国产| 在线免费观看日本欧美| 日韩理论片一区二区| 99精品在线免费| 国产精品欧美极品| 成人美女在线视频| 亚洲国产精品v| 成人免费av网站| 中文字幕欧美三区| 国产69精品久久久久毛片 | 国产精品一区二区91| 欧美精品一区二区三区高清aⅴ | 美女一区二区在线观看| 91精品国产综合久久久蜜臀图片 | 久久一二三国产| 激情五月播播久久久精品| 26uuu亚洲综合色欧美 | 午夜精品免费在线| 欧美精品v日韩精品v韩国精品v| 亚洲午夜久久久久久久久电影院| 欧美在线你懂得| 亚洲图片欧美一区| 欧美一级生活片| 精品制服美女久久| 日本一区二区三区高清不卡| 成人黄色777网| 一区二区三区.www| 88在线观看91蜜桃国自产| 久久9热精品视频| 国产夜色精品一区二区av| 99国产精品久久久久| 亚洲第四色夜色| 欧美电影免费观看完整版| 国产成人自拍网| 亚洲精品乱码久久久久久日本蜜臀| 欧美在线观看视频在线| 免费成人在线视频观看| 国产精品网站导航| 欧美三级资源在线| 国产综合久久久久影院| 亚洲天堂免费看| 日韩一区二区电影网| 大陆成人av片|