人工智能的目标分类

news2025/1/18 3:19:33

2a20c54b85e042bfa2440367ae4807e9.gif

欢迎来到 Papicatch的博客

目录

🍉引言

🍉目标分类的概述

🍈背景

🍈分类的重要性

🍍明确研究重点

🍍促进应用推广

🍍便于评估和比较

🍈分类的原则

🍍基于应用领域

🍍按照功能特点

🍍考虑技术实现方式

🍈常见的分类方式

🍍按智能化程度 

🍍按应用场景

🍍按解决的问题类型

🍉目标分类的常用模型

🍈决策树模型

🍍步骤

🍌特征选择

🍌节点分裂

🍌树的生长

🍍决策树的优点包括

🍌易于理解和解释

🍌对数据的准备要求不高

🍌能够处理多种类型的数据

🍍决策树缺点

🍌容易过拟合

🍌对噪声数据敏感

🍈朴素贝叶斯模型

🍍朴素贝叶斯模型的优点包括

🍍朴素贝叶斯模型的缺点包括

🍈支持向量机(SVM)模型

🍍SVM 的优点包括

🍍SVM 的缺点包括

🍈神经网络模型

🍍神经网络的优点包括

 🍍神经网络的缺点包括

🍈随机森林模型 

🍍随机森林的优点包括

🍍随机森林的缺点包括

🍉 示例

🍈CIFAR 数据集分类

🍍数据预处理

🍍模型选择

🍍训练策略

🍍模型评估

🍍代码实现(使用 TensorFlow 和 Keras)

🍈 猫狗分类

🍍数据

🍍特征提取

🍍模型选择

🍍训练过程

🍍评估指标 

🍍代码实现(使用 TensorFlow 和 Keras)

🍉总结 


2a20c54b85e042bfa2440367ae4807e9.gif

🍉引言

        人工智能(Artificial Intelligence,简称 AI)的发展日新月异,其应用领域广泛,涵盖了医疗、交通、金融、教育等多个方面。为了更好地理解和研究人工智能,对其目标进行分类是非常必要的。

🍉目标分类的概述

🍈背景

        在当今科技迅速发展的时代,人工智能已经成为引领创新和变革的重要力量。对人工智能目标进行准确分类,有助于我们更系统地理解其发展方向和潜在影响。

🍈分类的重要性

🍍明确研究重点

  • 有助于研究者和开发者聚焦特定领域,集中资源和精力实现具体目标。
  • 例如,在医疗领域,如果目标是疾病诊断,那么研究重点将是如何让人工智能准确识别各种病症的特征 

🍍促进应用推广

  • 使不同行业能够根据自身需求,有针对性地选择和应用适合的人工智能技术。
  • 比如,制造业可以利用优化生产流程的人工智能技术来提高生产效率和降低成本。 

🍍便于评估和比较

  • 能够对不同的人工智能系统和项目进行客观评估和比较。
  • 比如,比较两个用于交通预测的人工智能模型的准确性和实用性。 

🍈分类的原则

🍍基于应用领域

  • 如医疗、教育、金融等,因为不同领域的需求和问题差异较大。 

🍍按照功能特点

  • 例如预测、分类、优化等。 

🍍考虑技术实现方式

  • 如基于深度学习、机器学习、强化学习等。

🍈常见的分类方式

🍍按智能化程度 

        分为弱人工智能、强人工智能和超人工智能。弱人工智能专注于特定任务,强人工智能具备类似人类的综合智能,超人工智能则在智能水平上远超人类。 

🍍按应用场景

        如智能家居、智能交通、智能医疗等。

🍍按解决的问题类型

        包括数据处理与分析、模式识别、决策制定等。

🍉目标分类的常用模型

🍈决策树模型

        决策树是一种直观且易于理解的分类和回归模型。

        决策树的基本原理是基于一系列的特征测试,将数据逐步划分到不同的分支,最终形成叶节点,每个叶节点对应一个类别或预测值。

