2023 年 数维杯(C题)国际大学生数学建模挑战赛 |数学建模完整代码+建模过程全解全析

news2025/1/21 14:14:03

问题重述

信息技术和人工智能的迅速发展,特别关注大型语言模型(Large Language Models,LLMs)在全球范围内的广泛应用,以ChatGPT为代表。这些模型在机器人导航、语音识别、图像识别、自然语言处理和智能推荐等领域表现出色,为人们提供了丰富、智能和便捷的体验。
然而,随着这些技术的普及,也出现了一些潜在问题。首先,这些大型语言模型是基于文本训练的,而不同领域的语言和文化背景可能对生成的结果产生重要影响。其次,生成的文本可能存在语义偏见、逻辑不连贯和缺乏创造力的问题。最后,涉及隐私保护、版权保护以及学术不端行为等问题,特别是在学术领域可能存在使用AI生成论文导致的相关问题。
因此,虽然这些模型为我们带来了很多便利,但也需要认识到其潜在风险和挑战。在这个背景下,题目提出了一系列问题,旨在深入探讨使用AI生成文本可能引发的问题,并提出建立模型和方法来解决这些问题。
在这里插入图片描述

问题一

我们可以定义一些关键变量,然后通过对这些变量进行统计分析来寻找AI文本生成的基本规律。以下是一些可能的变量:

  1. W W W:生成的字数要求,取值为200字、500字等。
  2. G G G:生成次数,包括首次生成和点击"重新生成"按钮的次数。
  3. T T T:是否中英文翻译,取值为0表示未翻译,1表示中文翻译,2表示英文翻译。
  4. S S S:生成文本的风格,可以用一个离散值表示。

我们可以通过一个包含这些变量的矩阵 X X X 来表示数据:

X = [ W 1 G 1 T 1 S 1 W 2 G 2 T 2 S 2 ⋮ ⋮ ⋮ ⋮ W N G N T N S N ] X = \begin{bmatrix} W_1 & G_1 & T_1 & S_1 \\ W_2 & G_2 & T_2 & S_2 \\ \vdots & \vdots & \vdots & \vdots \\ W_N & G_N & T_N & S_N \end{bmatrix} X= W1W2WNG1G2GNT1T2TNS1S2SN

接下来,我们可以通过对矩阵 X X X 进行统计分析,找到生成文本的基本规律。例如,我们可以计算在特定字数要求下,重新生成的次数的平均值、中英文翻译的频率分布、不同风格的出现频率等。

使用统计学方法,例如计算均值、方差、频率分布等。例如,我们可以定义一个函数 (f(W, G, T, S)) 来表示生成文本的某个方面,然后通过对 (X) 中的数据进行分析,得到关于这个函数的统计信息。

f ( W , G , T , S ) = 某个方面的特征 f(W, G, T, S) = \text{某个方面的特征} f(W,G,T,S)=某个方面的特征

在简单多元回归中,通过回归模型的输出来判断文本是否为AI生成,设置一个阈值,当模型的输出超过这个阈值时,认为文本是由AI生成的。

在多元回归中,模型的输出 Y Y Y 可以表示为:

Y = β 0 + β 1 ⋅ W + β 2 ⋅ G + β 3 ⋅ T + β 4 ⋅ S + ϵ Y = \beta_0 + \beta_1 \cdot W + \beta_2 \cdot G + \beta_3 \cdot T + \beta_4 \cdot S + \epsilon Y=β0+β1W+β2G+β3T+β4S+ϵ

其中, β 0 , β 1 , β 2 , β 3 , β 4 \beta_0, \beta_1, \beta_2, \beta_3, \beta_4 β0,β1,β2,β3,β4是回归系数, ϵ \epsilon ϵ 是误差项。

设置一个阈值 T AI T_{\text{AI}} TAI,当 Y > T AI Y > T_{\text{AI}} Y>TAI 时,认为文本是由AI生成的,否则认为不是。

