支持向量机模型pytorch

通过5个条件判定一件事情是否会发生,5个条件对这件事情是否发生的影响力不同,计算每个条件对这件事情发生的影响力多大,写一个支持向量机模型pytorch程序,最后打印5个条件分别的影响力。

示例一

支持向量机(SVM)是一种监督学习模型,主要用于分类和回归分析问题。在SVM中,影响力或者重要性的概念并不像决策树中的特征重要性那样直接。SVM通过找到能够将不同类别的数据点分隔开的超平面来进行分类,而数据点距离这个超平面的远近(即间隔)决定了分类的置信度。

在SVM中,特征的影响力通常是通过模型的权重来间接体现的,这些权重在训练过程中被优化以最大化间隔。然而,需要注意的是,SVM的权重并不能直接解释为每个特征对最终决策的影响力,因为它们是在高维空间中同时优化得到的。

虽然PyTorch主要用于实现和训练神经网络,但我们仍然可以使用它来构建SVM模型。不过,通常情况下,SVM更倾向于使用像scikit-learn这样的库来实现,因为这些库为SVM提供了专门的优化算法和接口。

不过,如果坚持要使用PyTorch来实现SVM,并尝试从中提取特征的影响力,下面是一个简化的线性SVM实现示例,其中包含了训练完成后打印权重(作为影响力的一种近似)的步骤:

import torch  
import torch.nn as nn  
import torch.optim as optim  
from sklearn.datasets import make_classification  
from sklearn.model_selection import train_test_split  
from sklearn.metrics import accuracy_score  # 假设我们有5个条件(特征)  
num_features = 5  
# 生成一些模拟数据  
X, y = make_classification(n_samples=100, n_features=num_features, n_informative=num_features, n_redundant=0, random_state=42)  
# 将数据转换为PyTorch张量  
X_tensor = torch.tensor(X, dtype=torch.float32)  
y_tensor = torch.tensor(y * 2 - 1, dtype=torch.float32)  # 将标签转换为+1和-1  # 划分训练集和测试集  
X_train, X_test, y_train, y_test = train_test_split(X_tensor, y_tensor, test_size=0.2, random_state=42)  # 定义线性SVM模型  
class LinearSVM(nn.Module):  def __init__(self, input_dim):  super(LinearSVM, self).__init__()  self.linear = nn.Linear(input_dim, 1)  def forward(self, x):  return self.linear(x)  # 实例化模型  
model = LinearSVM(num_features)  # 定义损失函数和优化器  
criterion = nn.HingeEmbeddingLoss()  # 使用合页损失作为SVM的损失函数  
optimizer = optim.SGD(model.parameters(), lr=0.01)  # 训练模型  
num_epochs = 1000  
for epoch in range(num_epochs):  # 前向传播  outputs = model(X_train)  loss = criterion(outputs.squeeze() * y_train, torch.ones_like(y_train))  # 反向传播和优化  optimizer.zero_grad()  loss.backward()  optimizer.step()  if (epoch+1) % 100 == 0:  print(f'Epoch [{epoch+1}/{num_epochs}], Loss: {loss.item()}')  # 使用训练好的模型进行预测  
with torch.no_grad():  y_pred = model(X_test).squeeze()  y_pred_class = (y_pred > 0).float()  accuracy = accuracy_score(y_test.numpy(), y_pred_class.numpy())  print(f'Test Accuracy: {accuracy * 100:.2f}%')  # 打印权重作为条件影响力的近似  
for i, weight in enumerate(model.linear.weight.data.squeeze().numpy()):  print(f"Condition {i+1} influence: {weight}")

在这个例子中,我们使用了HingeEmbeddingLoss作为损失函数,它是SVM中常用的合页损失的一种变体。模型的权重在训练过程中被调整以最小化这个损失。在训练完成后,我们打印了线性层的权重,这些权重可以被解释为每个条件对最终决策的影响力的一种近似。然而,请注意,这种解释是基于线性模型的,且实际影响力可能更加复杂。

示例二

支持向量机(SVM)是一种用于分类、回归和异常值检测的非概率二元线性分类器。在SVM中,模型尝试在高维空间中找到一个超平面,以最大化地将不同类别的样本分隔开。然而,标准的SVM模型并不直接提供特征重要性或影响力的度量。

