【分类】【损失函数】处理类别不平衡:CEFL 和 CEFL2 损失函数的实现与应用

引言

在深度学习中的分类问题中,类别不平衡问题是常见的挑战之一。尤其在面部表情分类任务中,不同表情类别的样本数量可能差异较大,比如“开心”表情的样本远远多于“生气”表情。面对这种情况,普通的交叉熵损失函数容易导致模型过拟合到大类样本,忽略少数类样本。为了有效解决类别不平衡问题,Class-balanced Exponential Focal Loss (CEFL)Class-balanced Exponential Focal Loss 2 (CEFL2) 损失函数应运而生。

本文将详细介绍CEFLCEFL2损失函数,阐述它们在面部表情分类任务中的应用,并提供PyTorch实现代码,带有详细注释,适合开发者在实际项目中使用。

目录

  • 引言
  • 一、CEFL 和 CEFL2 损失函数概述
    • 1.1 Focal Loss 的背景
    • 1.2 CEFL 的定义
    • 1.3 CEFL2 的扩展与改进
    • 1.4 对比 CEFL 和 CEFL2
  • 二、面部表情分类中的类别不平衡问题
    • 2.1 类别不平衡对模型训练的影响
    • 2.2 解决策略
  • 三、如何使用 CEFL 和 CEFL2 损失函数
    • 3.1 CEFL 和 CEFL2 损失函数的核心公式
    • 3.2 类别频率的计算与应用
    • 3.3 计算类别频率的代码示例
  • 四、PyTorch 实现
    • 4.1 CEFL 实现
    • 4.2 CEFL2 实现
    • 4.3 训练过程
  • 总结
  • 参考文献

一、CEFL 和 CEFL2 损失函数概述

1.1 Focal Loss 的背景

在传统的分类任务中,交叉熵损失(Cross-Entropy Loss)常常用作优化目标。然而,交叉熵损失函数并没有很好地解决类别不平衡问题,特别是在少数类样本较少时。Focal Loss(焦点损失)由 Lin et al. (2017) 提出,主要用于解决 类别不平衡 问题,旨在通过减小容易分类样本的损失权重,增强模型对困难样本的关注。

Focal Loss 引入了一个调节因子 ( 1 − p t ) γ (1 - p_t)^\gamma (1pt)γ,通过减小容易分类样本的损失,聚焦模型训练中的难分类样本,从而引导模型更加关注难以分类的样本,尤其在类别不平衡的情形下,避免多数类样本主导训练。其公式如下:

F L ( p t ) = − α t ( 1 − p t ) γ log ⁡ ( p t ) FL(p_t) = -\alpha_t (1 - p_t)^\gamma \log(p_t) FL(pt)=αt(1pt)γlog(pt)

其中:

  • p t p_t pt 是预测类别的概率。
  • γ \gamma γ 调节因子,是一个常量超参数,通常设为大于 0 的值(例如 2),用于控制易分类样本的惩罚程度。较大的 γ \gamma γ 会增加对难分类样本的关注。当 γ \gamma γ=0时 ,焦点损失在形式上等价于交叉熵损失。
  • α t \alpha_t αt 是一个用于平衡类别不平衡的权重因子,可以根据每个类别的频率进行调整。

1.2 CEFL 的定义

Class-balanced Exponential Focal Loss (CEFL) 是在 Focal Loss 基础上的进一步改进。它通过在焦点损失中引入类别平衡策略,赋予每个类别不同的权重,从而有效地应对类别不平衡问题。
通过引入类别平衡策略来处理类别不平衡问题。与 Focal Loss 相比,CEFL 会根据每个类别的频率赋予不同的权重,从而调整损失函数,特别是在类别不平衡的情况下更加有效。

CEFL 的公式如下:

CEFL ( p t ) = − ( 1 − p t ) log ⁡ ( p t ) − p t ( 1 − p t ) γ log ⁡ ( p t ) \text{CEFL}(p_t) = -(1 - p_t) \log(p_t) - p_t (1 - p_t)^\gamma \log(p_t) CEFL(pt)=(1pt)log(pt)pt(1pt)γlog(pt)

