【深度学习实战】一、Numpy手撸神经网络实现线性回归

本文围绕用Numpy手撸神经网络实现线性回归展开,先定义包含data和grad的Tensor及初始化类,再实现全连接层、ReLU等层结构,组建模型,还实现带动量的SGD优化器和MSE损失函数,最后以拟合f(x)=sin(x)为例,完成数据处理、模型训练与验证,展示了神经网络底层实现过程。

☞☞☞AI 智能聊天, 问答助手, AI 智能搜索, 免费无限量使用 DeepSeek R1 模型☜☜☜

【深度学习实战】一、numpy手撸神经网络实现线性回归 - 创想鸟

【深度学习实战】一、Numpy手撸神经网络实现线性回归

一、简介

在学习深度学习时,在理论学习完成后,我们常常会直接使用框架(paddle/torch/tensorflow)来搭建我们的模型,常常忽略了各种层结构的底层实现。学习完成深度学习理论的你,能不能手撸一个简单的模型呢?本文旨在从基础开始,一步一步实现深度学习的参数优化,模型搭建过程,巩固基础知识,从理论到实践,一步一步探索深度学习的奥秘。

本文不会过多介绍深度学习的理论,直接从代码层面来实现全连接层、激活函数和SGD优化器,搭建一个简单的全连接模型,并且以一个线性回归示例,验证模型的效果。

二、目标

本文以学习为目的,以f(x) = sin(x)为目标函数,建立神经网络模型来拟合目标曲线。

数据如下图所示:【深度学习实战】一、Numpy手撸神经网络实现线性回归 - 创想鸟        

拟合结果如下图所示:【深度学习实战】一、Numpy手撸神经网络实现线性回归 - 创想鸟        

本文涉及的参考资料:

1、全连接层前向传播和梯度计算
2、动量梯度下降
3、ReLU

三、实现思路

在深度学习框架中,数据都是以tensor的形式进行计算,这里为了简单,数据的输入和输入都是以numpy.ndarray的格式传输。
本小节内容包含了相关类的实现。

1、tensor和初始化

tensor包含data和grad,保存data和对应的梯度数据。

In [1]

# 因为层的参数需要保存值和对应的梯度,这里定义梯度,可训练的参数全部以Tensor的类别保存import numpy as npnp.random.seed(10001)class Tensor:    def __init__(self, shape):        self.data = np.zeros(shape=shape, dtype=np.float32) # 存放数据        self.grad = np.zeros(shape=shape, dtype=np.float32) # 存放梯度    def clear_grad(self):        self.grad = np.zeros_like(self.grad)    def __str__(self):        return "Tensor shape: {}, data: {}".format(self.data.shape, self.data)# Tensor的初始化类,目前仅提供Normal初始化和Constant初始化class Initializer:    """    基类    """    def __init__(self, shape=None, name='initializer'):        self.shape = shape        self.name = name    def __call__(self, *args, **kwargs):        raise NotImplementedError    def __str__(self):        return self.nameclass Constant(Initializer):    def __init__(self, value=0., name='constant initializer', *args, **kwargs):        super().__init__(name=name, *args, **kwargs)        self.value = value    def __call__(self, shape=None, *args, **kwargs):        if shape:            self.shape = shape        assert shape is not None, "the shape of initializer must not be None."        return self.value + np.zeros(shape=self.shape)class Normal(Initializer):    def __init__(self, mean=0., std=0.01, name='normal initializer', *args, **kwargs):        super().__init__(name=name, *args, **kwargs)        self.mean = mean        self.std = std    def __call__(self, shape=None, *args, **kwargs):        if shape:            self.shape = shape        assert shape is not None, "the shape of initializer must not be None."        return np.random.normal(self.mean, self.std, size=self.shape)

   

2、Layer

这里实现了全连接层Linear和ReLU激活函数。
1、全连接层前向传播和梯度计算
2、ReLU

In [2]