在进行假设检验时,我们的目标是判断某个回归系数是否显著不为零。假设检验通常涉及到以下步骤:

首先,我们建立两个假设,即零假设 H 0 H_0 H0备择假设 H 1 H_1 H1

  • H 0 H_0 H0: 回归系数等于零,即 β i = 0 \beta_i = 0 βi=0,表示该变量对生成文本的某个方面没有显著影响。
  • H 1 H_1 H1: 回归系数不等于零,即 β i ≠ 0 \beta_i \neq 0 βi=0,表示该变量对生成文本的某个方面有显著影响。

选择显著性水平(Significance Level),通常用 (\alpha) 表示,例如取 (\alpha = 0.05)。这代表我们允许的错误发生率,即在零假设为真时错误地拒绝它的概率。

计算检验统计量(Test Statistic),该统计量用于在给定显著性水平下决定是否拒绝零假设。对于回归系数 (\beta_i),检验统计量通常计算为:

t = β ^ i SE ( β ^ i ) t = \frac{\hat{\beta}_i}{\text{SE}(\hat{\beta}_i)} t=SE(β^i)β^i

其中, β ^ i \hat{\beta}_i β^i 是回归系数的估计值, SE ( β ^ i ) \text{SE}(\hat{\beta}_i) SE(β^i) 是估计的标准误差。
根据检验统计量计算 p-值,p-值表示在零假设为真的情况下,观察到当前检验统计量或更极端情况的概率。

在给定的显著性水平下(通常为 (\alpha = 0.05)),比较 p-值和显著性水平,如果 (p < \alpha),则拒绝零假设,认为回归系数显著不为零;如果 (p \geq \alpha),则接受零假设,表示没有足够的证据拒绝零假设。

如果拒绝了零假设,说明相应的变量对生成文本的某个方面有显著影响。反之,如果接受了零假设,说明该变量对生成文本的某个方面没有显著影响。

通过假设检验的步骤,判断每个变量的回归系数是否显著不为零,从而在统计学上推断它们对生成文本的影响。

问题二

我们可以考虑使用一种二元分类的方法,通过分析每一段文本的多个因素来判断该段是否由AI生成。

定义一些可能影响判断的变量:

  1. L L L:生成语言,0表示未生成,1表示中文生成,2表示英文生成。
  2. (T):是否翻译,0表示未翻译,1表示中文翻译,2表示英文翻译。
  3. (G):生成次数,表示生成的次数。
  4. (L):输出字数限制,0表示没有字数限制,1表示有字数限制。

将这些变量用一个矩阵 (Y) 表示,其中每一行代表一段文本。

Y = [ L 1 T 1 G 1 L 1 L 2 T 2 G 2 L 2 ⋮ ⋮ ⋮ ⋮ L N T N G N L N ] Y = \begin{bmatrix} L_1 & T_1 & G_1 & L_1 \\ L_2 & T_2 & G_2 & L_2 \\ \vdots & \vdots & \vdots & \vdots \\ L_N & T_N & G_N & L_N \end{bmatrix} Y= L1L2LNT1T2TNG1G2GNL1L2LN

步骤二:建立二元分类模型

使用Transformer进行二元分类提供一些更具体的数学公式解释。我们将主要关注Transformer的Self-Attention机制和二元分类的数学表达。

1. Transformer的Self-Attention机制

Self-Attention机制允许模型在处理输入序列时对不同位置的信息分配不同的权重。对于一个输入序列 X X X,经过Self-Attention的计算,我们可以得到新的表示 (Z),其中 Z i Z_i Zi 表示第 i i i 个位置的表示。Self-Attention的计算可以用以下公式表示:

Z i = ∑ j Attention ( X i , X j ) ⋅ X j Z_i = \sum_{j} \text{Attention}(X_i, X_j) \cdot X_j Zi=jAttention(Xi,Xj)Xj