🍍步骤

它的构建过程通常包括以下几个步骤: 

🍌特征选择
  • 选择对数据分类最有帮助的特征。常用的特征选择方法有信息增益、增益率、基尼指数等。例如,对于一个学生成绩分类问题,可能会选择学习时间、平时作业完成情况等特征。
🍌节点分裂
  • 根据选择的特征和相应的阈值,将数据分成不同的子集。
🍌树的生长
  • 重复上述步骤,直到满足停止条件,如达到最大深度、节点中的样本数量过少等。

🍍决策树的优点包括

🍌易于理解和解释
  • 可以通过图形化的方式清晰展示决策过程。
🍌对数据的准备要求不高
  • 不需要对数据进行太多的预处理。
🍌能够处理多种类型的数据
  • 包括数值型和分类型数据。

🍍决策树缺点

🍌容易过拟合
  • 导致在新数据上的表现不佳。
🍌对噪声数据敏感
  • 少量的错误数据可能会对决策树的构建产生较大影响。
  1. 为了克服这些缺点,可以采取剪枝、集成学习(如随机森林)等方法。
  2. 例如,在一个预测天气是否适合户外活动的决策树中,可能首先根据是否有雨来进行分类,如果没有雨,再根据温度是否高于 25 度进一步划分,最终得出适合或不适合户外活动的结论。
  3. 在医疗领域,决策树可以用于疾病诊断,根据患者的症状、检查结果等特征来判断疾病类型。

🍈朴素贝叶斯模型

        朴素贝叶斯是基于贝叶斯定理与特征条件独立假设的分类方法。

        贝叶斯定理的表达式为:P(A|B) = P(B|A) * P(A) / P(B) ,其中 P(A|B) 表示在事件 B 发生的条件下事件 A 发生的概率。

        在朴素贝叶斯模型中,假设各个特征之间相互独立,这一假设被称为“朴素”条件。

        其分类的基本思想是:对于给定的待分类项,求解在此项出现的条件下各个类别出现的概率,哪个类别出现的概率最大,就认为此待分类项属于哪个类别。

        具体来说,假设有 k 个类别 C1, C2,..., Ck ,对于一个新的样本 x ,其特征为 x1, x2,..., xn ,那么属于类别 Ci 的概率可以通过以下公式计算:

P(Ci | x) = P(x | Ci) * P(Ci) / P(x)

        由于 P(x) 对于所有类别都是相同的,所以只需要比较 P(x | Ci) * P(Ci) 的大小。 

        其中,P(Ci) 是类别 Ci 的先验概率,可以通过训练数据中各类别的比例计算得到。

   P(x | Ci) 是在类别 Ci 下特征 x 出现的概率。由于假设特征相互独立,所以 P(x | Ci) = P(x1 | Ci) * P(x2 | Ci) *... * P(xn | Ci) 。

🍍朴素贝叶斯模型的优点包括

  • 算法简单,容易实现。
  • 对小规模数据表现良好,适合多分类任务。
  •  例如,在垃圾邮件分类中,将邮件中的单词作为特征,通过计算邮件属于垃圾邮件类别和正常邮件类别的概率来进行判断。

🍍朴素贝叶斯模型的缺点包括

  • 特征独立性假设在实际中往往不成立,可能会影响模型的准确性。
  • 对输入数据的表达形式很敏感。

        总的来说,朴素贝叶斯模型在许多实际应用中,尤其是在数据特征相对独立且数据量不大的情况下,能够提供快速有效的分类结果。 

🍈支持向量机(SVM)模型

        支持向量机(Support Vector Machine,SVM)是一种强大的机器学习算法,主要用于分类和回归任务。

        SVM 的基本思想是在特征空间中寻找一个最优的超平面,能够将不同类别的数据点尽可能地分开。这个超平面由距离它最近的几个数据点(称为支持向量)决定。

        对于线性可分的情况,SVM 通过最大化分类间隔来确定超平面。对于线性不可分的数据,可以通过引入核函数将数据映射到高维空间,使其在高维空间中变得线性可分。