尽管如此,我们可以通过观察训练后的SVM模型中特征的权重来大致估计每个特征对分类决策的影响力。在线性SVM中,每个特征都有一个对应的权重,这个权重可以被认为是该特征对分类决策的影响力的一种表示。对于非线性SVM(如使用核技巧的SVM),特征的影响力则不那么直接,因为输入空间被映射到了一个更高维的特征空间。

PyTorch没有内置的SVM实现,但我们可以使用其他库,如scikit-learn,来训练一个SVM模型并检查特征的权重。不过,如果坚持要使用PyTorch来构建类似SVM的模型,我们可以实现一个简单的线性SVM,并检查权重以估计特征的影响力。

下面是一个使用PyTorch构建线性SVM并打印特征影响力的示例代码:

import torch  
import torch.nn as nn  
import torch.optim as optim  
from sklearn.datasets import make_classification  
from sklearn.model_selection import train_test_split  
from sklearn.metrics import accuracy_score  # 假设我们有5个条件(特征)  
num_features = 5  # 生成一些模拟数据  
X, y = make_classification(n_samples=100, n_features=num_features, n_informative=num_features, n_redundant=0, random_state=42)  
X = torch.tensor(X.astype(float))  
y = torch.tensor(y.astype(float).reshape(-1, 1))  # Reshape to match PyTorch expectations  # 划分训练集和测试集  
X_train, X_test, y_train, y_test = train_test_split(X, y, test_size=0.2, random_state=42)  # 定义线性SVM模型  
class LinearSVM(nn.Module):  def __init__(self, input_dim):  super(LinearSVM, self).__init__()  self.fc = nn.Linear(input_dim, 1)  def forward(self, x):  return self.fc(x)  # 实例化模型  
model = LinearSVM(num_features)  # 定义损失函数和优化器  
criterion = nn.HingeEmbeddingLoss()  # SVM通常使用合页损失  
optimizer = optim.SGD(model.parameters(), lr=0.01)  # 训练模型  
num_epochs = 1000  
for epoch in range(num_epochs):  # 前向传播  outputs = model(X_train)  loss = criterion(outputs.squeeze(), y_train.squeeze())  # 反向传播和优化  optimizer.zero_grad()  loss.backward()  optimizer.step()  if (epoch+1) % 100 == 0:  print(f'Epoch [{epoch+1}/{num_epochs}], Loss: {loss.item()}')  # 评估模型  
with torch.no_grad():  predictions = (model(X_test).squeeze() > 0).float()  accuracy = accuracy_score(y_test.numpy(), predictions.numpy())  print(f'Test Accuracy: {accuracy}')  # 打印特征的影响力(权重的绝对值)  
for i, weight in enumerate(model.fc.weight.data.numpy().flatten()):  print(f"Condition {i+1} influence: {abs(weight)}")

在这个例子中,我们定义了一个简单的线性模型,它只有一个全连接层,没有激活函数。我们使用合页损失(HingeEmbeddingLoss),它是SVM中常用的损失函数。训练完成后,我们打印出全连接层的权重,作为每个条件对最终决策影响力的估计。

请注意,这个例子中的“影响力”是通过打印权重的绝对值来计算的。权重的符号表示特征对分类决策的方向(正或负),而绝对值可以大致表示特征的重要性。然而,这只是一个简单的估计,并不考虑特征之间的相互作用或模型的非线性(在这个例子中是线性的)。

对于非线性SVM或更复杂的模型,可能需要使用其他方法来估计特征的重要性,例如排列特征重要性或基于模型解释的库,如SHAP(SHapley Additive exPlanations)。


该程序在尝试使用 PyTorch 实现一个简单的线性支持向量机(SVM),并在模拟数据上训练它。PyTorch通常要求所有的计算都在同一种数据类型上执行,通常是Float类型,而这里遇到的错误提示表明是在尝试将Double类型的张量输入到期望Float类型的模型中。
要解决此问题,我们应当确保输入到模型中的所有张量都是Float类型。在代码中,可以通过调用`.float()`方法来实现。具体地,可以在创建`X`和`y`的张量时,将它们转换为Float类型。
以下是修正后的代码:

