【机器学习】使用Python实现图神经网络(GNN):图结构数据的分析与应用

在这里插入图片描述

🔥 个人主页:空白诗

在这里插入图片描述

文章目录

    • 一、引言
    • 二、图神经网络的基础知识
      • 1. 图的基本概念和术语
      • 2. 传统的图分析方法
      • 3. 图神经网络的基本原理
      • 4. GNN的基本模型
    • 三、主要的图神经网络模型
      • 1. 图卷积网络(Graph Convolutional Network, GCN)
      • 2. 图注意力网络(Graph Attention Network, GAT)
      • 3. 图自编码器(Graph Autoencoder)
      • 4. 图对抗网络(Graph GANs)
    • 四、图神经网络的应用场景
      • 1. 社交网络分析
      • 2. 生物信息学
      • 3. 化学分子图
      • 4. 交通网络
      • 5. 自然语言处理
    • 五、总结

在这里插入图片描述


一、引言

在现代数据分析中,图数据因其能够自然地表示对象及其相互关系,越来越受到关注。图结构在许多实际应用中普遍存在,如社交网络中的用户关系、化学分子中的原子和键、生物信息学中的基因交互网络、交通系统中的道路和交叉口等。传统的数据分析方法在处理这些复杂的图结构数据时常常力不从心,难以充分挖掘其中的潜在信息。

图神经网络(Graph Neural Networks, GNNs)作为一种新兴的机器学习方法,能够有效地处理和分析图结构数据。GNNs通过传播机制(message passing)在图的节点和边之间传播信息,捕捉复杂的节点间关系和图的全局结构,从而实现对图数据的深层次理解和高效处理。近年来,随着深度学习技术的发展,GNNs在多个领域取得了显著的成果,成为研究热点。

本文旨在系统地介绍图神经网络的基本原理、主要模型及其在不同应用场景中的实际案例。首先,我们将概述图的基本概念及传统图分析方法,接着深入探讨GNN的主要模型和应用,最后讨论当前GNN研究面临的挑战与未来发展方向。通过本文的介绍,读者将能够全面了解图神经网络这一强大工具在图结构数据分析中的潜力与应用前景。


二、图神经网络的基础知识

在这里插入图片描述

1. 图的基本概念和术语

在深入理解图神经网络之前,首先需要了解图的基本概念及其相关术语。

  • 节点(Node):图中的基本元素,表示实体或对象。
  • 边(Edge):连接节点的线,表示节点间的关系。
  • 邻接矩阵(Adjacency Matrix):用矩阵形式表示图中节点之间连接关系的矩阵。

例如,一个简单的无向图可以表示为:

节点 A
节点 B
节点 C
  • 图的类型
    • 无向图(Undirected Graph):边没有方向。
    • 有向图(Directed Graph):边具有方向。
    • 加权图(Weighted Graph):边带有权重,表示关系的强度。

2. 传统的图分析方法

在图神经网络之前,传统的图分析方法主要包括:

  • 最短路径算法:如Dijkstra算法,用于计算两个节点之间的最短路径。
  • PageRank算法:用于评估节点在图中的重要性,广泛应用于网页排名。

3. 图神经网络的基本原理

图神经网络通过一种称为传播机制(Message Passing)的过程来实现信息在图中节点和边之间的传递与更新。具体来说,GNN的基本原理包括以下几个步骤:

  1. 消息传递(Message Passing):每个节点从其邻居节点接收信息。
  2. 信息聚合(Aggregation):将接收到的邻居节点信息进行聚合,通常使用求和、平均或最大值等操作。
  3. 状态更新(Update):根据聚合的邻居信息和节点自身的信息更新节点状态。

可以用下图示来表示消息传递和信息聚合过程:

Update
Aggregation
Message Passing
发送消息
发送消息
发送消息
发送消息
发送消息
发送消息
聚合邻居消息
使用新状态
节点 B的最终状态
节点 B的新状态
节点 B
节点 A
节点 C

4. GNN的基本模型