其中:

  • p t p_t pt:表示样本属于正确类别的预测概率。
  • γ \gamma γ:( γ \gamma γ>0)焦点损失的调节因子,通常设置为 2,用于放大难以分类的样本的损失,使得模型更加关注困难的样本。注意当 γ \gamma γ=0时 ,CEFL损失在形式上是交叉熵损失。

公式的第一项是传统的交叉熵损失,第二项则是引入焦点损失后的部分,用来减小易分类样本的影响权重,使得困难样本对总损失的贡献更大,从而模型更加专注于难分类的样本。特别地,第二项通过 $( (1 - p_t)^\gamma ) $调节了模型对不同难度样本的关注程度。

1.3 CEFL2 的扩展与改进

CEFL2 是对 CEFL 损失函数的扩展,它进一步考虑了类别的频率信息,通过精细的调整每个类别的损失权重,使得模型在极度不平衡的数据集上表现更好。CEFL2 引入了类别频率(class frequency)作为权重,使用每个类别在数据集中出现的频率来调整每个类别的影响。

CEFL2 的公式为:
CEFL2 ( p t ) = − ( 1 − p t ) 2 ( 1 − p t ) 2 + p t 2 log ⁡ ( p t ) − p t 2 ( 1 − p t ) 2 + p t 2 ( 1 − p t ) γ log ⁡ ( p t ) \text{CEFL2}(p_t) = -\frac{(1 - p_t)^2}{(1 - p_t)^2 + p_t^2} \log(p_t) - \frac{p_t^2}{(1 - p_t)^2 + p_t^2} (1 - p_t)^\gamma \log(p_t) CEFL2(pt)=(1pt)2+pt2(1pt)2log(pt)(1pt)2+pt2pt2(1pt)γlog(pt)

其中:

  • 第一个项和第二个项分别对应于不同类别的损失权重和焦点损失的加权贡献。
  • ( 1 − p t ) 2 ( 1 − p t ) 2 + p t 2 \frac{(1 - p_t)^2}{(1 - p_t)^2 + p_t^2} (1pt)2+pt2(1pt)2 p t 2 ( 1 − p t ) 2 + p t 2 \frac{p_t^2}{(1 - p_t)^2 + p_t^2} (1pt)2+pt2pt2是根据类别的频率对损失进行调整的权重项。具体来说,它们的比例反映了每个类别相对于整个数据集的频率。

该损失函数通过动态调整类别的权重,使得模型对少数类样本的损失更加敏感,从而提升对少数类的识别能力。

1.4 对比 CEFL 和 CEFL2

特性CEFLCEFL2
核心思想结合焦点损失和类别平衡引入类别频率,进一步优化类别平衡
类别权重通过 α t \alpha_t αt 设置权重通过类别频率动态调整权重
适用场景通用的类别不平衡问题极度不平衡的类别问题
主要优点简单有效,适合一般类别不平衡问题更适用于处理极端类别不平衡的数据

二、面部表情分类中的类别不平衡问题

2.1 类别不平衡对模型训练的影响

在面部表情分类任务中,可能会出现不同表情类别样本不平衡的情况。例如,常见表情如“开心”或“惊讶”在数据集中占有大量样本,而“生气”或“害怕”等情绪类别可能样本较少。这种类别不平衡将导致模型偏向于大类表情,忽视少数类表情,从而影响分类性能,尤其是对少数类样本的识别。

影响

  • 模型可能会对大类表情有较高的分类准确率,而忽视少数类表情。
  • 少数类表情样本的训练效果较差,难以学到有效的特征表示。

2.2 解决策略

使用 CEFLCEFL2 损失函数可以有效缓解类别不平衡问题,在训练过程中让模型更多关注少数类样本,从而提升少数类样本的分类效果。

三、如何使用 CEFL 和 CEFL2 损失函数

3.1 CEFL 和 CEFL2 损失函数的核心公式