🍍SVM 的优点包括

  • 在处理小样本、非线性和高维数据时表现出色。
  • 具有较好的泛化能力。
  • 例如,在图像识别中,SVM 可以用于区分不同的物体类别,通过提取图像的特征,找到能够有效分类的超平面。

🍍SVM 的缺点包括

  • 计算复杂度较高,特别是在处理大规模数据时。
  • 对核函数的选择比较敏感。

🍈神经网络模型

        神经网络是一种模仿生物大脑神经元之间连接方式的机器学习模型。

        它由大量的节点(称为神经元)组成,这些节点通过连接形成网络结构。每个神经元接收来自其他神经元的输入,并通过一个激活函数产生输出。

        神经网络通过调整连接的权重来学习数据中的模式和规律。常见的神经网络类型包括多层感知机(MLP)、卷积神经网络(CNN)、循环神经网络(RNN)等。

🍍神经网络的优点包括

  • 能够自动学习数据中的复杂模式和特征。
  • 具有很强的表达能力,可以处理各种类型的数据。
  • 例如,在语音识别中,神经网络可以学习语音信号的特征,从而实现对语音的准确识别。

 🍍神经网络的缺点包括

  • 训练过程需要大量的计算资源和时间。
  • 模型的解释性较差,难以理解其决策过程。

🍈随机森林模型 

TikZ绘制随机森林Random Forest 算法图

        随机森林是一种集成学习方法,由多个决策树组成。

        在构建随机森林时,通过随机选择样本和特征来构建多个决策树。最终的预测结果通过综合多个决策树的预测结果得出,通常采用投票或平均的方式。

🍍随机森林的优点包括

  • 具有较高的准确性和稳定性。
  • 能够处理高维数据,并且不容易出现过拟合。
  • 例如,在信用评估中,随机森林可以综合考虑多个因素来判断一个人的信用状况。

🍍随机森林的缺点包括

  • 对于噪声数据比较敏感。
  • 计算成本相对较高。

🍉 示例

🍈CIFAR 数据集分类

        CIFAR 数据集(通常指 CIFAR-10 或 CIFAR-100)是用于图像分类任务的经典数据集。

        CIFAR-10 数据集包含 10 个不同的类别,分别是飞机、汽车、鸟、猫、鹿、狗、青蛙、马、船和卡车。每个类别有 6000 张图像,其中 5000 张用于训练,1000 张用于测试,图像的大小为 32x32 像素,颜色通道为 3(RGB)。

在对 CIFAR 数据集进行分类时,需要考虑以下几个关键方面

🍍数据预处理

  • 图像的归一化:将像素值缩放到 0 到 1 之间,有助于模型的训练和收敛。
  • 数据增强:通过随机旋转、裁剪、翻转等操作增加数据的多样性,减少过拟合的风险。

🍍模型选择

  • 卷积神经网络(CNN)通常是处理图像分类任务的首选模型,因为它们能够自动学习图像中的局部特征和模式。
  • 可以选择经典的 CNN 架构,如 LeNet、AlexNet、VGG、ResNet 等,也可以根据数据特点自行设计模型。

🍍训练策略

  • 选择合适的优化器,如随机梯度下降(SGD)、Adagrad、Adadelta、Adam 等。
  • 调整学习率:通常采用学习率衰减策略,在训练过程中逐渐降低学习率,以获得更好的收敛效果。
  • 定义损失函数:对于多类别分类问题,常用的损失函数是交叉熵损失(Cross-Entropy Loss)。

🍍模型评估

  • 使用测试集上的准确率(Accuracy)、召回率(Recall)、F1 值等指标来评估模型的性能。
  • 可以绘制训练集和验证集上的损失和准确率曲线,分析模型的训练过程和是否存在过拟合或欠拟合现象。

🍍代码实现(使用 TensorFlow 和 Keras)