# 为了使层能够组建起来,实现前向传播和反向传播,首先定义层的基类Layer# Layer的几个主要方法说明:#   forward: 实现前向传播#   backward: 实现反向传播#   parameters: 返回该层的参数,传入优化器进行优化class Layer:    def __init__(self, name='layer', *args, **kwargs):        self.name = name    def forward(self, *args, **kwargs):        raise NotImplementedError    def backward(self):        raise NotImplementedError    def parameters(self):        return []    def __call__(self, *args, **kwargs):        return self.forward(*args, **kwargs)    def __str__(self):        return self.nameclass Linear(Layer):    """    input X, shape: [N, C]    output Y, shape: [N, O]    weight W, shape: [C, O]    bias b, shape: [1, O]    grad dY, shape: [N, O]    forward formula:        Y = X @ W + b   # @表示矩阵乘法    backward formula:        dW = X.T @ dY        db = sum(dY, axis=0)        dX = dY @ W.T    """    def __init__(        self,        in_features,        out_features,        name='linear',        weight_attr=Normal(),        bias_attr=Constant(),        *args,        **kwargs        ):        super().__init__(name=name, *args, **kwargs)        self.weights = Tensor((in_features, out_features))        self.weights.data = weight_attr(self.weights.data.shape)        self.bias = Tensor((1, out_features))        self.bias.data = bias_attr(self.bias.data.shape)        self.input = None    def forward(self, x):        self.input = x        output = np.dot(x, self.weights.data) + self.bias.data        return output    def backward(self, gradient):        self.weights.grad += np.dot(self.input.T, gradient)  # dy / dw        self.bias.grad += np.sum(gradient, axis=0, keepdims=True)  # dy / db         input_grad = np.dot(gradient, self.weights.data.T)  # dy / dx        return input_grad    def parameters(self):        return [self.weights, self.bias]    def __str__(self):        string = "linear layer, weight shape: {}, bias shape: {}".format(self.weights.data.shape, self.bias.data.shape)        return stringclass ReLU(Layer):    """    forward formula:        relu = x if x >= 0             = 0 if x  0)    """    def __init__(self, name='relu', *args, **kwargs):        super().__init__(name=name, *args, **kwargs)        self.activated = None    def forward(self, x):        x[x  0)

   

3、模型组网

将层串联起来,实现前向传播和反向传播。

In [3]

# 模型组网的功能是将层串起来,实现数据的前向传播和梯度的反向传播# 添加层的时候,按照顺序添加层的参数# Sequential方法说明:#   add: 向组网中添加层#   forward: 按照组网构建的层顺序,依次前向传播#   backward: 接收损失函数的梯度,按照层的逆序反向传播class Sequential:    def __init__(self, *args, **kwargs):        self.graphs = []        self._parameters = []        for arg_layer in args:            if isinstance(arg_layer, Layer):                self.graphs.append(arg_layer)                self._parameters += arg_layer.parameters()    def add(self, layer):        assert isinstance(layer, Layer), "The type of added layer must be Layer, but got {}.".format(type(layer))        self.graphs.append(layer)        self._parameters += layer.parameters()    def forward(self, x):        for graph in self.graphs:            x = graph(x)        return x    def backward(self, grad):        # grad backward in inverse order of graph        for graph in self.graphs[::-1]:            grad = graph.backward(grad)    def __call__(self, *args, **kwargs):        return self.forward(*args, **kwargs)    def __str__(self):        string = 'Sequential:n'        for graph in self.graphs:            string += graph.__str__() + 'n'        return string    def parameters(self):        return self._parameters

   

4、优化器

实现了SGD优化器(带动量)
1、动量梯度下降

In [4]