import torch
import torch.nn as nn
import torch.optim as optim
from sklearn.datasets import make_classification
from sklearn.model_selection import train_test_split
from sklearn.metrics import accuracy_score# 假设我们有5个条件(特征)
num_features = 5# 生成一些模拟数据
X, y = make_classification(n_samples=100, n_features=num_features, n_informative=num_features, n_redundant=0, random_state=42)# 确保X和y是float类型,以兼容PyTorch
X = torch.tensor(X).float() # cast to float
y = torch.tensor(y).float().view(-1, 1) # cast to float and reshape to match PyTorch expectations# 划分训练集和测试集
X_train, X_test, y_train, y_test = train_test_split(X, y, test_size=0.2, random_state=42)# 定义线性SVM模型
class LinearSVM(nn.Module):def __init__(self, input_dim):super(LinearSVM, self).__init__()self.fc = nn.Linear(input_dim, 1)def forward(self, x):return self.fc(x)# 实例化模型
model = LinearSVM(num_features)# 定义损失函数和优化器
criterion = nn.HingeEmbeddingLoss()  # SVM通常使用合页损失
optimizer = optim.SGD(model.parameters(), lr=0.01)# 训练模型
num_epochs = 1000
for epoch in range(num_epochs):# 前向传播outputs = model(X_train)loss = criterion(outputs, y_train)# 反向传播和优化optimizer.zero_grad()loss.backward()optimizer.step()if (epoch+1) % 100 == 0:print(f'Epoch [{epoch+1}/{num_epochs}], Loss: {loss.item()}')# 评估模型
with torch.no_grad():predictions = (model(X_test).squeeze() > 0).float()accuracy = accuracy_score(y_test.numpy(), predictions.numpy())print(f'Test Accuracy: {accuracy}')
# 打印特征的影响力(权重的绝对值)
for i, weight in enumerate(model.fc.weight.data.numpy().flatten()):print(f"Condition {i+1} influence: {abs(weight)}")

注意:在`X = torch.tensor(X).float()`和`y = torch.tensor(y).float().view(-1, 1)`中,移除了对`astype(float)`的调用,因为`.float()`已经确保了张量的类型为float,并且`view()`方法被用于将`y`的形状重新塑造为PyTorch期望的形状,即一个列向量。
这段代码应该能够在不会产生任何类型错误的情况下运行。还可以根据需要调整损失函数(例如在SVM中通常使用合页损失,但可能需要合适的输出转换)和其他超参数。

示例三

支持向量机(SVM)是一种监督学习模型,通常用于分类和回归分析。在SVM中,每个输入特征(本例中的5个条件)对分类边界的位置有影响,但这种影响不是直接通过权重来表示的,而是通过支持向量和核函数来定义的。因此,与神经网络不同,SVM没有直接的“权重”来表示特征的重要性。

然而,线性SVM有一个权重向量,它与输入特征相乘以做出决策。这些权重可以解释为特征对分类决策的影响力。对于非线性SVM,特征的影响力不那么直接,因为它们被映射到一个高维空间,其中非线性决策边界被构造。

在PyTorch中,我们可以使用TorchSVM这样的第三方库来实现SVM,或者使用标准库来实现线性SVM的简化版本。但是,请注意,PyTorch本身并没有提供官方的SVM实现。

为了简化问题,我们可以实现一个线性SVM,并解释其权重作为特征的影响力。这里是一个简单的例子,演示如何使用PyTorch构建一个线性SVM模型,并打印出5个条件的影响力(权重):

import torch  
from torch import nn  
import numpy as np  
from sklearn.model_selection import train_test_split  
from sklearn.datasets import make_classification  
from sklearn.metrics import accuracy_score  # 生成模拟数据  
np.random.seed(42)  
X, y = make_classification(n_samples=100, n_features=5, n_informative=5, n_redundant=0, random_state=42)  
X_tensor = torch.tensor(X.astype(np.float32))  
y_tensor = torch.tensor(y.astype(np.float32)).view(-1, 1)  # 划分训练集和测试集  
X_train, X_test, y_train, y_test = train_test_split(X_tensor, y_tensor, test_size=0.2, random_state=42)  # 将标签转换为±1(SVM标准形式)  
y_train = y_train * 2 - 1  
y_test = y_test * 2 - 1  # 定义线性SVM模型  
class LinearSVM(nn.Module):  def __init__(self, input_dim):  super(LinearSVM, self).__init__()  self.linear = nn.Linear(input_dim, 1)  def forward(self, x):  return self.linear(x)  # 实例化模型  
model = LinearSVM(5)  # 定义损失函数和优化器  
criterion = nn.HingeEmbeddingLoss()  # SVM通常使用合页损失  
optimizer = torch.optim.SGD(model.parameters(), lr=0.01)  # 训练模型  
num_epochs = 1000  
for epoch in range(num_epochs):  # 前向传播  outputs = model(X_train)  loss = criterion(outputs.squeeze() * y_train.squeeze(), torch.ones_like(y_train))  # 反向传播和优化  optimizer.zero_grad()  loss.backward()  optimizer.step()  if (epoch+1) % 100 == 0:  print(f'Epoch [{epoch+1}/{num_epochs}], Loss: {loss.item()}')  # 测试模型  
y_pred = model(X_test).squeeze()  
y_pred_class = (y_pred > 0).float() * 2 - 1  # 将预测值转换为±1  
accuracy = accuracy_score(y_test.numpy(), y_pred_class.detach().numpy())  
print(f'Test Accuracy: {accuracy}')  # 打印特征的影响力(权重)  
for i, weight in enumerate(model.linear.weight.data.squeeze().numpy()):  print(f"Condition {i+1} influence: {weight}")