图神经网络的基本模型通过上述过程在多层网络中逐层传播和聚合信息。以下是几种主要的GNN模型:

  • 图卷积网络(Graph Convolutional Network, GCN):利用卷积操作在图上进行信息聚合,能够捕捉局部图结构特征。
  • 图注意力网络(Graph Attention Network, GAT):引入注意力机制,为每个邻居节点分配不同的权重,从而实现更灵活的信息聚合。
  • 图自编码器(Graph Autoencoder):通过编码器-解码器结构实现图数据的自监督学习。
  • 图对抗网络(Graph GANs):利用生成对抗网络在图结构数据中生成和判别节点及边的信息。

通过对这些模型的理解,可以更好地应用GNN处理实际的图结构数据。接下来,我们将详细介绍这些主要的图神经网络模型及其应用。


三、主要的图神经网络模型

图神经网络(GNN)在近年来的发展中涌现出多种模型,每种模型都有其独特的优势和应用场景。以下是几种主要的GNN模型及其基本原理和应用示例。

1. 图卷积网络(Graph Convolutional Network, GCN)

GCN利用卷积操作在图结构数据上进行信息聚合,能够有效捕捉局部图结构特征。GCN的核心思想是通过节点的邻居节点信息来更新该节点的表示。

GCN的前向传播公式为:

H ( l + 1 ) = σ ( D − 1 2 A D − 1 2 H ( l ) W ( l ) ) H^{(l+1)} = \sigma \left( D^{-\frac{1}{2}} A D^{-\frac{1}{2}} H^{(l)} W^{(l)} \right) H(l+1)=σ(D21AD21H(l)W(l))

其中, H ( l ) H^{(l)} H(l)表示第 l l l层的节点特征矩阵, A A A表示邻接矩阵, D D D表示度矩阵, W ( l ) W^{(l)} W(l)表示第 l l l层的权重矩阵, σ ( ⋅ ) \sigma(\cdot) σ()表示激活函数。

以下是一个简单的GCN代码示例:

import torch
import torch.nn as nn
import torch.nn.functional as F
import networkx as nx
from torch_geometric.datasets import Planetoid
from torch_geometric.nn import GCNConv# 加载数据集
dataset = Planetoid(root='/tmp/Cora', name='Cora')class GCN(nn.Module):def __init__(self):super(GCN, self).__init__()self.conv1 = GCNConv(dataset.num_node_features, 16)self.conv2 = GCNConv(16, dataset.num_classes)def forward(self, data):x, edge_index = data.x, data.edge_indexx = self.conv1(x, edge_index)x = F.relu(x)x = F.dropout(x, training=self.training)x = self.conv2(x, edge_index)return F.log_softmax(x, dim=1)# 模型训练和评估代码略

2. 图注意力网络(Graph Attention Network, GAT)

GAT引入了注意力机制,为每个邻居节点分配不同的权重,从而实现更灵活的信息聚合。注意力机制使得模型能够根据邻居节点的重要性来更新节点的表示。

GAT的核心思想是通过注意力机制计算邻居节点的权重:

e i j = LeakyReLU ( a T [ W h i ∥ W h j ] ) e_{ij} = \text{LeakyReLU}(\mathbf{a}^T [\mathbf{W} \mathbf{h}_i \parallel \mathbf{W} \mathbf{h}_j]) eij=LeakyReLU(aT[WhiWhj])

α i j = exp ⁡ ( e i j ) ∑ k ∈ N i exp ⁡ ( e i k ) \alpha_{ij} = \frac{\exp(e_{ij})}{\sum_{k \in N_i} \exp(e_{ik})} αij=kNiexp(eik)exp(eij)

以下是一个简单的GAT代码示例:

import torch
import torch.nn as nn
import torch.nn.functional as F
from torch_geometric.datasets import Planetoid
from torch_geometric.nn import GATConv# 加载数据集
dataset = Planetoid(root='/tmp/Cora', name='Cora')class GAT(nn.Module):def __init__(self):super(GAT, self).__init__()self.conv1 = GATConv(dataset.num_node_features, 8, heads=8, dropout=0.6)self.conv2 = GATConv(8*8, dataset.num_classes, heads=1, concat=True, dropout=0.6)def forward(self, data):x, edge_index = data.x, data.edge_indexx = F.dropout(x, p=0.6, training=self.training)x = self.conv1(x, edge_index)x = F.elu(x)x = F.dropout(x, p=0.6, training=self.training)x = self.conv2(x, edge_index)return F.log_softmax(x, dim=1)# 模型训练和评估代码略