# 优化器主要完成根据梯度来优化参数的任务,其主要参数有学习率和正则化类型和正则化系数# Optimizer主要方法:#   step: 梯度反向传播后调用,该方法根据计算出的梯度,对参数进行优化#   clear_grad: 模型调用backward后,梯度会进行累加,如果已经调用step优化过参数,需要将使用过的梯度清空#   get_decay: 根据不同的正则化方法,计算出正则化惩罚值class Optimizer:    """    optimizer base class.    Args:        parameters (Tensor): parameters to be optimized.        learning_rate (float): learning rate. Default: 0.001.        weight_decay (float): The decay weight of parameters. Defaylt: 0.0.        decay_type (str): The type of regularizer. Default: l2.    """    def __init__(self, parameters, learning_rate=0.001, weight_decay=0.0, decay_type='l2'):        assert decay_type in ['l1', 'l2'], "only support decay_type 'l1' and 'l2', but got {}.".format(decay_type)        self.parameters = parameters        self.learning_rate = learning_rate        self.weight_decay = weight_decay        self.decay_type = decay_type            def step(self):        raise NotImplementedError    def clear_grad(self):        for p in self.parameters:            p.clear_grad()    def get_decay(self, g):        if self.decay_type == 'l1':            return self.weight_decay        elif self.decay_type == 'l2':            return self.weight_decay * g# 基本的梯度下降法为(不带正则化):# W = W - learn_rate * dW# 带动量的梯度计算方法(减弱的梯度的随机性):# dW = (momentum * v) + (1 - momentum) * dWclass SGD(Optimizer):    def __init__(self, momentum=0.9, *args, **kwargs):        super().__init__(*args, **kwargs)        self.momentum = momentum        self.velocity = []        for p in self.parameters:            self.velocity.append(np.zeros_like(p.grad))    def step(self):        for p, v in zip(self.parameters, self.velocity):            decay = self.get_decay(p.grad)            v = self.momentum * v + p.grad + decay # 动量计算            p.data = p.data - self.learning_rate * v

   

5、损失函数

实现了MSE损失函数。

In [5]

# 损失函数的设计延续了Layer的模式,但是因为需要注意的是forward和backward部分有些不同# MSE_loss = (predict_value - label) ^ 2# MSE方法和Layer的区别:#   forward:y是组网输出的值,target是目标值(这里的输入是组网的输出和目标值),前向传播的同时把dloss / dy 计算出来#   backward: 没有参数,因为在forward的时候,计算出了dloss / dy,所以这里不需要输入参数class MSE(Layer):    """    Mean Square Error:        J = 0.5 * (y - target)^2    gradient formula:        dJ/dy = y - target    """    def __init__(self, name='mse', reduction='mean', *args, **kwargs):        super().__init__(name=name, *args, **kwargs)        assert reduction in ['mean', 'none', 'sum'], "reduction only support 'mean', 'none' and 'sum', but got {}.".format(reduction)        self.reduction = reduction        self.pred = None        self.target = None    def forward(self, y, target):        assert y.shape == target.shape, "The shape of y and target is not same, y shape = {} but target shape = {}".format(y.shape, target.shape)        self.pred = y        self.target = target        loss = 0.5 * np.square(y - target)        if self.reduction is 'mean':            return loss.mean()        elif self.reduction is 'none':            return loss        else:            return loss.sum()    def backward(self):        gradient = self.pred - self.target        return gradient

   

6、dataset

In [6]