在这个例子中,我们创建了一个简单的线性SVM模型,使用了HingeEmbeddingLoss作为损失函数,它试图将正例和负例分隔开,并最大化间隔。模型训练完成后,我们打印出线性层的权重,这些权重可以被解释为每个条件对最终分类决策的影响力。

请注意,这个例子是一个简化的线性SVM实现,并不适用于所有情况,特别是当数据不是线性可分的时候。对于非线性问题,可能需要使用核方法或其他非线性SVM的实现。但是,这些实现通常不会直接提供特征的“影响力”度量,因为决策边界在高维空间中变得更加复杂。

示例四

支持向量机(SVM)是一种监督学习模型,通常用于分类和回归分析。在SVM中,每个输入特征对模型决策边界的影响是通过特征在训练过程中的权重来体现的。然而,标准的SVM模型并不直接提供每个特征对最终预测结果的直接影响力度量。尽管如此,我们可以通过查看训练后的SVM模型中特征的系数来近似估计它们的重要性。

请注意,PyTorch本身并没有提供SVM模型的直接实现,因为SVM通常不是通过梯度下降和反向传播来训练的,而是使用二次规划来解决的。不过,我们可以使用scikit-learn中的SVC(支持向量分类)来实现SVM,并分析特征的重要性。

但是,如果坚持要使用PyTorch风格的代码,我们可以使用PyTorch的自动梯度功能和优化器来近似实现一个线性SVM。以下是一个简化的线性SVM实现,用于二分类问题,并在训练后打印出每个条件(特征)的影响力:

import torch  
import torch.nn as nn  
import torch.optim as optim  
from sklearn.datasets import make_classification  
from sklearn.model_selection import train_test_split  
from sklearn.metrics import accuracy_score  # 确保结果可复现  
torch.manual_seed(42)  # 生成模拟数据  
num_conditions = 5  
X, y = make_classification(n_samples=100, n_features=num_conditions, n_informative=num_conditions, n_redundant=0, random_state=42)  
X_train, X_test, y_train, y_test = train_test_split(X, y, test_size=0.2, random_state=42)  # 转换为PyTorch张量  
X_train_tensor = torch.tensor(X_train, dtype=torch.float32)  
y_train_tensor = torch.tensor(y_train, dtype=torch.float32).view(-1, 1)  
X_test_tensor = torch.tensor(X_test, dtype=torch.float32)  
y_test_tensor = torch.tensor(y_test, dtype=torch.float32).view(-1, 1)  # 线性SVM模型(没有偏置项)  
class LinearSVM(nn.Module):  def __init__(self, input_dim):  super(LinearSVM, self).__init__()  self.linear = nn.Linear(input_dim, 1, bias=False)  # 偏置项设置为False  def forward(self, x):  return self.linear(x)  # 实例化模型  
model = LinearSVM(num_conditions)  # 定义优化器和损失函数  
optimizer = optim.SGD(model.parameters(), lr=0.01)  
criterion = nn.HingeEmbeddingLoss()  # 使用合页损失作为SVM的损失函数  # 训练模型  
num_epochs = 1000  
for epoch in range(num_epochs):  optimizer.zero_grad()  outputs = model(X_train_tensor)  loss = criterion(outputs.squeeze(), y_train_tensor.squeeze())  loss.backward()  optimizer.step()  if (epoch + 1) % 100 == 0:  print(f'Epoch [{epoch + 1}/{num_epochs}], Loss: {loss.item()}')  # 测试模型  
with torch.no_grad():  y_pred = model(X_test_tensor).squeeze()  y_pred_class = (y_pred > 0).float()  # 根据输出的正负性判断类别  accuracy = accuracy_score(y_test, y_pred_class.numpy())  print(f'Test Accuracy: {accuracy}')  # 打印每个条件的影响力(基于训练后的权重)  
for i, weight in enumerate(model.linear.weight.data.squeeze().numpy()):  print(f"Condition {i + 1} influence: {weight}")