其中, Attention ( X i , X j ) \text{Attention}(X_i, X_j) Attention(Xi,Xj)表示第 i i i 个位置和第 j j j 个位置之间的注意力权重。

2. 文本表示

对于文本段落的表示,我们可以使用Transformer的输出中的某一维度,通常是CLS标记的输出。表示为 C C C

C = Transformer ( X ) C = \text{Transformer}(X) C=Transformer(X)

3. 二元分类层

将文本表示输入二元分类层,其中 (W) 是权重,(b) 是偏置,(f) 是激活函数(通常是Sigmoid函数):

y ^ = f ( W ⋅ C + b ) \hat{y} = f(W \cdot C + b) y^=f(WC+b)

4. 损失函数

使用二元交叉熵损失函数:

Loss = − 1 N ∑ i = 1 N [ y i log ⁡ ( y ^ i ) + ( 1 − y i ) log ⁡ ( 1 − y ^ i ) ] \text{Loss} = -\frac{1}{N} \sum_{i=1}^{N} \left[ y_i \log(\hat{y}_i) + (1-y_i) \log(1-\hat{y}_i) \right] Loss=N1i=1N[yilog(y^i)+(1yi)log(1y^i)]

其中, N N N 是样本数量, y i y_i yi 是实际标签(0或1), y ^ i \hat{y}_i y^i 是模型的预测输出。

5. 训练过程

通过反向传播算法,优化模型参数以最小化损失函数。使用梯度下降算法或其他优化算法。

6. 推断过程

在推断过程中,将新的文本输入模型,得到输出概率。可以根据概率设定一个阈值,例如0.5,判断文本是由AI生成还是非AI生成。

这些数学公式提供了对问题二中使用Transformer进行二元分类任务的详细解释。在实践中,可以根据具体情况调整模型结构和超参数。

步骤三:训练模型

使用已有的数据集,包含标记好的文本段落和对应的变量值,对模型进行训练。在训练中,模型将学习不同变量对于文本生成的影响,从而能够判断一段文本是否由AI生成。

在实际应用中,基于Transformer的二元分类任务的代码通常使用深度学习框架,例如TensorFlow或PyTorch。由于代码的长度较长,这里提供一个简化版本的伪代码,展示了关键的步骤和概念。

这个伪代码使用PyTorch作为深度学习框架,同时使用Hugging Face的Transformers库以便快速使用预训练的Transformer模型。

import torch
import torch.nn as nn
from transformers import BertModel, BertTokenizer

# 定义Transformer模型
class TransformerClassifier(nn.Module):
    def __init__(self, hidden_size, num_classes):
        super(TransformerClassifier, self).__init__()
        self.transformer = BertModel.from_pretrained('bert-base-uncased')
        self.fc = nn.Linear(hidden_size, num_classes)
        self.sigmoid = nn.Sigmoid()

    def forward(self, input_ids, attention_mask):
        outputs = self.transformer(input_ids, attention_mask=attention_mask)
        cls_output = outputs.last_hidden_state[:, 0, :]
        logits = self.fc(cls_output)
        proba = self.sigmoid(logits)
        return proba

# 数据预处理
tokenizer = BertTokenizer.from_pretrained('bert-base-uncased')
text = "This is a sample text."
inputs = tokenizer(text, return_tensors="pt", padding=True, truncation=True)

# 构建模型
hidden_size = 768  # BERT-base的隐藏层大小
num_classes = 1    # 二元分类
model = TransformerClassifier(hidden_size, num_classes)

# 模型输入
input_ids = inputs["input_ids"]
attention_mask = inputs["attention_mask"]

# 模型输出
output_proba = model(input_ids, attention_mask)

# 计算损失
criterion = nn.BCELoss()
target = torch.tensor([1.0])  # 实际标签
loss = criterion(output_proba, target)