损失函数公式说明
CEFL − ( 1 − p t ) log ⁡ ( p t ) − p t ( 1 − p t ) γ log ⁡ ( p t ) -(1 - p_t) \log(p_t) - p_t (1 - p_t)^\gamma \log(p_t) (1pt)log(pt)pt(1pt)γlog(pt)基于 Focal Loss,加入类别权重调整
CEFL2 − ( 1 − p t ) 2 ( 1 − p t ) 2 + p t 2 log ⁡ ( p t ) − p t 2 ( 1 − p t ) 2 + p t 2 ( 1 − p t ) γ log ⁡ ( p t ) -\frac{(1 - p_t)^2}{(1 - p_t)^2 + p_t^2} \log(p_t) - \frac{p_t^2}{(1 - p_t)^2 + p_t^2} (1 - p_t)^\gamma \log(p_t) (1pt)2+pt2(1pt)2log(pt)(1pt)2+pt2pt2(1pt)γlog(pt)引入类别频率,进一步调整损失权重

3.2 类别频率的计算与应用

CEFL2 中,需要根据训练集中的类别分布计算每个类别的频率。这些频率作为权重在损失函数中进行调整。类别频率的计算公式如下:

class_freq t = 1 num_samples_in_class t \text{class\_freq}_t = \frac{1}{\text{num\_samples\_in\_class}_t} class_freqt=num_samples_in_classt1

随后,将类别频率归一化,使其和为 1:

normalized_class_freq t = class_freq t ∑ class_freq \text{normalized\_class\_freq}_t = \frac{\text{class\_freq}_t}{\sum \text{class\_freq}} normalized_class_freqt=class_freqclass_freqt

3.3 计算类别频率的代码示例

import numpy as np

def compute_class_frequencies(targets, num_classes):
    # 计算每个类别的样本数量
    class_counts = np.bincount(targets.numpy(), minlength=num_classes)
    
    # 防止除零错误,计算每个类别的频率
    class_freq = 1.0 / (class_counts + 1e-6)
    
    # 归一化类别频率
    class_freq = class_freq / np.sum(class_freq)
    
    return torch.tensor(class_freq, dtype=torch.float32)

四、PyTorch 实现

4.1 CEFL 实现

import torch	
import torch.nn as nn
import torch.nn.functional as F

class CEFL(nn.Module):
    def __init__(self, alpha, gamma=2.0):
        super(CEFL, self).__init__()
        self.alpha = alpha  # 类别的权重
        self.gamma = gamma  # 焦点损失的调节参数

    def forward(self, inputs, targets):
        # 使用softmax计算类别概率
        p = F.softmax(inputs, dim=1)
        
        # 选择正确类别的预测概率
        p_t = p.gather(1, targets.view(-1, 1))
        
        # 计算损失
        loss = -self.alpha * (1 - p_t) ** self.gamma * torch.log(p_t)
        
        return loss.mean()

代码解释

  1. 类的构造函数 (__init__):

    • alpha: 这是一个超参数,用于对各类别的损失加权。它在训练过程中控制类别的重要性。一般来说,alpha 用来增加或减少某些类别的损失权重(通常在类别不平衡时使用)。
    • gamma: 这是焦点损失的调节参数。焦点损失(Focal Loss)是一种为了解决类别不平衡问题而提出的损失函数,gamma 控制模型对易分类样本和难分类样本的关注程度。较大的 gamma 会增加对难分类样本的关注。
  2. forward 方法:

    • inputs: 网络的输出(通常是 logits),大小为 (batch_size, num_classes),表示每个样本对于每个类别的预测得分。
    • targets: 真实标签,大小为 (batch_size,),是样本的正确类别标签。
  3. F.softmax(inputs, dim=1):

    • 对模型的输出 logits 进行 softmax 计算,将其转化为概率分布。softmax 的作用是将每个样本的所有类别得分转化为一个概率分布,概率值的总和为 1。
    • dim=1 表示在类别维度上进行归一化,即每个样本的类别概率和为 1。
  4. p.gather(1, targets.view(-1, 1)):

    • p 是通过 softmax 得到的类别概率矩阵,p.gather(1, targets.view(-1, 1)) 选择每个样本的正确类别的概率。
    • gather(1, targets.view(-1, 1)) 会根据 targets 中给出的标签索引,从 p 中提取每个样本对应类别的概率。view(-1, 1)targets 转换为列向量,确保正确地索引每个样本的类别。
  5. 焦点损失部分:

    • loss = -self.alpha * (1 - p_t) ** self.gamma * torch.log(p_t):
      • p_t: 每个样本在正确类别上的预测概率。
      • (1 - p_t) ** self.gamma: 这是焦点损失的核心部分。它会放大模型对难分类样本的关注。对于那些预测较为确定的样本(即 p_t 接近 1),(1 - p_t) 会较小,损失减少;对于难分类样本(即 p_t 接近 0),(1 - p_t) 会较大,损失增加。
      • self.alpha: 用于控制类别的重要性。如果某些类别较为不平衡,alpha 可以增加这些类别的损失权重。
      • torch.log(p_t): 计算类别概率的对数值,通常是交叉熵的一部分。
  6. 返回平均损失:

    • loss.mean(): 返回所有样本的平均损失。