import tensorflow as tf
from tensorflow.keras.datasets import cifar10
from tensorflow.keras.models import Sequential
from tensorflow.keras.layers import Conv2D, MaxPooling2D, Flatten, Dense
from tensorflow.keras.optimizers import Adam
from tensorflow.keras.utils import to_categorical

# 加载 CIFAR-10 数据集
(x_train, y_train), (x_test, y_test) = cifar10.load_data()

# 数据预处理
x_train = x_train / 255.0
x_test = x_test / 255.0

# 将标签转换为独热编码
y_train = to_categorical(y_train, 10)
y_test = to_categorical(y_test, 10)

# 构建模型
model = Sequential([
    Conv2D(32, (3, 3), activation='relu', padding='same', input_shape=(32, 32, 3)),
    Conv2D(32, (3, 3), activation='relu'),
    MaxPooling2D((2, 2)),
    Conv2D(64, (3, 3), activation='relu', padding='same'),
    Conv2D(64, (3, 3), activation='relu'),
    MaxPooling2D((2, 2)),
    Flatten(),
    Dense(512, activation='relu'),
    Dense(10, activation='softmax')
])

# 编译模型
model.compile(optimizer=Adam(learning_rate=0.001),
              loss='categorical_crossentropy',
              metrics=['accuracy'])

# 训练模型
history = model.fit(x_train, y_train, epochs=20, batch_size=64, validation_split=0.1)

# 评估模型
loss, accuracy = model.evaluate(x_test, y_test)
print("Test Loss:", loss)
print("Test Accuracy:", accuracy)

# 绘制训练和验证的准确率曲线
import matplotlib.pyplot as plt

plt.plot(history.history['accuracy'])
plt.plot(history.history['val_accuracy'])
plt.title('Model Accuracy')
plt.ylabel('Accuracy')
plt.xlabel('Epoch')
plt.legend(['Train', 'Validation'], loc='upper left')
plt.show()

在上述代码中:

  • 首先加载 CIFAR-10 数据集,并进行数据预处理,包括像素值归一化和标签独热编码。
  • 构建了一个简单的卷积神经网络模型,包含卷积层、池化层、全连接层等。
  • 使用 Adam 优化器和交叉熵损失函数编译模型。
  • 通过 fit 方法训练模型,并记录训练历史。
  • 最后在测试集上评估模型,并绘制训练和验证的准确率曲线,以分析模型的性能和过拟合情况。

🍈 猫狗分类

        猫狗分类是一个常见的图像分类任务,旨在区分给定的图像是猫还是狗。

🍍数据

        通常需要收集大量的猫和狗的图像数据集。这些图像可能具有不同的姿态、颜色、背景和分辨率。数据的质量和多样性对于模型的训练效果至关重要。

🍍特征提取

        图像分类的关键在于提取有效的特征。对于猫狗分类,可以使用传统的手工特征提取方法,如边缘检测、颜色直方图等,但现在更常用的是基于深度学习的自动特征提取。

🍍模型选择

  • 卷积神经网络(CNN):能够自动从图像中学习特征,在图像分类任务中表现出色。
  • 预训练模型:如 VGG、ResNet 等,可以利用在大规模数据集上学习到的通用特征,然后在猫狗数据集上进行微调。

🍍训练过程

  • 数据增强:通过随机旋转、裁剪、翻转图像等操作,增加数据的多样性,减少过拟合。
  • 优化算法:选择合适的优化器,如 SGD、Adam 等,调整学习率等参数。
  • 损失函数:常用的交叉熵损失函数用于衡量预测结果与真实标签之间的差异。

🍍评估指标 

        通常使用准确率、召回率、F1 值等来评估模型的性能。

🍍代码实现(使用 TensorFlow 和 Keras)

import tensorflow as tf
from tensorflow.keras.preprocessing.image import ImageDataGenerator
from tensorflow.keras.models import Sequential
from tensorflow.keras.layers import Conv2D, MaxPooling2D, Flatten, Dense
from tensorflow.keras.optimizers import Adam