# 反向传播与优化
optimizer = torch.optim.Adam(model.parameters(), lr=0.001)
optimizer.zero_grad()
loss.backward()
optimizer.step()

使用BERT模型进行文本表示,使用了Sigmoid激活函数和二元交叉熵损失函数进行二元分类。

步骤四:模型评估

使用另外的数据集对模型进行评估,检查模型的性能,包括准确率、召回率、精确率等指标。这些指标可以衡量模型在判断每一段文本生成情况上的表现。

import torch
from transformers import BertTokenizer

# 加载已训练的模型
model = TransformerClassifier(hidden_size, num_classes)
model.load_state_dict(torch.load('your_trained_model.pth'))  # 请替换为你实际的模型文件路径
model.eval()

# 数据预处理
tokenizer = BertTokenizer.from_pretrained('bert-base-uncased')
text = "This is a new text for inference."
inputs = tokenizer(text, return_tensors="pt", padding=True, truncation=True)

# 模型输入
input_ids = inputs["input_ids"]
attention_mask = inputs["attention_mask"]

# 推断
with torch.no_grad():
    output_proba = model(input_ids, attention_mask)

# 输出概率
print("预测概率:", output_proba.item())

# 根据阈值进行分类
threshold = 0.5
prediction = 1 if output_proba.item() > threshold else 0
print("预测结果:", prediction)

推理代码加载了之前训练好的模型权重,并使用该模型对新的文本进行推断。

这个方法结合了机器学习的思想,通过学习不同变量对文本生成的影响,使得模型能够在给定输入变量的情况下判断文本是否由AI生成。

问题三

对于语言模型特征中的信息熵,以及统计验证、特征工程、文献网络分析和社交网络分析等方法。

1. 语言模型特征:

1.1 信息熵:

信息熵是用来度量一个随机变量不确定度的概念,可以应用于文本的信息量评估。

H ( X ) = − ∑ i = 1 n P ( x i ) log ⁡ 2 P ( x i ) H(X) = - \sum_{i=1}^{n} P(x_i) \log_2 P(x_i) H(X)=i=1nP(xi)log2P(xi)

其中, P ( x i ) P(x_i) P(xi) 是词汇表中第 i i i个词出现的概率。

2. 实验设计与验证:

2.1 统计验证:

在统计验证中,一个常见的做法是使用 t 检验。

t = X ˉ − μ s / n t = \frac{\bar{X} - \mu}{s/\sqrt{n}} t=s/n Xˉμ

其中, X ˉ \bar{X} Xˉ 是样本均值, μ \mu μ是总体均值, s s s 是样本标准差, n n n 是样本大小。

3. 技术细节:

3.1 特征工程:

使用 TF-IDF进行关键词权重计算。

TF-IDF ( t , d ) = TF ( t , d ) × IDF ( t ) \text{TF-IDF}(t, d) = \text{TF}(t, d) \times \text{IDF}(t) TF-IDF(t,d)=TF(t,d)×IDF(t)

其中,TF 表示词频,IDF 表示逆文档频率。

4. 引用和参考文献:

4.1 文献网络分析:

可以使用图论的相关指标,如节点度、中心性等。

centrality = 连接到节点的边数 总节点数 − 1 \text{centrality} = \frac{\text{连接到节点的边数}}{\text{总节点数}-1} centrality=总节点数1连接到节点的边数

5. 作者身份可疑:

5.1 社交网络分析:

使用社交网络中的中心性指标,例如介数中心性。

介数中心性 = ∑ s ≠ v ≠ t σ ( s , t ∣ v ) σ ( s , t ) \text{介数中心性} = \sum_{s \neq v \neq t} \frac{\sigma(s, t|v)}{\sigma(s, t)} 介数中心性=s=v=tσ(s,t)σ(s,tv)

其中, σ ( s , t ) \sigma(s, t) σ(s,t) 表示从节点 s s s 到节点 t t t 的最短路径数, σ ( s , t ∣ v ) \sigma(s, t|v) σ(s,tv) 表示通过节点 (v) 的最短路径数。