3. 图自编码器(Graph Autoencoder)

图自编码器通过编码器-解码器结构实现图数据的自监督学习,主要用于图的重构和表示学习。

以下是一个简单的图自编码器代码示例:

import torch
import torch.nn.functional as F
from torch_geometric.nn import GCNConvclass GAE(nn.Module):def __init__(self, in_channels, out_channels):super(GAE, self).__init__()self.conv1 = GCNConv(in_channels, 2 * out_channels)self.conv2 = GCNConv(2 * out_channels, out_channels)def encode(self, x, edge_index):x = F.relu(self.conv1(x, edge_index))return self.conv2(x, edge_index)def decode(self, z, edge_index):return torch.sigmoid((z[edge_index[0]] * z[edge_index[1]]).sum(dim=1))def forward(self, data):z = self.encode(data.x, data.edge_index)return self.decode(z, data.edge_index)# 模型训练和评估代码略

4. 图对抗网络(Graph GANs)

图对抗网络通过生成对抗网络(GAN)的框架来处理图结构数据,生成高质量的图数据表示。

以下是一个简单的图对抗网络代码示例:

import torch
import torch.nn as nn
import torch.optim as optim
from torch_geometric.datasets import Planetoid
from torch_geometric.nn import GCNConvclass Generator(nn.Module):def __init__(self, in_channels, out_channels):super(Generator, self).__init__()self.conv1 = GCNConv(in_channels, 2 * out_channels)self.conv2 = GCNConv(2 * out_channels, out_channels)def forward(self, x, edge_index):x = F.relu(self.conv1(x, edge_index))return self.conv2(x, edge_index)class Discriminator(nn.Module):def __init__(self, in_channels):super(Discriminator, self).__init__()self.conv = GCNConv(in_channels, 1)def forward(self, x, edge_index):return torch.sigmoid(self.conv(x, edge_index))# 模型训练和评估代码略

通过这些模型,可以在不同的应用场景中选择合适的图神经网络,以实现对图结构数据的有效处理和分析。在实际应用中,通常需要根据具体的数据特点和任务要求,对模型进行调整和优化。


四、图神经网络的应用场景

图神经网络(GNN)因其强大的建模能力和灵活性,在许多领域都有广泛的应用。以下是几个主要的应用场景及其具体案例:

1. 社交网络分析

在社交网络中,用户之间的关系可以自然地表示为图结构。GNN在以下几个方面有显著的应用:

  • 用户推荐:通过捕捉用户之间的关系和行为模式,GNN可以预测用户的兴趣,推荐可能感兴趣的朋友或内容。例如,Pinterest使用PinSage(一种基于GCN的模型)来进行内容推荐。
用户 A
内容 B
内容 C
用户 D
内容 E

代码示例(以PinSage为例):

import torch
import torch.nn.functional as F
from torch_geometric.nn import GCNConvclass PinSage(torch.nn.Module):def __init__(self, in_channels, out_channels):super(PinSage, self).__init__()self.conv1 = GCNConv(in_channels, out_channels)self.conv2 = GCNConv(out_channels, out_channels)def forward(self, x, edge_index):x = F.relu(self.conv1(x, edge_index))x = self.conv2(x, edge_index)return F.log_softmax(x, dim=1)# 数据加载和模型训练代码略
  • 社区检测:GNN可以有效识别社交网络中的社区结构,将相似的用户分组。例如,Twitter利用GNN来检测和分析网络中的兴趣社区。
社区 2
社区 1
用户 E
用户 D
用户 F
用户 B
用户 A
用户 C

代码示例(社区检测):