4.2 CEFL2 实现

import torch
import torch.nn as nn
import torch.nn.functional as F

class CEFL2(nn.Module):
    def __init__(self, class_frequencies, gamma=2.0):
        super(CEFL2, self).__init__()
        self.class_frequencies = class_frequencies  # 类别频率
        self.gamma = gamma  # 焦点损失的调节参数

    def forward(self, inputs, targets):
        # 使用softmax计算类别概率
        p = F.softmax(inputs, dim=1)
        
        # 选择正确类别的预测概率
        p_t = p.gather(1, targets.view(-1, 1))

        # 计算每个类别的加权损失
        loss_term_1 = (1 - p_t)**2 / ((1 - p_t)**2 + p_t**2) * torch.log(p_t)
        loss_term_2 = p_t**2 / ((1 - p_t)**2 + p_t**2) * (1 - p_t)**self.gamma * torch.log(p_t)
        
        # 将每个类别的频率作为加权项
        loss = -self.class_frequencies[targets] * (loss_term_1 + loss_term_2)
        
        return loss.mean()

代码解释

  1. 类的构造函数 (__init__):

    • class_frequencies: 这是每个类别的频率。通常,频率是类别样本的出现概率或样本的加权值。该参数在处理类别不平衡时尤其重要。较少出现的类别会赋予较高的权重,以便模型对这些类别更敏感。
    • gamma: 和 CEFL 中的 gamma 相同,用于调节焦点损失的程度,控制对难分类样本的关注。
  2. forward 方法:

    • inputs: 与 CEFL 相同,是模型的输出(即 logits)。
    • targets: 与 CEFL 相同,是真实标签。
  3. F.softmax(inputs, dim=1):

    • 对模型的输出 inputs 进行 softmax 计算,得到每个样本在各类别上的概率。
  4. p.gather(1, targets.view(-1, 1)):

    • gather 方法用来根据 targets 中的标签提取每个样本的正确类别的预测概率。
  5. 加权损失部分

    • loss_term_1 = (1 - p_t)**2 / ((1 - p_t)**2 + p_t**2) * torch.log(p_t):
      • 这是针对正确类别概率 p_t 的一个加权项。这个项的目的是将模型的关注点放在难分类的样本上。计算时考虑了正确类和错误类之间的比例,进而调整损失值。
    • loss_term_2 = p_t**2 / ((1 - p_t)**2 + p_t**2) * (1 - p_t)**self.gamma * torch.log(p_t):
      • 另一个加权项,考虑了模型对难分类样本的关注(即当 p_t 小,样本难分类时),通过增加 gamma 使得模型对难分类样本的权重更加突出。
    • 这两个损失项的组合有助于在类别不平衡问题中进行加权,增强对少数类的学习。
  6. 加权频率项

    • loss = -self.class_frequencies[targets] * (loss_term_1 + loss_term_2):
      • 将每个类别的频率(class_frequencies)引入损失计算中。这使得类别频率较低的类别(通常是少数类)在计算损失时有更高的权重,从而让模型更加关注少数类。
  7. 返回平均损失

    • loss.mean(): 返回所有样本的加权平均损失。

4.3 训练过程