# 数据路径
train_dir = 'train/'
test_dir = 'test/'

# 数据增强
train_datagen = ImageDataGenerator(
    rescale=1./255,
    rotation_range=20,
    width_shift_range=0.2,
    height_shift_range=0.2,
    shear_range=0.2,
    zoom_range=0.2,
    horizontal_flip=True
)

test_datagen = ImageDataGenerator(rescale=1./255)

# 加载数据
train_generator = train_datagen.flow_from_directory(
    train_dir,
    target_size=(150, 150),
    batch_size=32,
    class_mode='binary'
)

test_generator = test_datagen.flow_from_directory(
    test_dir,
    target_size=(150, 150),
    batch_size=32,
    class_mode='binary'
)

# 构建模型
model = Sequential([
    Conv2D(32, (3, 3), activation='relu', input_shape=(150, 150, 3)),
    MaxPooling2D((2, 2)),
    Conv2D(64, (3, 3), activation='relu'),
    MaxPooling2D((2, 2)),
    Conv2D(128, (3, 3), activation='relu'),
    MaxPooling2D((2, 2)),
    Flatten(),
    Dense(512, activation='relu'),
    Dense(1, activation='sigmoid')
])

# 编译模型
model.compile(optimizer=Adam(learning_rate=0.001),
              loss='binary_crossentropy',
              metrics=['accuracy'])

# 训练模型
history = model.fit(train_generator, epochs=50, validation_data=test_generator)

# 评估模型
loss, accuracy = model.evaluate(test_generator)
print("Test Loss:", loss)
print("Test Accuracy:", accuracy)

在上述代码中:

  • 定义了数据增强的操作,包括旋转、平移、翻转等。
  • 从指定的目录加载训练和测试数据,并设置图像的大小和批大小。
  • 构建了一个简单的卷积神经网络模型。
  • 使用 Adam 优化器和二分类交叉熵损失函数编译模型。
  • 进行训练,并在测试集上评估模型。

🍉总结 

  • 目标分类是对不同类型目标进行系统划分和归类的重要过程。通过目标分类,我们能够更加清晰地理解和组织各种目标,从而更有效地规划和管理我们的行动。
  • 目标可以基于多种标准进行分类。从时间维度来看,有短期目标、中期目标和长期目标。短期目标通常是在近期内可实现的具体任务,中期目标则需要在一定时间段内努力达成,而长期目标往往是更宏观、更长远的追求。
  • 按照性质划分,目标可分为定性目标和定量目标。定性目标侧重于描述性质、特点或方向,如提高团队合作能力;定量目标则以具体的数据和指标来衡量,例如销售额达到一定数值。
  • 根据领域的不同,目标可以分为个人目标、职业目标、学业目标、财务目标、健康目标等。每个领域都有其独特的重点和要求。
  • 此外,还可以根据目标的重要性和优先级进行分类,确定哪些目标是关键的、必须优先完成的,哪些是次要的、可以后续处理的。
  • 目标分类有助于我们明确每个目标的特点和需求,合理分配资源和精力,制定有针对性的策略和计划,确保各个目标能够有序实现,最终推动个人和组织的全面发展。

https://blog.csdn.net/2302_76516899?type=blog

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

F_GETDOWN的例子

代码&#xff1a; 7:46 2024/7/1#include <unistd.h> #include <fcntl.h> #include <stdio.h> int main(void) {int uid;int fdopen("test.txt",O_RDWR);uidfcntl(fd,F_GETOWN);printf("the SIG recv ID is %d\n",uid);close(fd);retur…

使用 Vue 实现包含单选框的弹窗功能(附Demo)

目录 前言1. Vue22. Vue3 前言 如果在弹窗中单独增设一些选项或者少部分的数据&#xff0c;可用如下的方式 &#xff08;不用单独创建专门的表单样式&#xff09; 如果单纯可以通过基本的按钮传输给后端&#xff0c;可用如下知识点 对于弹窗的基本知识推荐阅读&#xff1a; …