import torch
import torch.nn as nn
import torch_geometric.nn as pyg_nnclass CommunityDetectionGNN(nn.Module):def __init__(self, in_channels, hidden_channels, out_channels):super(CommunityDetectionGNN, self).__init__()self.conv1 = pyg_nn.GCNConv(in_channels, hidden_channels)self.conv2 = pyg_nn.GCNConv(hidden_channels, out_channels)def forward(self, x, edge_index):x = F.relu(self.conv1(x, edge_index))x = self.conv2(x, edge_index)return F.log_softmax(x, dim=1)# 数据加载和模型训练代码略

2. 生物信息学

生物信息学中存在大量的图结构数据,如基因-蛋白质相互作用网络、蛋白质结构图等。GNN在以下几个方面表现出色:

  • 蛋白质-蛋白质相互作用预测:通过建模蛋白质之间的相互作用网络,GNN可以预测未发现的蛋白质交互关系,帮助揭示生物过程的机制。
蛋白质 A
蛋白质 B
蛋白质 C
蛋白质 D

代码示例(蛋白质相互作用预测):

import torch
import torch.nn as nn
from torch_geometric.nn import GCNConvclass ProteinInteractionGNN(nn.Module):def __init__(self, in_channels, hidden_channels, out_channels):super(ProteinInteractionGNN, self).__init__()self.conv1 = GCNConv(in_channels, hidden_channels)self.conv2 = GCNConv(hidden_channels, out_channels)def forward(self, x, edge_index):x = F.relu(self.conv1(x, edge_index))x = self.conv2(x, edge_index)return torch.sigmoid(x)# 数据加载和模型训练代码略
  • 药物发现:GNN可以用来分析化合物分子的结构,预测其生物活性,从而加速新药的发现。例如,GraphDTA使用GNN来预测药物-靶点的结合亲和力。
药物 A
靶点 B
药物 C
靶点 D

代码示例(药物发现):

import torch
import torch.nn as nn
from torch_geometric.nn import GCNConvclass DrugTargetGNN(nn.Module):def __init__(self, in_channels, hidden_channels, out_channels):super(DrugTargetGNN, self).__init__()self.conv1 = GCNConv(in_channels, hidden_channels)self.conv2 = GCNConv(hidden_channels, out_channels)def forward(self, x, edge_index):x = F.relu(self.conv1(x, edge_index))x = self.conv2(x, edge_index)return torch.sigmoid(x)# 数据加载和模型训练代码略

3. 化学分子图

化学分子可以表示为图结构,其中节点代表原子,边代表化学键。GNN在以下几个方面有重要应用:

  • 分子性质预测:通过建模分子的图结构,GNN可以预测分子的物理化学性质,如溶解度、稳定性等。这在材料科学和药物设计中尤为重要。例如,ChemProp使用GCN来预测分子的各种性质。
碳原子
氧原子
氢原子
氢原子
氢原子
氢原子

代码示例(分子性质预测):

import torch
import torch.nn as nn
from torch_geometric.nn import GCNConvclass MolecularPropertyGNN(nn.Module):def __init__(self, in_channels, hidden_channels, out_channels):super(MolecularPropertyGNN, self).__init__()self.conv1 = GCNConv(in_channels, hidden_channels)self.conv2 = GCNConv(hidden_channels, out_channels)def forward(self, x, edge_index):x = F.relu(self.conv1(x, edge_index))x = self.conv2(x, edge_index)return x# 数据加载和模型训练代码略
  • 新药研发:通过分析分子图结构,GNN可以生成具有特定性质的新分子,帮助化学家设计新药。
新分子 A
属性 B
新分子 C
属性 D

代码示例(新药研发):

import torch
import torch.nn as nn
from torch_geometric.nn import GCNConvclass DrugDiscoveryGNN(nn.Module):def __init__(self, in_channels, hidden_channels, out_channels):super(DrugDiscoveryGNN, self).__init__()self.conv1 = GCNConv(in_channels, hidden_channels)self.conv2 = GCNConv(hidden_channels, out_channels)def forward(self, x, edge_index):x = F.relu(self.conv1(x, edge_index))x = self.conv2(x, edge_index)return x# 数据加载和模型训练代码略

4. 交通网络

在交通系统中,路网可以表示为图结构,其中节点代表交叉口,边代表道路。GNN在以下几个方面具有应用前景:

  • 路径优化:通过分析交通路网的图结构,GNN可以优化路径选择,提高交通效率。