为了更好地展示如何在训练过程中使用 CEFLCEFL2 损失函数,,并将其应用于一个简单的神经网络模型。以下是更新后的代码示例:

import torch
from torch.utils.data import DataLoader, Dataset
import numpy as np

# 计算类别频率的函数
def compute_class_frequencies(targets, num_classes):
    # 计算每个类别的样本数量
    class_counts = torch.bincount(targets, minlength=num_classes)
    
    # 防止除零错误,计算每个类别的频率
    class_freq = 1.0 / (class_counts.float() + 1e-6)
    
    # 归一化类别频率
    class_freq = class_freq / class_freq.sum()
    
    return class_freq

# 自定义数据集类
class CustomDataset(Dataset):
    def __init__(self, data, targets):
        self.data = data
        self.targets = targets

    def __len__(self):
        return len(self.data)

    def __getitem__(self, idx):
        return self.data[idx], self.targets[idx]

# 创建一个虚拟数据集
num_samples = 1000
num_classes = 7
input_dim = 128
data = torch.randn(num_samples, input_dim)
targets = torch.randint(0, num_classes, (num_samples,))

# 计算每个类别的频率
class_frequencies = compute_class_frequencies(targets, num_classes)

# 创建数据加载器
dataset = CustomDataset(data, targets)
dataloader = DataLoader(dataset, batch_size=32, shuffle=True)

# 定义模型(例如一个简单的全连接网络)
class SimpleModel(nn.Module):
    def __init__(self, input_dim, num_classes):
        super(SimpleModel, self).__init__()
        self.fc = nn.Linear(input_dim, num_classes)

    def forward(self, x):
        return self.fc(x)

# 初始化模型和损失函数
model = SimpleModel(input_dim, num_classes)
criterion = CEFL2(class_frequencies)  # 使用 CEFL2 损失函数
optimizer = torch.optim.Adam(model.parameters(), lr=0.001)

# 训练模型
epochs = 10
for epoch in range(epochs):
    model.train()
    running_loss = 0.0
    for inputs, targets in dataloader:
        optimizer.zero_grad()
        outputs = model(inputs)
        loss = criterion(outputs, targets)
        loss.backward()
        optimizer.step()
        
        running_loss += loss.item()

    avg_loss = running_loss / len(dataloader)
    print(f"Epoch [{epoch+1}/{epochs}], Loss: {avg_loss:.4f}")

代码解释

  1. 类别频率计算 (compute_class_frequencies):

    • 这个函数计算了每个类别在数据中的出现频率。我们通过计算每个类别的出现次数并进行归一化,得到类别频率。
    • torch.bincount(targets) 用于计算每个类别出现的次数,随后通过频率逆转的方式进行归一化。
  2. 自定义数据集 (CustomDataset):

    • 这个自定义数据集类返回每个样本的输入和标签对,适用于 PyTorch 的 DataLoader
  3. 模型定义 (SimpleModel):

    • 定义了一个简单的全连接层的神经网络,用于演示如何应用损失函数。
    • 模型输入为 input_dim,输出为 num_classes
  4. 训练循环:

    • 在每个 epoch 中,模型通过前向传播获得预测结果,并计算损失。
    • 使用 CEFL2 损失函数,基于每个类别的频率进行加权损失计算。
    • optimizer.zero_grad() 清空之前的梯度,loss.backward() 计算梯度,optimizer.step() 更新模型权重。

总结

在本文中,我们深入探讨了 Class-balanced Exponential Focal Loss (CEFL)Class-balanced Exponential Focal Loss 2 (CEFL2) 损失函数的定义、原理及其应用,重点介绍了它们如何有效解决类别不平衡问题。通过引入类别权重和类别频率,这些损失函数能够帮助模型在训练过程中更好地关注少数类样本,避免对多数类样本的过拟合,从而提升少数类的分类性能。

本文还提供了 PyTorch 实现的详细代码,包括如何计算类别频率、定义损失函数,并在训练过程中应用它们。

为帮助理解类别频率的影响,以下图示展示了不同类别在训练过程中损失调整的效果:

CSDN @ 2136
原始训练集
计算类别频率
计算类别频率加权后的损失
优化模型
训练结果
类别频率
损失调整
模型优化
CSDN @ 2136