在这个例子中,我们实现了一个简单的线性SVM模型,使用合页损失(Hinge Loss)作为损失函数,并通过随机梯度下降(SGD)进行优化。训练完成后,我们打印出线性层中的权重,这些权重可以被解释为每个条件对最终决策的影响力。请注意,这个实现是为了教学目的而简化的,并没有包括所有SVM可能的功能和优化。

此外,由于PyTorch本身不是为SVM设计的,这个实现可能不是最高效或最准确的。在实际应用中,推荐使用专门为SVM设计的库,如scikit-learn中的SVC。

示例五

在支持向量机(Support Vector Machine, SVM)模型中,特征的影响力通常不是直接通过模型的参数来衡量的,因为SVM的决策边界仅由支持向量决定,而这些支持向量是数据集中的一部分样本,不一定是每个特征都具有代表性的。然而,我们可以通过查看训练好的SVM模型中每个特征在决策函数中的权重来近似估计每个条件的影响力。

不过,值得注意的是,PyTorch本身并没有提供SVM的原生实现,因为SVM通常通过求解二次规划问题来训练,而这与神经网络的前向传播和反向传播机制不同。尽管如此,我们可以使用第三方库(如scikit-learn)来训练SVM,并获取特征权重。如果坚持要在PyTorch环境中实现,我们可以自己编写SVM的训练逻辑,但这通常比较复杂且不是PyTorch的典型用法。

由于想要用PyTorch实现SVM,我会给出一个简化的SVM实现示例,但这主要是为了教学目的,实际应用中建议使用成熟的库(如scikit-learn)。

下面是一个简化的线性SVM的PyTorch实现,它计算了每个特征对决策边界的影响力:

import torch  
import torch.nn as nn  
import torch.optim as optim  # 假设数据维度和标签  
num_samples = 100  
num_conditions = 5  # 随机生成数据  
X = torch.randn(num_samples, num_conditions)  
y = torch.randint(low=0, high=2, size=(num_samples, 1)) * 2 - 1  # 生成+1和-1的标签  # 线性SVM模型  
class LinearSVM(nn.Module):  def __init__(self, input_dim):  super(LinearSVM, self).__init__()  self.linear = nn.Linear(input_dim, 1)  def forward(self, x):  return self.linear(x)  # 初始化模型  
model = LinearSVM(num_conditions)  # 定义损失函数和优化器  
def hinge_loss(output, target):  return torch.mean(torch.max(torch.zeros_like(output), 1 - target * output))  optimizer = optim.SGD(model.parameters(), lr=0.01)  # 训练模型  
num_epochs = 1000  
for epoch in range(num_epochs):  optimizer.zero_grad()  output = model(X)  loss = hinge_loss(output, y)  loss.backward()  optimizer.step()  if (epoch + 1) % 100 == 0:  print(f'Epoch [{epoch + 1}/{num_epochs}], Loss: {loss.item()}')  # 打印权重作为影响力  
for i, weight in enumerate(model.linear.weight.data.squeeze()):  print(f"Condition {i + 1} influence: {weight.item()}")

在这个例子中,我们定义了一个简单的线性SVM模型,它只有一个线性层。我们使用随机生成的数据进行训练,并使用hinge loss作为损失函数。训练完成后,我们打印出线性层的权重,这些权重可以被解释为每个条件对决策边界的影响力。

请注意,这个例子是为了教学目的而简化的,并且可能无法在实际问题中达到最佳性能。在实际应用中,建议使用成熟的机器学习库(如scikit-learn)来训练SVM模型,并获取特征的重要性。在scikit-learn中,可以使用coef_属性来获取线性SVM的特征权重。

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

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

相关文章

postgis导入shp数据时“dbf file (.dbf) can not be opened.“