# 这里仿照PaddlePaddle,Dataset需要实现__getitem__和__len__方法class Dataset:    def __init__(self, *args, **kwargs):        pass    def __getitem__(self, idx):        raise NotImplementedError("'{}' not implement in class {}"                                  .format('__getitem__', self.__class__.__name__))    def __len__(self):        raise NotImplementedError("'{}' not implement in class {}"                                  .format('__len__', self.__class__.__name__))# 根据dataset和一些设置,生成每个batch在dataset中的索引class BatchSampler:    def __init__(self, dataset=None, shuffle=False, batch_size=1, drop_last=False):        self.batch_size = batch_size        self.drop_last = drop_last        self.shuffle = shuffle        self.num_data = len(dataset)        if self.drop_last or (self.num_data % batch_size == 0):            self.num_samples = self.num_data // batch_size        else:            self.num_samples = self.num_data // batch_size + 1        indices = np.arange(self.num_data)        if shuffle:            np.random.shuffle(indices)        if drop_last:            indices = indices[:self.num_samples * batch_size]        self.indices = indices    def __len__(self):        return self.num_samples    def __iter__(self):        batch_indices = []        for i in range(self.num_samples):            if (i + 1) * self.batch_size  0:            yield batch_indices# 根据sampler生成的索引,从dataset中取数据,并组合成一个batchclass DataLoader:    def __init__(self, dataset, sampler=BatchSampler, shuffle=False, batch_size=1, drop_last=False):        self.dataset = dataset        self.sampler = sampler(dataset, shuffle, batch_size, drop_last)    def __len__(self):        return len(self.sampler)    def __call__(self):        self.__iter__()    def __iter__(self):        for sample_indices in self.sampler:            data_list = []            label_list = []            for indice in sample_indices:                data, label = self.dataset[indice]                data_list.append(data)                label_list.append(label)            yield np.stack(data_list, axis=0), np.stack(label_list, axis=0)

   

四、线性回归示例

本小节的目标是使用上面完成的类,搭建一个简单的模型,并且实现线性拟合的过程。

1、提取数据

In [7]

# 提取训练数据(这里是一个预先生成的f(x) = sin(x) + noise的数据)!unzip -oq ~/data/data119921/sin_data.zip

   

2、查看数据分布

In [8]

# 绘制原始数据图像import matplotlib.pyplot as plt%matplotlib inlinex_path = "x.npy"y_path = "y.npy"X = np.load(x_path)Y = np.load(y_path)plt.scatter(X, Y)

       


               

               

3、搭建模型,设置超参数

In [9]

epoches = 1000batch_size = 4learning_rate = 0.01weight_decay = 0.0train_number = 100 # 选择的训练数据数量,总共200,这里仅挑选一部分训练,否则数据太多过拟合看不出来# 继承之前定义的Dataset,定义一个简单的Datasetclass LinearDataset(Dataset):    def __init__(self, X, Y):        self.X = X        self.Y = Y    def __len__(self):        return len(self.X)    def __getitem__(self, idx):        return self.X[idx], self.Y[idx]# 搭建一个简单的模型model = Sequential(    Linear(1, 16, name='linear1'),    ReLU(name='relu1'),    Linear(16, 64, name='linear2'),    ReLU(name='relu2'),    Linear(64, 16, name='linear2'),    ReLU(name='relu3'),    Linear(16, 1, name='linear2'),)opt = SGD(parameters=model.parameters(), learning_rate=learning_rate, weight_decay=weight_decay, decay_type='l2')loss_fn = MSE()print(model)

       

Sequential:linear layer, weight shape: (1, 16), bias shape: (1, 16)relu1linear layer, weight shape: (16, 64), bias shape: (1, 64)relu2linear layer, weight shape: (64, 16), bias shape: (1, 16)relu3linear layer, weight shape: (16, 1), bias shape: (1, 1)

       

4、训练

In [10]

# 挑选部分数据训练,数据分布图绘制indexes = np.arange(X.shape[0])train_indexes = np.random.choice(indexes, train_number)X = X[train_indexes]Y = Y[train_indexes]plt.scatter(X, Y)

       


               

               In [ ]

# 构建dataset和dataloader,开始训练train_dataset = LinearDataset(X, Y)train_dataloader = DataLoader(train_dataset, shuffle=True, batch_size=batch_size, drop_last=True)for epoch in range(1, epoches):    losses = []    for x, y in train_dataloader:        pred = model(x)        loss = loss_fn(pred, y)        losses.append(loss)        grad = loss_fn.backward()        model.backward(grad)        opt.step()        opt.clear_grad()    print("epoch: {}. loss: {}".format(epoch, np.array(losses).mean()))

   