了解 ZooKeeper:关键概念和架构

ZooKeeper 是一种分布式协调服务&#xff0c;广泛用于分布式系统中&#xff0c;用于维护配置信息、命名、同步和组服务。它最初由雅虎开发&#xff0c;现在是一个 Apache 项目&#xff0c;已成为许多大型分布式应用程序不可或缺的一部分。本文深入探讨 ZooKeeper 的关键概念和架…

(四)Appdesigner-文件存在判断及对话框设计

目录 前言 一、文件存在判断 &#xff08;一&#xff09;基础知识 &#xff08;二&#xff09;实际操作 二、对话框设计 &#xff08;一&#xff09;基础知识 1.提示对话框 2.询问对话框 3.文件选择对话框 &#xff08;二&#xff09;实际操作 1.提示对话框 2.询问…

考研生活day1--王道课后习题2.2.1、2.2.2、2.2.3

2.2.1 题目描述&#xff1a; 解题思路&#xff1a; 这是最基础的操作&#xff0c;思路大家应该都有&#xff0c;缺少的应该是如何下笔&#xff0c;很多同学都是有思路但是不知道如何下笔&#xff0c;这时候看思路的意义不大&#xff0c;可以直接看答案怎么写&#xff0c;最好…

关于内存和外存文件不同字符集下占用空间大小问题

关于内存和外存不同字符集下文件占用空间大小问题 存储&#xff08;外存&#xff09;的文件中的字符&#xff1a; ASCII&#xff1a;每个字符占用1个字节&#xff0c;用来存储英文字符和常用标点符号。ISO-8859-1&#xff1a;每个字符占用1个字节&#xff0c;向下兼容ASCII。G…

【代码随想录】【算法训练营】【第53天】 [739]每日温度 [496]下一个更大元素I [503]下一个更大元素II

前言 思路及算法思维&#xff0c;指路 代码随想录。 题目来自 LeetCode。 day 48&#xff0c;周六&#xff0c;不能再坚持~ 题目详情 [739] 每日温度 题目描述 739 每日温度 解题思路 前提&#xff1a; 思路&#xff1a; 重点&#xff1a; 代码实现 C语言 [496] 下一…

【一篇搞懂】操作系统期末大题:进程同步与互斥 PV操作

文章目录 一、前言&#x1f680;&#x1f680;&#x1f680;二、正文&#xff1a;☀️☀️☀️题型一&#xff1a;利用信号量实现前驱关系题型二&#xff1a;利用信号量实现资源同步与互斥 一、前言&#x1f680;&#x1f680;&#x1f680; 本文简介&#xff1a;这是一篇基于b…

Pycharm常用快捷键整理

1&#xff0c;格式化代码 【ctrlAltL】 写代码的时候会发现有很多黄色的波浪号&#xff0c;这个时候可以点击任意黄色波浪号的代码&#xff0c;然后按下【Ctrl Alt L】进行代码格式化 2&#xff0c;快速往返 ctrll Alt ⬅ &#xff0c;表示查看上一步调用函数位置&#xff0…

Redis 7.x 系列【9】数据类型之自动排重集合(Set)

有道无术&#xff0c;术尚可求&#xff0c;有术无道&#xff0c;止于术。 本系列Redis 版本 7.2.5 源码地址&#xff1a;https://gitee.com/pearl-organization/study-redis-demo 文章目录 1. 前言2. 常用命令2.1 SADD2.2 SCARD2.3 SISMEMBER2.4 SREM2.5 SSCAN2.6 SDIFF2.7 SU…

华为OD机试 - 启动多任务排序 - 拓扑排序(Java 2024 D卷 200分)