作者进行矢量数据导入数据库中出现上述报错 导致报错原因 导入的shp文件路径太深导入的shp文件名称或路径中有中文将需要导入数据的shp 文件、dbf 文件、prj 等文件放在到同一个文件夹内,且名字要一致;导入失败: 导入成功:

近屿智能独家研发出专用于AIGC工程师的学习路径图

近期,关于“人工智能将取代大量人类工作”的讨论愈发热烈。在CCTV-13的《两会你我他》访谈节目中,专家们深入探讨了这一议题。他们普遍认为,AI技术本身不会直接取代人类的工作,而是那些掌握了AI技术的人可能会在职场上占据优势。这…

算法题解记录11+++从前序与中序遍历序列构造二叉树(百日筑基)

题目描述: 给定两个整数数组 preorder 和 inorder ,其中 preorder 是二叉树的先序遍历, inorder 是同一棵树的中序遍历,请构造二叉树并返回其根节点。 示例 1: 输入: preorder [3,9,20,15,7], inorder [9,3,15,20,7] 输出: [3,…

SpringBoot集成Skywalking日志收集

在实际项目中,为了方便线上排查问题,尤其是微服务之间调用链路比较复杂的系统中,通过可视化日志的手段仍然是最直接也很方便的排查定位问题的手段,比如大家熟悉的ELK就是一种比较成熟的可视化日志展现方式,在skywalkin…

mysql performance schema 实践

参考MySQL调优性能监控之performance schema,做了一些扩展 1 2、哪类SQL的平均响应时间最多 SUM_NO_INDEX_USED>0用来过滤那些没有使用的查询。 SELECT SCHEMA_NAME,DIGEST_TEXT,AVG_TIMER_WAIT,MAX_TIMER_WAIT,SUM_LOCK_TIME,SUM_ERRORS ,SUM_SELECT_FULL_JOIN,SUM_NO_IND…

基于SSM强国有我党建网站

摘要 国家的繁荣富强与每一个人都息息相关密不可分并且关系密切,无论是从事最底层的工作的城市清洁工、工地上的民工、街边自己售卖自制商品进行生活的小商小贩;还是有一定的经济地位可以在电视中,采访中,各类访谈节目以及广大影…

【ARM 裸机】汇编 led 驱动之编译程序

编译程序这一节分为四个步骤: 1、将 .s .c 文件变成 .o 文件,使用 arm-linux-gnueabihf-gcc; arm-linux-gnueabihf-gcc -g -c leds.s -o led.o上述命令就是将 leds.s 编译为 led.o,其中“ -g ”选项是产生调试信息,G…

《系统分析与设计》实验-----需求规格说明书 哈尔滨理工大学

文章目录 需求规格说明书1.引言1.1编写目的1.2项目背景1.3定义1.4参考资料 2.任务概述2.1目标2.2运行环境2.3条件与限制 3.数据描述3.1静态数据3.2动态数据3.3数据库介绍3.4数据词典3.5数据采集 4.功能需求4.1功能划分4.2功能描述…

「51媒体网」汽车类媒体有哪些?车展媒体宣传

传媒如春雨,润物细无声,大家好,我是51媒体网胡老师。 汽车类媒体有很多,具体如下: 汽车之家:提供全面的汽车新闻、评测、导购等内容。 爱卡汽车:同样是一个综合性的汽车信息平台,涵…

2路音频解码器JR-AD201

音频解码器 详细介绍 JR-AD201 2路音频解码器,支持RF/ASI/IP输入,支持DRA/AC3/EAC3/AAC/MPEG等音频,输出:2路模拟立体声,2路AES/EBU。 产品特点 支持多种输入方式RF/IP/ASI 接口丰富,AES/EBU/模拟立体声/A…

【C语言基础】:编译和链接(计算机中的翻译官)

文章目录 一、翻译环境和运行环境1. 翻译环境1.1 编译1.1.1 预处理1.1.2 编译1.1.3 汇编 1.2 链接 2. 运行环境 一、翻译环境和运行环境 我们在Visual Studio上写的C语言代码其实都是一些文本信息,计算机是不能够直接执行他们的,计算机只能够执行二进制…

【位运算】Leetcode 两整数之和

题目解析 371. 两整数之和 算法讲解 异或的本质就是无进位相加,但是我们需要处理进位,就需要知道哪一位上有进位,再让无进位相加的结果 进位即可,在重复这个过程,当进位等于0的时候,说明相加的过程已经结…