5、验证效果

In [12]

# 训练结束,生成比较密集的点,绘制曲线查看模型效果val_number = 500  # 验证点的个数X_val = np.linspace(-np.pi, np.pi, val_number).reshape(val_number, 1)Y_val = np.sin(X_val) * 2val_dataset = LinearDataset(X_val, Y_val)val_dataloader = DataLoader(val_dataset, shuffle=False, batch_size=2, drop_last=False)all_pred = []for x, y in val_dataloader:    pred = model(x)    all_pred.append(pred)all_pred = np.vstack(all_pred)plt.plot(X_val, Y_val, color='green', label='true')plt.plot(X_val, all_pred, color='red', label='predict')plt.legend()plt.show()

       

               In [13]

# 打印模型权重for g in model.graphs:    try:        print(g.name, "  weights: ", g.weights.data)        print(g.name, "  bias: ", g.bias.data)    except:        # relu 没有参数        pass

       

linear1   weights:  [[-3.39505853e-01  1.82815127e-01  3.41670755e-04  4.51586227e-01   1.53022752e-01  4.51654343e-01 -3.72304150e-01  2.76332489e-01  -1.38630030e-01 -9.45745032e-02 -2.80274033e-02  3.21501804e-01   5.63259058e-04  3.02464553e-01  4.12779030e-01 -5.02756806e-01]]linear1   bias:  [[-0.27559667  0.25060406 -0.00106264  0.25735576  0.15667835 -0.29261948  -0.22068097  0.34773508 -0.06852324 -0.06383495 -0.00121021 -0.20815822  -0.00207523  0.41023867 -0.14955467 -0.27659916]]linear2   weights:  [[ 0.00802045 -0.01371165 -0.02685921 ...  0.02362987 -0.00621883  -0.02786108] [-0.00452856 -0.00503155  0.04844489 ... -0.00561967  0.0025664   0.00678349] [-0.00615242 -0.00192324  0.00115901 ... -0.00903875  0.00314179  -0.01176954] ... [-0.00625044 -0.00103386  0.12367338 ... -0.0048607  -0.01353281  -0.00611369] [ 0.00415564 -0.01963549  0.12541482 ...  0.01609308 -0.00733272  -0.01286687] [ 0.03625054 -0.03395289  0.00589992 ...  0.02610544  0.00226727  -0.01638553]]linear2   bias:  [[-5.80917490e-02  5.01950195e-02 -2.29461260e-01  8.53813886e-01   0.00000000e+00  5.57391247e-03  0.00000000e+00 -1.83248948e-01   2.48837634e-01 -1.11183245e-01 -3.48240873e-01 -4.50779643e-02  -1.28934035e-02  1.12025269e-01  3.79346683e-01  1.35687659e-01   1.21481402e-01 -8.63197975e-02  1.85562909e-03 -2.77419326e-01   7.55994579e-01  0.00000000e+00  0.00000000e+00 -1.42549552e-01   2.88624148e-01 -1.72867527e-01  1.70860914e-01  2.40404679e-01  -8.84156448e-02 -8.03972453e-02 -2.88965818e-01  9.83171145e-02   0.00000000e+00  3.17059611e-01 -1.04739710e-01 -1.16109983e-03   4.49676180e-01  5.43205541e-01  0.00000000e+00  2.16567560e-01   2.66316055e-01  6.52556933e-02  4.21085572e-01 -1.75897451e-01   1.70725040e-01  4.57763929e-01  5.90660615e-02  0.00000000e+00   2.24770074e-01  4.92650106e-01  3.92872747e-01 -1.09088249e-03   3.87059634e-01  1.32970903e-01 -8.24098597e-04  6.95018101e-01  -2.67006851e-01 -3.10753157e-03  0.00000000e+00 -4.12923279e-02  -1.75980184e-02 -4.42488935e-02  0.00000000e+00  4.16345087e-02]]linear2   weights:  [[-0.00030464 -0.01316401 -0.00232969 ... -0.00735164  0.02166657   0.00125336] [ 0.01472182 -0.01163708  0.00238465 ... -0.01319246  0.02852089   0.00038934] [-0.01692646 -0.00244135 -0.00771588 ...  0.05227914 -0.14514223   0.01070569] ... [ 0.00063122  0.00322329 -0.00613279 ... -0.00629652  0.02223584  -0.00575858] [ 0.00141447  0.00212887 -0.01180259 ... -0.00223564  0.00415438   0.00539367] [-0.00545804 -0.01563078  0.00269196 ... -0.01580513  0.0176982  -0.00294621]]linear2   bias:  [[ 2.24308947e-02  4.52850508e-02 -6.85257176e-04  4.71155020e-01  -2.25538467e-02  4.94627319e-01 -3.26158083e-04  8.32043208e-01   1.27510619e+00 -1.93002987e-02  8.65411471e-01 -1.87107957e-02  -2.39317258e-02  3.22988423e-02  8.12310457e-01  1.43143661e-02]]linear2   weights:  [[-0.02986098] [-0.07522691] [-0.00509935] [-0.79988172] [-0.1247629 ] [-0.83384197] [ 0.0070327 ] [ 0.916285  ] [ 1.40066481] [ 0.02468298] [-1.16986177] [-0.17584702] [-0.22990252] [-0.18561223] [ 0.89437478] [-0.02239539]]linear2   bias:  [[0.47546356]]

       