交叉口 A
交叉口 B
交叉口 C
交叉口 D

代码示例(路径优化):

import torch
import torch.nn as nn
from torch_geometric.nn import GCNConvclass TrafficPathOptimizationGNN(nn.Module):def __init__(self, in_channels, hidden_channels, out_channels):super(TrafficPathOptimizationGNN, self).__init__()self.conv1 = GCNConv(in_channels, hidden_channels)self.conv2 = GCNConv(hidden_channels, out_channels)def forward(self, x, edge_index):x = F.relu(self.conv1(x, edge_index))x = self.conv2(x, edge_index)return x# 数据加载和模型训练代码略
  • 交通流量预测:GNN可以通过建模历史交通数据,预测未来的交通流量,帮助交通管理部门做出更好的决策。例如,ST-GCN使用GNN来进行交通流量预测,效果显著。
流量数据
流量数据
流量数据
流量数据
交叉口 A
交叉口 B
交叉口 C
交叉口 D

代码示例(交通流量预测):

import torch
import torch.nn as nn
from torch_geometric.nn import GCNConvclass TrafficFlowPredictionGNN(nn.Module):def __init__(self, in_channels, hidden_channels, out_channels):super(TrafficFlowPredictionGNN, self).__init__()self.conv1 = GCNConv(in_channels, hidden_channels)self.conv2 = GCNConv(hidden_channels, out_channels)def forward(self, x, edge_index):x = F.relu(self.conv1(x, edge_index))x = self.conv2(x, edge_index)return x# 数据加载和模型训练代码略

5. 自然语言处理

在自然语言处理(NLP)领域,文本数据可以表示为图结构,如句子之间的关系、词语之间的依赖关系等。GNN在以下几个方面有广泛应用:

  • 句子关系建模:通过建模句子之间的关系,GNN可以提升问答系统和文本分类的性能。例如,Text GCN利用GCN对文档进行分类。
句子1
词1
词2
句子2
词3

代码示例(句子关系建模):

import torch
import torch.nn as nn
from torch_geometric.nn import GCNConvclass TextGCN(nn.Module):def __init__(self, in_channels, hidden_channels, out_channels):super(TextGCN, self).__init__()self.conv1 = GCNConv(in_channels, hidden_channels)self.conv2 = GCNConv(hidden_channels, out_channels)def forward(self, x, edge_index):x = F.relu(self.conv1(x, edge_index))x = self.conv2(x, edge_index)return F.log_softmax(x, dim=1)# 数据加载和模型训练代码略
  • 知识图谱:GNN可以用来处理和推理知识图谱中的信息,提升知识图谱的完备性和准确性。例如,R-GCN使用GNN来推理知识图谱中的实体关系。
实体1
关系1
实体2
关系2
实体3
关系3

代码示例(知识图谱推理):

import torch
import torch.nn as nn
from torch_geometric.nn import RGCNConvclass KnowledgeGraphGNN(nn.Module):def __init__(self, in_channels, hidden_channels, out_channels, num_relations):super(KnowledgeGraphGNN, self).__init__()self.conv1 = RGCNConv(in_channels, hidden_channels, num_relations)self.conv2 = RGCNConv(hidden_channels, out_channels, num_relations)def forward(self, x, edge_index, edge_type):x = F.relu(self.conv1(x, edge_index, edge_type))x = self.conv2(x, edge_index, edge_type)return F.log_softmax(x, dim=1)# 数据加载和模型训练代码略

这些案例展示了图神经网络在不同领域中的广泛应用和巨大潜力。通过结合领域知识和先进的图神经网络技术,可以进一步推动各领域的研究和应用进展。


五、总结

