实现BatchNorm2d-深度学习-python

python

import numpy as np

class MyBatchNorm2d:
    def __init__(self, num_features, eps=0.001, momentum=0.99):
        self.gamma = np.ones([num_features, ])
        self.beta = np.zeros([num_features, ])
        self.eps = eps
        self.momentum = momentum
        self.running_mean = 0.0
        self.running_var = 1.0
    
    def forward_train(self, input):
        assert input.dim == 4 

        mean = input.mean(axis=0)
        var = input.var(axis=0)
        input_norm = (input-mean)/np.sqrt(self.eps+var)
        
        results = self.gamma * input_norm + self.beta

        self.running_mean = self.running_mean*self.momentum + (1-self.momentum)*mean
        self.running_var = self.running_var*self.momentum + (1-self.momentum)*var

        return results
    
    def forward_test(self, input):
        assert input.dim == 4

        input_norm = (input-self.running_mean) / np.sqrt(self.eps+self.running_var)
        results = input_norm * self.gamma + self.beta

        return results
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值