以上就是【深度学习实战】一、Numpy手撸神经网络实现线性回归的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/57359.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
如何使用Docker进行应用的监控和日志管理
上一篇 2025年11月10日 05:10:03
淘宝直播真的能赚钱吗?赚钱的方式有哪些?月入10万+?揭秘淘宝直播6大赚钱方式,新手也能快速上手!
下一篇 2025年11月10日 05:12:01

相关推荐

  • composer require-dev和require有什么不同_Composer Require与Require-Dev区别解析

    require用于声明项目运行必需的依赖,如框架、数据库组件和第三方SDK,这些包会随项目部署到生产环境;2. require-dev用于声明仅在开发和测试阶段需要的工具,如PHPUnit、PHPStan、Faker等,不会默认部署到生产环境;3. 安装时composer install根据环境决定…

    2026年5月10日
    1000
  • Matplotlib 地图中多类型图例的创建与优化

    Matplotlib 地图中多类型图例的创建与优化Matplotlib 地图中多类型图例的创建与优化Matplotlib 地图中多类型图例的创建与优化Matplotlib 地图中多类型图例的创建与优化

    本教程旨在解决matplotlib地图可视化中,如何在一个图例中同时展示颜色块(如区域分类)和自定义标记(如特定兴趣点)的问题。文章详细介绍了当传统`patch`对象无法正确显示标记时,如何利用`matplotlib.lines.line2d`创建标记图例句柄,并将其与颜色块图例句柄合并,从而生成一…

    2026年5月10日 用户投稿
    100
  • Golang JSON序列化:控制敏感字段暴露的最佳实践

    本教程探讨golang中如何高效控制结构体字段在json序列化时的可见性。当需要将包含敏感信息的结构体数组转换为json响应时,通过利用`encoding/json`包提供的结构体标签,特别是`json:”-“`,可以轻松实现对特定字段的忽略,从而避免敏感数据泄露,确保api…

    2026年5月10日
    000
  • 比特币新手教程 比特币交易平台有哪些

    比特币是一种去中心化的数字货币,基于区块链技术实现点对点交易,具有匿名性、有限发行和不可篡改等特点;新手可通过交易所购买,P2P交易获得比特币,常用平台包括Binance、OKX和Huobi;交易流程包括注册账户、实名认证、绑定支付方式、充值法币并下单购买,可选择市价单或限价单;比特币存储方式有交易…

    2026年5月10日
    000
  • c++中的SFINAE技术是什么_c++模板编程中的SFINAE原理与应用

    SFINAE 是“替换失败不是错误”的原则,指模板实例化时若参数替换导致错误,只要存在其他合法候选,编译器不报错而是继续重载决议。它用于条件启用模板、类型检测等场景,如通过 decltype 或 enable_if 控制函数重载,实现类型特征判断。尽管 C++20 引入 Concepts 简化了部分…

    2026年5月10日
    000
  • Go语言mgo查询构建:深入理解bson.M与日期范围查询的正确实践

    本文旨在解决go语言mgo库中构建复杂查询时,特别是涉及嵌套`bson.m`和日期范围筛选的常见错误。我们将深入剖析`bson.m`的类型特性,解释为何直接索引`interface{}`会导致“invalid operation”错误,并提供一种推荐的、结构清晰的代码重构方案,以确保查询条件能够正确…

    2026年5月10日
    100
  • RichHandler与Rich Progress集成:解决显示冲突的教程

    在使用rich库的`richhandler`进行日志输出并同时使用`progress`组件时,可能会遇到显示错乱或溢出问题。这通常是由于为`richhandler`和`progress`分别创建了独立的`console`实例导致的。解决方案是确保日志处理器和进度条组件共享同一个`console`实例…

    2026年5月10日
    000
  • Golang goroutine与channel调试技巧

    使用go run -race检测数据竞争,结合runtime.NumGoroutine监控协程数量,通过pprof分析阻塞调用栈,利用select超时避免永久阻塞,有效排查goroutine泄漏、死锁和数据竞争问题。 Go语言的goroutine和channel是并发编程的核心,但它们也带来了调试上…

    2026年5月10日
    000
  • 松下案例入选《2025企业社会责任竞争力指数报告》

    松下案例入选《2025企业社会责任竞争力指数报告》松下案例入选《2025企业社会责任竞争力指数报告》松下案例入选《2025企业社会责任竞争力指数报告》松下案例入选《2025企业社会责任竞争力指数报告》

    11月14日,中国新闻社《中国新闻周刊》在北京成功举办了第二十一届企业社会责任系列活动·2025责任之星特别节目。活动以“致明天:焕新责任竞争力”为主题,汇聚了来自政府、企业及学术界的多位代表,共同探讨新时代下企业如何通过责任创新打造核心竞争力。松下电器(中国)有限公司总裁赵炳弟作为企业界代表受邀出…

    2026年5月10日 用户投稿
    000
  • 使用 Jupyter Notebook 进行探索性数据分析

    Jupyter Notebook通过单元格实现代码与Markdown结合,支持数据导入(pandas)、清洗(fillna)、探索(matplotlib/seaborn可视化)、统计分析(describe/corr)和特征工程,便于记录与分享分析过程。 Jupyter Notebook 是进行探索性…

    2026年5月10日
    000
  • 《魔兽世界》将于6月11日开启国服回归技术测试

    《魔兽世界》将于6月11日开启国服回归技术测试《魔兽世界》将于6月11日开启国服回归技术测试《魔兽世界》将于6月11日开启国服回归技术测试《魔兽世界》将于6月11日开启国服回归技术测试

    《%ign%ignore_a_1%re_a_1%》官方宣布,将于6月11日开启国服回归技术测试,时间为7天,并称可以在6月内正式开服,玩家们可以访问官网下载战网客户端并预下载“巫妖王之怒”客户端,技术测试详情见下图。 WordAi WordAI是一个AI驱动的内容重写平台 53 查看详情 以上就是《…

    2026年5月10日 用户投稿
    200
  • php常量怎么用_PHP常量(define/const)定义与使用方法

    PHP中可通过define函数和const关键字定义常量,用于存储不可变值。define适用于全局作用域,支持动态名称和条件定义,如define(‘SITE_NAME’, ‘MyWebsite’);const在编译时生效,语法简洁但限制多,只能在类或全…

    2026年5月10日
    000
  • 如何在HTML中插入表单元素_HTML表单控件与输入类型使用指南

    HTML表单通过标签构建,包含action和method属性定义数据提交目标与方式,常用input类型如text、password、email等适配不同输入需求,配合label、required、placeholder提升可用性,结合textarea、select、button等控件实现完整交互,是…

    2026年5月10日
    100
  • 创建指定大小并填充特定数据的Golang文件教程

    本文将介绍如何使用Golang创建一个指定大小的文件,并用特定数据填充它。我们将使用 `os` 包提供的函数来创建和截断文件,从而实现快速生成大文件的目的。示例代码展示了如何创建一个10MB的文件,并将其填充为全零数据。掌握这些方法,可以方便地在例如日志系统或磁盘队列等场景中,预先创建测试文件或初始…

    2026年5月10日
    000
  • Python命令怎样使用profile分析脚本性能 Python命令性能分析的基础教程

    使用Python的cProfile模块分析脚本性能最直接的方式是通过命令行执行python -m cProfile your_script.py,它会输出每个函数的调用次数、总耗时、累积耗时等关键指标,帮助定位性能瓶颈;为进一步分析,可将结果保存为文件python -m cProfile -o ou…

    2026年5月10日
    000
  • 使用 WebCodecs VideoDecoder 实现精确逐帧回退

    本文档旨在解决在使用 WebCodecs VideoDecoder 进行视频解码时,实现精确逐帧回退的问题。通过比较帧的时间戳与目标帧的时间戳,可以避免渲染中间帧,从而提高用户体验。本文将提供详细的解决方案和示例代码,帮助开发者实现精确的视频帧控制。 在使用 WebCodecs VideoDecod…

    2026年5月10日
    000
  • 如何插入查询结果数据_SQL插入Select查询结果方法

    如何插入查询结果数据_SQL插入Select查询结果方法如何插入查询结果数据_SQL插入Select查询结果方法如何插入查询结果数据_SQL插入Select查询结果方法如何插入查询结果数据_SQL插入Select查询结果方法

    使用INSERT INTO…SELECT语句可高效插入数据,通过NOT EXISTS、LEFT JOIN、MERGE语句或唯一约束避免重复;表结构不一致时可通过别名、类型转换、默认值或计算字段处理;结合存储过程可提升可维护性,支持参数化与动态SQL。 将查询结果数据插入到另一个表中,可以…

    2026年5月10日 用户投稿
    000
  • Discord.py 交互按钮超时与持久化解决方案

    本教程旨在解决Discord.py中交互按钮在一段时间后出现“This Interaction Failed”错误的问题。我们将深入探讨视图(View)的超时机制,并提供通过正确设置timeout参数以及利用bot.add_view()方法实现按钮持久化的具体方案,确保您的机器人交互功能稳定可靠,即…

    2026年5月10日
    000
  • Debian Copilot的社区活跃度如何

    debian copilot是codeberg社区维护的ai助手,旨在为debian用户提供服务。尽管搜索结果中没有直接提供关于debian copilot社区支持活跃度的具体数据,但我们可以通过debian社区的整体活跃度和特点来推断其活跃性。 Debian社区的一般情况: Debian拥有详尽的…

    2026年5月10日
    000
  • JavaScript 动态菜单点击高亮效果实现教程

    本教程详细介绍了如何使用 JavaScript 实现动态菜单的点击高亮功能。通过事件委托和状态管理,当用户点击菜单项时,被点击项会高亮显示(绿色),同时其他菜单项恢复默认样式(白色)。这种方法避免了不必要的DOM操作,提高了性能和代码可维护性,确保了无论点击方向如何,功能都能稳定运行。 动态菜单高亮…

    2026年5月10日
    200

发表回复

登录后才能评论
关注微信