结合多个特征进行加权得分和二元分类判断:

class BinaryClassifier:
    def __init__(self, weights, threshold):
        self.weights = weights
        self.threshold = threshold

    def calculate_total_score(self, features):
        # 计算总得分
        total_score = sum(f * w for f, w in zip(features, self.weights))
        return total_score

    def classify(self, total_score):
        # 进行二元分类判断
        return "AI生成" if total_score > self.threshold else "人类创作"

# 示例特征和权重
example_features = [feature1, feature2, feature3]  # 请替换为实际特征的值
example_weights = [weight1, weight2, weight3]  # 请替换为实际权重的值

# 示例阈值
example_threshold = 0.5  # 请替换为实际阈值

# 创建二元分类器对象
classifier = BinaryClassifier(weights=example_weights, threshold=example_threshold)

# 计算总得分
total_score_example = classifier.calculate_total_score(example_features)

# 进行二元分类判断
classification_result = classifier.classify(total_score_example)

# 打印结果
print(f"总得分: {total_score_example}")
print(f"分类结果: {classification_result}")

问题四:

了解,建立一个综合的抄袭检测模型需要综合考虑文本、图像和公式等多个方面。以下是一个简化的框架,其中包括文本相似性、图像处理和公式匹配等不同模块:

文本相似性模块:

使用文本相似性度量方法,如余弦相似度,来比较文章中数学模型的文本描述。

from sklearn.feature_extraction.text import CountVectorizer
from sklearn.metrics.pairwise import cosine_similarity

def calculate_text_similarity(text1, text2):
    vectorizer = CountVectorizer().fit_transform([text1, text2])
    vectors = vectorizer.toarray()
    similarity = cosine_similarity([vectors[0]], [vectors[1]])[0][0]
    return similarity

图像处理模块:

使用深度学习方法对图像进行特征提取,然后比较图像的相似性。

# 使用适当的深度学习库导入模型和相关功能
from tensorflow.keras.applications import VGG16
from tensorflow.keras.preprocessing import image
from tensorflow.keras.applications.vgg16 import preprocess_input
from tensorflow.keras.models import Model
import numpy as np

def calculate_image_similarity(image_path1, image_path2):
    # 使用预训练的VGG16模型提取图像特征
    model = VGG16(weights='imagenet', include_top=False)
    img1 = image.load_img(image_path1, target_size=(224, 224))
    img2 = image.load_img(image_path2, target_size=(224, 224))
    img1 = image.img_to_array(img1)
    img2 = image.img_to_array(img2)
    img1 = preprocess_input(np.expand_dims(img1, axis=0))
    img2 = preprocess_input(np.expand_dims(img2, axis=0))
    features1 = model.predict(img1)
    features2 = model.predict(img2)

    # 使用余弦相似度计算特征向量的相似性
    similarity = cosine_similarity(features1.flatten().reshape(1, -1), features2.flatten().reshape(1, -1))[0][0]
    return similarity

公式匹配模块:

使用LaTeX解析器将公式解析成结构化的数据,然后比较两个公式的结构相似性。

# 使用适当的LaTeX解析库导入模型和相关功能
from sympy import Eq, latex, simplify, symbols
from sympy.parsing.latex import parse_latex

def calculate_formula_similarity(formula1, formula2):
    # 解析LaTeX公式
    expr1 = parse_latex(formula1)
    expr2 = parse_latex(formula2)

    # 简化表达式
    simplified_expr1 = simplify(expr1)
    simplified_expr2 = simplify(expr2)

    # 比较两个公式的相似性
    similarity = float(simplified_expr1.equals(simplified_expr2))
    return similarity

模型整合:

将以上三个模块整合为一个综合的抄袭检测模型:

class PlagiarismDetectionModel:
    def __init__(self, text_weight, image_weight, formula_weight):
        self.text_weight = text_weight
        self.image_weight = image_weight
        self.formula_weight = formula_weight

    def detect_plagiarism(self, text1, text2, image_path1, image_path2, formula1, formula2):
        # 计算各模块相似性
        text_similarity = calculate_text_similarity(text1, text2)
        image_similarity = calculate_image_similarity(image_path1, image_path2)
        formula_similarity = calculate_formula_similarity(formula1, formula2)

        # 综合得分
        total_score = self.text_weight * text_similarity + self.image_weight * image_similarity + self.formula_weight * formula_similarity

        # 返回结果
        return total_score

消融实验

消融实验是为了评估模型中各个组成部分的重要性,通常通过逐步移除某个组件并观察模型性能的变化来进行。在抄袭检测模型中,我们可以进行消融实验以评估文本、图像和公式模块对整体抄袭检测性能的贡献。

以下是一个简单的消融实验示例,假设我们有一个包含文本、图像和公式的抄袭检测模型,我们分别对这三个模块进行消融实验:

class AblationExperiment:
    def __init__(self, model):
        self.model = model

    def text_ablation(self, text1, text2, image_path1, image_path2, formula1, formula2):
        # 移除文本模块
        self.model.text_weight = 0
        total_score = self.model.detect_plagiarism(text1, text2, image_path1, image_path2, formula1, formula2)
        return total_score

    def image_ablation(self, text1, text2, image_path1, image_path2, formula1, formula2):
        # 移除图像模块
        self.model.image_weight = 0
        total_score = self.model.detect_plagiarism(text1, text2, image_path1, image_path2, formula1, formula2)
        return total_score

    def formula_ablation(self, text1, text2, image_path1, image_path2, formula1, formula2):
        # 移除公式模块
        self.model.formula_weight = 0
        total_score = self.model.detect_plagiarism(text1, text2, image_path1, image_path2, formula1, formula2)
        return total_score

在这个示例中,我们创建了一个AblationExperiment类,该类允许我们分别移除文本、图像和公式模块,然后检查模型性能的变化。

plagiarism_model = PlagiarismDetectionModel(text_weight=0.5, image_weight=0.3, formula_weight=0.2)
experiment = AblationExperiment(plagiarism_model)

# 示例文本、图像和公式
example_text1 = ""
example_text2 = ""
example_image_path1 = "path/to/image1.jpg"
example_image_path2 = "path/to/image2.jpg"
example_formula1 = "a = b + c"
example_formula2 = "x = y * z"

# 消融实验:移除文本模块
text_ablation_score = experiment.text_ablation(example_text1, example_text2, example_image_path1, example_image_path2, example_formula1, example_formula2)

# 消融实验:移除图像模块
image_ablation_score = experiment.image_ablation(example_text1, example_text2, example_image_path1, example_image_path2, example_formula1, example_formula2)

# 消融实验:移除公式模块
formula_ablation_score = experiment.formula_ablation(example_text1, example_text2, example_image_path1, example_image_path2, example_formula1, example_formula2)

# 打印结果
print(f"移除文本模块后得分: {text_ablation_score}")
print(f"移除图像模块后得分: {image_ablation_score}")
print(f"移除公式模块后得分: {formula_ablation_score}")

2023 年 数维杯(C题) CS数模 国际大学生数学建模挑战赛 全解全析

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

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

相关文章

Dread Hunger恐惧饥荒服务器宣布关服

Dread Hunger恐惧饥荒服务器宣布关服 大家好我是艾西&#xff0c;如果不是被逼无奈 谁不喜欢在自己的舒适圈待着呢.从2022年年初到2023年下半年有太多的记忆了从最开始的当狼激动开心到后面慢慢的变成了一种恐惧&#xff0c;从最开始的变态花活变成了只要赢就行逐渐麻木了 作为…

Ubuntu 安装VMware Tools选项显示灰色,如何安装VMware Tools