图中展示了训练过程中如何计算类别频率,并利用这些频率对损失进行加权,从而优化模型训练效果。

通过本文的讲解,您应该对 CEFLCEFL2 损失函数的定义、实现和应用有了更深刻的理解。如果您正在处理类别不平衡的分类任务,不妨尝试使用这些损失函数,它们能有效提升模型的性能,特别是在少数类样本的分类效果上。

参考文献

  • T.-Y. Lin, P. Goyal, R. Girshick, K. He, and P. Dollar, ``Focal loss for dense object detection,’’ in Proc. IEEE Int. Conf. Comput. Vis., Oct. 2017, pp. 2980-2988.doi:10.48550/arXiv.1708.02002.
  • L. Wang, C. Wang, Z. Sun, S. Cheng and L. Guo, “Class Balanced Loss for Image Classification,” in IEEE Access, vol. 8, pp. 81142-81153, 2020, doi: 10.1109/ACCESS.2020.2991237.

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/957246.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

python麻辣香锅菜品推荐

1.推荐算法概述 推荐算法出现得很早,最早的推荐系统是卡耐基梅隆大学推出的Web Watcher浏览器导航系统,可以根据当的搜索目标和用户信息,突出显示对用户有用的超链接。斯坦福大学则推出了个性化推荐系统LIRA.AT&T实验室于1997年提出基于协作过滤的个性化推荐系统…

利用大型语言模型在量化投资中实现自动化策略

“Automate Strategy Finding with LLM in Quant investment” 论文地址:https://arxiv.org/pdf/2409.06289 摘要 这个新提出的量化股票投资框架,利用大型语言模型(LLMs)与多智能体系统相结合的方法,通过LLMs从包括数…

JAVA:Spring Boot 实现责任链模式处理订单流程的技术指南

1、简述 在复杂的业务系统中,订单流程往往需要一系列的操作,比如验证订单、检查库存、处理支付、更新订单状态等。责任链模式(Chain of Responsibility)可以帮助我们将这些处理步骤分开,并且以链式方式处理每一个操作…

(开源)基于Django+Yolov8+Tensorflow的智能鸟类识别平台

1 项目简介(开源地址在文章结尾) 系统旨在为了帮助鸟类爱好者、学者、动物保护协会等群体更好的了解和保护鸟类动物。用户群体可以通过平台采集野外鸟类的保护动物照片和视频,甄别分类、实况分析鸟类保护动物,与全世界各地的用户&…

算法专题(三):二分查找

本篇还是像之前一样,以举例子的形式向大家讲解!每道题的题目均是传送门!点击跳转对应题! 目录 一、二分查找 1.1 题目 1.2 思路 1.3 代码实现 总结(模版) 朴素版: 二、在排序数组中查找…

C# OpenCvSharp 部署文档矫正,包括文档扭曲/模糊/阴影等情况

目录 说明 效果 模型 项目 代码 下载 参考 C# OpenCvSharp 部署文档矫正,包括文档扭曲/模糊/阴影等情况 说明 地址:https://github.com/RapidAI/RapidUnDistort 修正文档扭曲/模糊/阴影等情况,使用onnx模型简单轻量部署&#xff0c…

Excel 技巧15 - 在Excel中抠图头像,换背景色(★★)

本文讲了如何在Excel中抠图头像,换背景色。 1,如何在Excel中抠图头像,换背景色 大家都知道在PS中可以很容易抠图头像,换背景色,其实Excel中也可以抠简单的图,换背景色。 ※所用头像图片为百度搜索&#x…

吴恩达深度学习——神经网络介绍

文章内容来自BV11H4y1F7uH,仅为个人学习所用。 文章目录 什么是神经网络引入神经网络神经元激活函数ReLU隐藏单元 用神经网络进行监督学习监督学习与无监督学习举例 什么是神经网络 引入 已经有六个房子的数据集,横轴为房子大小,纵轴为房子…

xctf-comment(Intruder,git恢复,SQL注入,Hex解码)