图神经网络(GNN)凭借其强大的建模能力和灵活性,在许多领域展现了巨大的潜力和广泛的应用。在社交网络分析中,GNN能够通过用户之间的关系和行为模式进行精准的用户推荐和社区检测,显著提升社交平台的用户体验。在生物信息学领域,GNN通过建模基因-蛋白质相互作用网络和蛋白质结构图,促进了蛋白质-蛋白质相互作用预测和新药发现,推动了生命科学的进步。化学分子图的建模使得GNN在分子性质预测和新药研发方面表现优异,帮助科学家加速材料科学和药物设计的进程。在交通网络中,GNN通过对交通路网的分析,优化了路径选择和交通流量预测,提高了交通系统的效率和安全性。在自然语言处理领域,GNN通过建模句子之间的关系和处理知识图谱,提升了文本分类、问答系统和知识图谱推理的性能。

这些应用案例不仅展示了GNN在不同领域中的广泛适用性和巨大潜力,还体现了GNN在处理复杂图结构数据方面的独特优势。未来,随着研究的深入和技术的发展,图神经网络有望在更多领域产生深远影响,为解决复杂的现实问题提供强有力的工具。通过不断探索和优化GNN模型,将进一步推动各领域的创新和进步。

在这里插入图片描述

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

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

相关文章

【并发编程】JUC并发编程

JUC并发编程 1. 线程基础知识复习2. CompletableFuture2.1 Future接口理论知识复习2.2 Future接口常用实现类FutureTask异步任务2.2.1 Future接口能干什么2.2.2 Future接口相关架构2.2.3 Future编码实战和优缺点分析2.2.4 完成一些复杂的任务 2.3 CompletableFuture对Future的改…

数学建模基础:统计模型

目录 前言 一、概率与统计基础 二、统计模型 三、Matlab统计工具箱 四、实例示范:市场调查分析 步骤 1:数据导入 步骤 2:数据可视化 步骤 3:建立多元线性回归模型 步骤 4:模型验证 步骤 5:模型应…

ArcGIS制作规划图卫星影像地图虚化效果

文章目录 一、效果展示二、加载数据三、效果制作四、注意事项一、效果展示 二、加载数据 订阅专栏后,从csdn私信查收实验数据资料,加载ArcGIS制作规划图卫星影像地图虚化效果.rar中的数据,如下所示: 三、效果制作 1. 创建掩膜图层 新建一个矢量图层,因为主要是作图需要…

深入探讨:UART与USART在单片机中串口的实际应用与实现技巧

单片机(Microcontroller Unit, MCU)是一种集成了处理器、存储器和输入输出接口的微型计算机。它广泛应用于嵌入式系统中,用于控制各类电子设备。UART和USART是单片机中常见的通信接口,负责串行数据传输。下面我们详细介绍它们在单…

Qt底层原理:深入解析QWidget的绘制技术细节(1)

在Qt5中,QWidget的绘制流程比较分散,网上介绍的文章也很少,因此写一篇文章总结记录一下这部分的知识点。 笔者使用的是Qt5.15.2的源码。 基本的绘制流程:从update到合成 更新请求(Invalidate): 当一个QWidg…

001、DM8安装

参照:https://eco.dameng.com/document/dm/zh-cn/pm/install-uninstall.html 1. 准备工作 操作系统查看 [rootora19c ~]# cat /etc/redhat-release CentOS Linux release 7.9.2009 (Core)新建用户 [rootora19c ~]# groupadd dinstall -g 2001 [rootora19c ~]# …

数据分析第十二讲 数据可视化入门(一)

数据可视化入门(一) 在完成了对数据的透视之后,我们可以将数据透视的结果通过可视化的方式呈现出来,简单的说,就是将数据变成漂亮的统计图表,因为人类对颜色和形状会更加敏感,然后再进一步解读…

AXI三板斧之Outstanding、Out-of-order、interleaving

1、AXI三板斧之Outstanding 可以不用等单个命令的响应,直接连续发送N个命令(N>1),假设Slave端的Outstanding能力为N时(N>1),那么Master端可以在Slave不返回读数据的情况下,连…

SARscape——Frost斑点滤波

目录 一、算法原理1、概述2、参考文献 二、软件操作三、结果展示1、原始图像2、滤波结果 一、算法原理 1、概述 2、参考文献 [1] 廉小亲,黄雪,高超,等. 基于Frost滤波和改进CNN的SAR图像TR方法 [J]. 计算机仿真, 2023, 40 (05): 49-55233. [2] SAR图像相干斑滤波算法研究_朱俊…