只要你的网络没问题&#xff0c;你直接执行这几个命令&#xff0c;重启ubuntu虚拟机即可、 sudo dpkg --configure -a sudo apt-get autoremove open-vm-tools sudo apt-get install open-vm-tools sudo apt-get install open-vm-tools-desktop

苹果电脑录屏快捷键,让你成为录屏达人

“苹果电脑录屏好麻烦呀&#xff0c;操作步骤很繁琐&#xff0c;有人知道苹果电脑怎么快速录屏呀&#xff0c;要是有快捷键就更好了&#xff0c;大家知道苹果电脑有录屏快捷键吗&#xff1f;谢谢啦&#xff01;” 苹果电脑以其直观的用户界面和卓越的性能而闻名&#xff0c;而…

MES选型注意事项

1、明确需求和边界 企业首先要明确需要MES哪些模块及要实现的目标&#xff0c;如实现质量透明化、设备状态管理、IPQC检验管理等。MES通常要与其他系统集成&#xff0c;如与ERP集成&#xff0c;要事先明确哪些在ERP中做&#xff0c;哪些在MES中做&#xff0c;哪些需要同步。 车…

java VR全景商城免费搭建 saas商城 b2b2c商城 o2o商城 积分商城 秒杀商城 拼团商城 分销商城 短视频商城

1. 涉及平台 平台管理、商家端&#xff08;PC端、手机端&#xff09;、买家平台&#xff08;H5/公众号、小程序、APP端&#xff08;IOS/Android&#xff09;、微服务平台&#xff08;业务服务&#xff09; 2. 核心架构 Spring Cloud、Spring Boot、Mybatis、Redis 3. 前端框架…

普源DS1052E固件升级【附所有升级固件及工具】

折腾了两天&#xff0c;总算是弄好了。 升级的目的是啥&#xff1f;DS1052E的带宽是50M&#xff0c;示波器的时基最小可以调到5ns。固件升级后示波器的时基最小可以调到2ns&#xff0c;理论上说明此时示波器的带宽是100M。 网上的方法能找到很多&#xff0c;我总结一下大概的流…

23款奔驰GLC260L升级小柏林音响 全新15个扬声器

2023年款奔驰GLC260 GLC300升级小柏林之声 3D音效系统 升级小柏林之声音响之后&#xff0c;全车一共有15个喇叭&#xff0c;1台功放&#xff0c;每一首音乐都能在车内掀起激情的音浪&#xff0c;感受纯粹的音乐享受&#xff0c;低频震撼澎湃&#xff0c;让你的心跳与音乐完美契…

【2021集创赛】Arm杯二等奖-基于Arm核的智慧病房手势识别方案

团队介绍 参赛单位&#xff1a;上海交通大学 队伍名称&#xff1a;芯灵手巧 指导老师&#xff1a;王琴、景乃锋 参赛队员&#xff1a;林圣凯、林新源、莫志文 总决赛奖项&#xff1a;二等奖 1.项目概述 1.1 选题背景 我们的选题背景是考虑到很多卧床病人不便于独自向医护人…

前端实现RSA非对称加密及生成RSA公私密钥

前端实现RSA非对称加密 RSA简介安装jsencryptRSA加密RSA解密如何生成公私秘钥&#xff08;windows&#xff09; RSA简介 RSA用于保密性时&#xff0c;就是公钥加密&#xff0c;私钥解密。 因为公钥是可以公开了&#xff0c; 那么任何人都可以使用公钥对信息进行加密&#xff0…

Win10系统投影到此电脑的功能无法使用的解决办法(Miracast: Available, no HDCP)

前提是电脑得支持Miracast 1. 如何查看自己的win10电脑是否支持Miracast无线投屏功能 通过window R快捷键运行dxdiag.exe。等待Direct X 诊断工具检测完毕点击保存所有信息。通过记事本打开刚才保存的DxDiag.txt 查找有关Miracast的信息。【NotAvailable】表示不支持【Availab…