这题是2018年网鼎杯真题,考察 Burp Suite 的 Intruder 模块去找用户密码,使用 githacker 恢复代码(githack不行),代码审计发现SQL二次注入,尝试SQL注入读取文件内容,读取的是/home/www/.bash_hi…

分布式系统通信解决方案:Netty 与 Protobuf 高效应用

分布式系统通信解决方案:Netty 与 Protobuf 高效应用 一、引言 在现代网络编程中,数据的编解码是系统设计的一个核心问题,特别是在高并发和低延迟的应用场景中,如何高效地序列化和传输数据对于系统的性能至关重要。随着分布式系…

C++《AVL树》

在之前的学习当中我们已经了解了二叉搜索树,并且我们知道二叉搜索树的查找效率是无法满足我们的要求,当二叉树为左或者右斜树查找的效率就很低下了,那么这本篇当中我们就要来学习对二叉搜索树进行优化的二叉树——AVL树。在此会先来了解AVL树…

ToDesk设置临时密码和安全密码都可以当做连接密码使用

ToDesk 在各领域办公都已经是非常常见了 为了安全 ToDesk 设置了连接密码,想连接 需要输入远程码和连接密码 我们刚打开 系统默认给我们用的是临时密码,安全性确实很强 和定时Tokey一样,固定时间切换。 但是 如果我们要经常连接这个电脑&a…

LLMs(大型语言模型)的多智能体:Auto-GPT

LLMs(大型语言模型)的多智能体:Auto-GPT 是指在一个系统中集成多个具有不同能力、角色和任务的智能体,这些智能体能够相互协作、沟通和交互,以共同完成复杂的任务或解决复杂的问题。每个智能体都可以被视为一个独立的实体,具有自己的策略、目标和知识库,通过相互之间的…

【Linux环境变量与命令行参数】常见环境变量 | 环境变量的全局属性 | 命令行参数

前言 本文中主要介绍PATH、HOME、SHELL、HISTSIZE这4个环境变量,其中详细介绍PATH。并理解环境变量的全局属性--环境变量可以被子进程继承,这里要注意和C中的继承进行区分。其次,介绍命令行参数--mian函数的参数。 1.环境变量的基本概念 在…

【Python】函数(二)

链式调用 # 判定是否是奇数 def isOdd(num):if num % 2 0:return Falseelse:return Trueresult isOdd(10) print(result)实际上也可以简化写作 print(isOdd(10))把一个函数的返回值, 作为另一个函数的参数, 这种操作称为 链式调用 嵌套调用 函数内部还可以调用其他的函数…

【Elasticsearch 】 聚合分析:桶聚合

🧑 博主简介:CSDN博客专家,历代文学网(PC端可以访问:https://literature.sinhy.com/#/?__c1000,移动端可微信小程序搜索“历代文学”)总架构师,15年工作经验,精通Java编…

学习ASP.NET Core的身份认证(基于JwtBearer的身份认证7)

本文验证基于请求头中传递token信息的认证方式,webapi项目的控制器类中新建如下函数,仅通过验证的客户端能调用,需要客户端请求在Header中添加’Authorization’: Bearer token’的键值对且通过token验证后才能调用。 [Authorize] [HttpGet]…

游戏AI,让AI 玩游戏有什么作用?

让 AI 玩游戏这件事远比我们想象的要早得多。追溯到 1948 年,图灵和同事钱伯恩共同设计了国际象棋程序 Turochamp。之所以设计这么个程序,图灵是想说明,机器理论上能模拟人脑能做的任何事情,包括下棋这样复杂的智力活动。 可惜的是…

9. 神经网络(一.神经元模型)

首先,先看一个简化的生物神经元结构: 生物神经元有多种类型,内部也有复杂的结构,但是可以把单个神经元简化为3部分组成: 树突:一个神经元往往有多个树突,用于接收传入的信息。轴突:…

Docker可视化管理工具Portainer

Portainer简介 Portainer 是一个轻量级的、开源的容器管理工具,提供了一个直观的 Web 用户界面(UI),用于管理 Docker 和 Kubernetes 环境。它简化了容器的部署、监控和管理,特别适合不熟悉命令行操作的用户或团队。 …