资深专家教你如何开展新版FMEA培训

新版FMEA的出现,不仅优化了原有的分析流程,更引入了一系列创新的理念和方法,为企业提供了更为全面、细致的风险评估与管理手段。因此,开展新版FMEA培训对于提升企业的质量管理水平、增强产品竞争力具有重要意义。 本文&#xff0…

【昇思25天学习打卡营打卡指南-第一天】基本介绍与快速入门

昇思MindSpore介绍 昇思MindSpore是一个全场景深度学习框架,旨在实现易开发、高效执行、全场景统一部署三大目标。 其中,易开发表现为API友好、调试难度低;高效执行包括计算效率、数据预处理效率和分布式训练效率;全场景则指框架…

【CT】LeetCode手撕—92. 反转链表 II

目录 题目1- 思路2- 实现⭐92. 反转链表 II——题解思路 3- ACM实现 题目 原题连接:92. 反转链表 II 1- 思路 模式识别:翻转 给定 left 和 right 固定区间的链表 ——> ①虚拟头结点 ②三个指针方式实现 2- 实现 ⭐92. 反转链表 II——题解思路 c…

面向对象进阶--抽象(Java 抽象)详解

1.1 抽象类引入 父类中的方法,被它的子类们重写,子类各自的实现都不尽相同。那么父类的方法声明和方法主体,只有声明还有意义,而方法主体则没有存在的意义了(因为子类对象会调用自己重写的方法)。换句话说,父类可能知道…

流媒体学习之路(WebRTC)——音频NackTracker优化思路(8)

流媒体学习之路(WebRTC)——音频NackTracker优化思路(8) —— 我正在的github给大家开发一个用于做实验的项目 —— github.com/qw225967/Bifrost目标:可以让大家熟悉各类Qos能力、带宽估计能力,提供每个环节关键参数调节接口并实…

数据结构——排序(期末总结)

1. 插入排序 1.1 直接插入排序 思想 假设第一个元素是已经排好序的元素&#xff0c;从第二个元素开始依次插入操作&#xff0c;大的放后面&#xff0c;小的放前面。 代码 void insert(int a[], int n) {int i, j, key;for (i 2; i < n; i){key a[i];j i - 1;while (j…

kotlin集合框架

1、集合框架的接口类型对比 2、不可变和可变List fun main() {// 不可变List - 不能删除或添加元素val intList: List<Int> listOf(1,2,3)intList.forEach{println(it) // 1 2 3}println("")// 可变List - 可以删除或添加元素val mutableList mutableListO…

目标检测——YOLOv10算法解读

论文&#xff1a;YOLOv10: Real-Time End-to-End Object Detection (2024.5.23) 作者&#xff1a;Ao Wang, Hui Chen, Lihao Liu, Kai Chen, Zijia Lin, Jungong Han, Guiguang Ding 链接&#xff1a;https://arxiv.org/abs/2405.14458 代码&#xff1a;https://github.com/THU…

C++ | Leetcode C++题解之第165题比较版本号

题目&#xff1a; 题解&#xff1a; class Solution { public:int compareVersion(string version1, string version2) {int n version1.length(), m version2.length();int i 0, j 0;while (i < n || j < m) {long long x 0;for (; i < n && version1[…

【OpenHarmony开发】自定义系统应用之实践

前言 OpenHarmony系统应用是指预装在OpenHarmony操作系统中的应用程序&#xff0c;也称为系统应用。这些应用程序通常由操作系统开发者开发&#xff0c;包括系统设置、电话、短信、浏览器、相机、音乐、视频等常用应用程序。这些应用程序通常具有更高的权限和更深入的系统集成…

机器学习参数寻优:方法、实例与分析

机器学习参数寻优:方法、实例与分析 机器学习模型的性能很大程度上依赖于其参数的选择。参数寻优(Hyperparameter Tuning)是提升模型表现的关键步骤之一。本文将详细介绍主流的参数寻优方法,包括网格搜索(Grid Search)、随机搜索(Random Search)、贝叶斯优化(Bayesia…