SecureCRT 9.4.2 for Mac

SecureCRT是一款由VanDyke Software公司开发的终端仿真软件&#xff0c;它提供了类似于Telnet和SSH等协议的远程访问功能。SecureCRT专门为网络管理员、系统管理员和其他需要保密访问网络设备的用户设计。 SecureCRT具有以下特点&#xff1a; 安全性&#xff1a;SecureCRT支持…

学网络安全需要报名参加培训吗?

目前&#xff0c;网络安全产业已经进入高速发展阶段&#xff0c;不仅得到了国家政策支持&#xff0c;而且各行各业对网络安全人才的需求量不断增加&#xff0c;因此网络安全也成为了当下热门的职业&#xff0c;更是拿高薪、转行IT的首选方向。那么&#xff0c;对于零基础小白而…

vue的常用指令

1.使用双花括号( {{}} )对变量输出,内部可以写简单的表达式用于对数据的处理 2..v-text&#xff1a;相当于js的innerText, 3.v-html&#xff1a;相当于js的innerHTML 4.v-bind&#xff1a;动态绑定属性,简写是冒号( : ) 5.绑定class&#xff1a;操作元素的 class 列表和内联样式…

最简单的测试Jquery-jquery是否正常工作的代码

01-运行后在页面上显示“jQuery is working!” 代码如下&#xff1a; <!DOCTYPE html> <html> <head><meta charset"UTF-8"><title>it is title</title><meta name"viewport" content"widthdevice-width,in…

【missing-semester】The shell

文章目录 shell 是什么shell 怎么用执行基本程序 Shell中的路径重定向输入输出管道piperoot用户的使用课后练习参考资料 我的操作环境&#xff1a;Windows11下的WSL2(Ubuntu20.04)&#xff0c;之后的所有操作都是基于这个前提的 shell 是什么 命令行操作语言&#xff0c;文本界…

FastAdmin表格顶部增加toolbar按钮

效果入下图&#xff0c;在表格顶部增加一个自定义按钮&#xff0c;点击确认后请求服务器接口 表格对应的index.html中 <div class"panel-body"><div id"myTabContent" class"tab-content"><div class"tab-pane fade active …

使用 Gradle 命令了解项目构建信息

引言 首先&#xff0c;Gradle 作为使用 Android Studio 开发 Android 项目的默认构建工具&#xff0c;它里面的任何东西都基于两个概念&#xff1a; projects ( 项目 )tasks ( 任务 ) 每一个构建由一个或多个 projects 构成&#xff0c;每一个 project 由一个或多个 tasks 构…

基于象群算法优化概率神经网络PNN的分类预测 - 附代码

基于象群算法优化概率神经网络PNN的分类预测 - 附代码 文章目录 基于象群算法优化概率神经网络PNN的分类预测 - 附代码1.PNN网络概述2.变压器故障诊街系统相关背景2.1 模型建立 3.基于象群优化的PNN网络5.测试结果6.参考文献7.Matlab代码 摘要&#xff1a;针对PNN神经网络的光滑…

IDEA写mybatis程序,java.io.IOException:Could not find resource mybatis-config.xml

找不到mybatis-config.xml 尝试maven idea:module&#xff0c;不是模块构造问题 尝试检验pom.xml&#xff0c;在编译模块添加了解析resources内容依旧不行 <?xml version"1.0" encoding"UTF-8"?> <project xmlns"http://maven.apache.or…

微服务和Spring Cloud Alibaba介绍

1、微服务介绍 1.1 系统架构演变 随着互联网的发展&#xff0c;网站应用的规模也在不断的扩大&#xff0c;进而导致系统架构也在不断的进行变化。从互联网早起到现在&#xff0c;系统架构大体经历了下面几个过程: 单体应用架构 —> 垂直应用架构 —> 分布 式架构—>…