华为OD机试 2024D卷题库疯狂收录中&#xff0c;刷题点这里 专栏导读 本专栏收录于《华为OD机试&#xff08;JAVA&#xff09;真题&#xff08;D卷C卷A卷B卷&#xff09;》。 刷的越多&#xff0c;抽中的概率越大&#xff0c;每一题都有详细的答题思路、详细的代码注释、样例测…

如何做好一个企业家IP:塑造独特的个人品牌

在当今数字化时代&#xff0c;个人品牌的力量愈发凸显&#xff0c;对于企业家而言&#xff0c;一个强大的IP&#xff08;Intellectual Property&#xff0c;即知识产权或个人品牌&#xff09;不仅有助于提升个人影响力&#xff0c;还能为企业的发展注入强大动力。那么&#xff…

BGE M3-Embedding 模型介绍

BGE M3-Embedding来自BAAI和中国科学技术大学&#xff0c;是BAAI开源的模型。相关论文在https://arxiv.org/abs/2402.03216&#xff0c;论文提出了一种新的embedding模型&#xff0c;称为M3-Embedding&#xff0c;它在多语言性&#xff08;Multi-Linguality&#xff09;、多功能…

Feign 原理流程图练习-01

目录 作业: 老师给的参考流程图 要求 解答 知识扩展 Feign基础原理 接口定义 代理对象生成 请求调用 请求发送 响应处理 容错与熔断 总结 作业: 老师给的参考流程图 pdf版本 【金山文档 | WPS云文档】 Feign https://kdocs.cn/l/ctbagIyxN348 ​ 要求 结合上面…

[C++][设计模式][状态模式]详细讲解

目录 1.动机2.模式定义3.要点总结4.代码感受1.代码一2.代码二 1.动机 在软件构建过程中&#xff0c;某些对象的状态如果改变&#xff0c;其行为也会随之而放生变化 比如文档处于只读状态&#xff0c;其支持的行为和读写状态支持的行为就可能完全不同 如何在运行时根据对象的状…

STM32 SWD烧写

最小电路 stm32f103x 内部已经集成了振荡电路&#xff0c;可以省略&#xff1b;rst引脚电路&#xff0c;可以省略&#xff0c;boot0,boot1不需要设置 正常烧录 -------------------------------------------------------------------STM32CubeProgrammer v2.9.0 …

antd Select前端加模糊搜索

背景&#xff1a;前端的小伙伴经常在开发antd Select的时候后端不提供搜索模糊搜索接口&#xff0c;而是全量返回数据&#xff0c;这个时候就需要我们前端自己来写一个模糊搜索了。 效果 代码截图 代码 <SelectshowSearchmode"multiple"options{studioList}filte…

读AI新生:破解人机共存密码笔记17不确定性和概率

1. 前向搜索 1.1. 通过前向搜索&#xff0c;通过考虑各种可能的动作序列的结果&#xff0c;来选择动作&#xff0c;是智能系统的基本能力 1.2. 如果一家卡车运输公司想要优化其100辆卡车在美国的运输&#xff0c;那么该公司可能需要考虑的状态数量将是10^700个 1.3. 几乎所有…

leetcode 第133场双周赛 100333.统计逆序对的数目【计数dp/滚动数组/前缀和优化】

分析&#xff1a; 先考虑如下问题。 求长度为n&#xff0c;逆序对为m的排列数量。 可以考虑dp&#xff0c;dp[i][j]定义为长度为i&#xff0c;逆序对为j的排列数量。 dp[1][0] 1; //枚举排列长度&#xff0c;或者认为枚举当前需要插到长度为i-1的排列中的数字 for(int i 1…

Mini-Contract电子合同在线签署小程序源码

Mini-Contract电子合同在线签署小程序源码&#xff0c;采用的是uniapp Vue3框架搭建&#xff0c;只有前端源码是一个聚合市场上各类电子合同解决方案商的工具&#xff0c;让用户无需一个个对接电子合同厂商&#xff0c;节省时间和精力。该程序提供了简洁的代码和最新的技术栈&a…