zoukankan      html  css  js  c++  java
  • BP神经网络实现

    # -*- coding: utf-8 -*-
    # ---------------------------------------------------------------------------
    # BP-ANN.py
    # Created on: 2014-06-12 09:49:56.00000
    # Description:
    # ---------------------------------------------------------------------------
    
    import os
    import math
    import time
    import datetime
    
    #输入层n个神经元
    n = 4
    #隐含层p个神经元
    p = 6
    #输出层q个神经元
    q = 1
    
    #输入向量
    trainsample = 60
    x = [[0 for i in range(0, n)] for j in range(trainsample)]
    x = [[0.27500,0.60000,0.14085,0.07143],[0.22500,0.43333,0.14085,0.07143],[0.17500,0.50000,0.12676,0.07143],[0.15000,0.46667,0.15493,0.07143],[0.25000,0.63333,0.14085,0.07143],[0.35000,0.73333,0.18310,0.14286],[0.15000,0.56667,0.14085,0.10714],[0.25000,0.56667,0.15493,0.07143],[0.10000,0.40000,0.14085,0.07143],[0.22500,0.46667,0.15493,0.03571],[0.35000,0.66667,0.15493,0.07143],[0.20000,0.56667,0.16901,0.07143],[0.20000,0.43333,0.14085,0.03571],[0.07500,0.43333,0.09859,0.03571],[0.45000,0.76667,0.11268,0.07143],[0.42500,0.90000,0.15493,0.14286],[0.35000,0.73333,0.12676,0.14286],[0.27500,0.60000,0.14085,0.10714],[0.42500,0.70000,0.18310,0.10714],[0.27500,0.70000,0.15493,0.10714],[0.75000,0.50000,0.60563,0.50000],[0.60000,0.50000,0.57746,0.53571],[0.72500,0.46667,0.63380,0.53571],[0.37500,0.20000,0.50704,0.46429],[0.62500,0.36667,0.59155,0.53571],[0.42500,0.36667,0.57746,0.46429],[0.57500,0.53333,0.60563,0.57143],[0.22500,0.23333,0.40845,0.35714],[0.65000,0.40000,0.59155,0.46429],[0.30000,0.33333,0.49296,0.50000],[0.25000,0.10000,0.43662,0.35714],[0.47500,0.43333,0.53521,0.53571],[0.50000,0.16667,0.50704,0.35714],[0.52500,0.40000,0.60563,0.50000],[0.40000,0.40000,0.45070,0.46429],[0.67500,0.46667,0.56338,0.50000],[0.40000,0.43333,0.57746,0.53571],[0.45000,0.33333,0.52113,0.35714],[0.55000,0.16667,0.57746,0.53571],[0.40000,0.26667,0.49296,0.39286],[0.57500,0.53333,0.78873,0.89286],[0.45000,0.33333,0.66197,0.67857],[0.77500,0.43333,0.77465,0.75000],[0.57500,0.40000,0.73239,0.64286],[0.62500,0.43333,0.76056,0.78571],[0.90000,0.43333,0.87324,0.75000],[0.22500,0.26667,0.57746,0.60714],[0.82500,0.40000,0.83099,0.64286],[0.67500,0.26667,0.76056,0.64286],[0.80000,0.63333,0.80282,0.89286],[0.62500,0.50000,0.66197,0.71429],[0.60000,0.33333,0.69014,0.67857],[0.70000,0.43333,0.71831,0.75000],[0.42500,0.26667,0.64789,0.71429],[0.45000,0.36667,0.66197,0.85714],[0.60000,0.50000,0.69014,0.82143],[0.62500,0.43333,0.71831,0.64286],[0.92500,0.70000,0.88732,0.78571],[0.92500,0.30000,0.91549,0.82143],[0.50000,0.16667,0.64789,0.53571]]
    
    d = [0 for i in range(0, trainsample)]
    d = [0.2,0.2,0.2,0.2,0.2,0.2,0.2,0.2,0.2,0.2,0.2,0.2,0.2,0.2,0.2,0.2,0.2,0.2,0.2,0.2,0.5,0.5,0.5,0.5,0.5,0.5,0.5,0.5,0.5,0.5,0.5,0.5,0.5,0.5,0.5,0.5,0.5,0.5,0.5,0.5,0.7,0.7,0.7,0.7,0.7,0.7,0.7,0.7,0.7,0.7,0.7,0.7,0.7,0.7,0.7,0.7,0.7,0.7,0.7,0.7]
    
    #隐含层(p个隐含层神经元, 每个隐含层神经元有对应输入层神经元有一个系数)
    hi = [0 for i in range(0, p)]
    ho = [0 for i in range(0, p)]
    b1 = [0.3 for i in range(0, p)]
    Whi = [[0.5 for i in range(0, n)] for j in range(p)]
    pp = [0 for i in range(0, p)]
    rateWhi = 0.05
    
    #输出层(q个输出层神经元, 每个输出层神经元有对应隐含层神经元有一个系数)
    yi = [0 for i in range(0, q)]
    yo = [1 for i in range(0, q)]
    b2 = [0.3 for i in range(0, q)]
    Woh = [[0.5 for i in range(0, p)] for j in range(q)]
    qq = [0 for i in range(0, q)]
    rateWoh = 0.05
    #误差函数
    e=1.0
    
    
    def f1(x):
        y = 1.0/(1.0+math.exp(-1.0*x))
        return y
    
    def f2(x):
        y = f1(x)
        y = y * (1.0 - y)
        return y
        
    def train():
        e = 0.0
        for trainIndex in range(0, trainsample):  # trainsample
            #print(x[trainIndex])
            #隐含层 输入 输出
            for i in range(0, p):
                hi[i] = 0
                for j in range(0, n):
                    hi[i] = hi[i] + Whi[i][j] * x[trainIndex][j]
                ho[i] = f1(hi[i]+b1[i])
            #输出层 输入 输出
            for i in range(0, q):
                yi[i] = 0
                for j in range(0, p):
                    yi[i] = yi[i] + Woh[i][j] * ho[j]
                yo[i] = f1(yi[i]+b2[i])
            #print(hi)
            #误差函数对输出层的各神经元的偏导数
            for i in range(0, q):
                qq[i] = 0
                qq[i] = (d[trainIndex] - yo[i]) * yo[i] * (1 - yo[i])# * ho[i]
                for k in range(0, p):
                    Woh[i][k] = Woh[i][k] + rateWoh * qq[i] * ho[k]
    
            for i in range(0, p):
                pp[i] = 0
                for j in range(0, q):
                    pp[i] = pp[i] + qq[j] * Woh[j][i]
                pp[i] = pp[i] * ho[i] * (1 - ho[i])
                for k in range(0, n):
                    Whi[i][k] = Whi[i][k] + rateWhi * pp[i] * x[trainIndex][k]
            
            for i in range(0, q):    
                e = e + 0.5 * math.pow((d[trainIndex] - yo[i]), 2)
            
            #
            for i in range(0, q):
                b2[i] = b2[i] + rateWoh * qq[i]
            for i in range(0, p):
                b1[i] = b1[i] + rateWhi * pp[i]
        return e
    
    def recognize(vv):
        #隐含层 输入 输出
        for i in range(0, p):
            hi[i] = 0
            for j in range(0, n):
                hi[i] = hi[i] + Whi[i][j] * vv[j]
            ho[i] = f1(hi[i]+b1[i])
        #输出层 输入 输出
        for i in range(0, q):
            yi[i] = 0
            for j in range(0, p):
                yi[i] = yi[i] + Woh[i][j] * ho[j]
            yo[i] = f1(yi[i]+b2[i])
        print('-------------------------------------------------------')
        print(yo)
    
        
    times = 0
    while e > 0.001:
        #计算各层输入和输出
        e = train()
        times = times + 1
        print(str(times)+"   " + str(e))
        if times > 10000:
            break
    recognize([0.7, 0.5, 0.774647887, 0.821428571])
    recognize([0.4,0.433333333,0.521126761,0.464285714])                                        
    recognize([0.25,0.5,0.112676056,0.071428571])
  • 相关阅读:
    stl 在 acm中的应用总结
    hdu_2089(数位dp)
    水dp第二天(背包有关)
    dp水一天
    poj_2195Going Home(最小费用最大流)
    poj_3281Dining(网络流+拆点)
    GSS4
    SPOJ GSS1_Can you answer these queries I(线段树区间合并)
    Ajax实现局部数据交互的一个简单实例
    对学习Ajax的知识总结
  • 原文地址:https://www.cnblogs.com/gispathfinder/p/5783403.html
Copyright © 2011-2022 走看看