基于Python的药物相互作用预测模型AI构建与优化(下.代码部分)
四、特征工程
4.1 分子描述符计算
分子描述符作为量化分子性质的关键数值,能够从多维度反映药物分子的结构和化学特征,在药物相互作用预测中起着举足轻重的作用。RDKit 库凭借其强大的功能,为我们提供了丰富的分子描述符计算方法,涵盖了多个重要方面的分子性质。
分子量(Molecular Weight)是最基本的分子描述符之一,它反映了分子的质量大小,对药物的药代动力学性质有着不可忽视的影响。在药物研发和临床应用中,分子量是评估药物吸收、分布、代谢和排泄过程的重要参考指标。例如,一般来说,分子量较小的药物更容易通过生物膜,从而提高其生物利用度。在 RDKit 中,计算分子量的方法简洁高效,通过Descriptors.MolWt(mol)函数,即可准确地计算出分子的分子量。以阿司匹林(SMILES 字符串为为例,首先使用Chem.MolFromSmiles函数将 SMILES 字符串转换为分子对象mol,然后调用Descriptors.MolWt(mol)函数,就能得到阿司匹林的分子量。具体代码如下:
from rdkit import Chemfrom rdkit.Chem import Descriptorssmiles = "CC(=O)OC1=CC=CC=C1C(=O)O"mol = Chem.MolFromSmiles(smiles)molecular_weight = Descriptors.MolWt(mol)print(f"阿司匹林的分子量: {molecular_weight}")
运行上述代码,即可得到阿司匹林的分子量,这一数值为后续分析阿司匹林在体内的药代动力学过程提供了基础数据。
拓扑极性表面积(Topological Polar Surface Area, TPSA)是衡量分子极性的重要指标,它与药物分子的水溶性、膜通透性等密切相关。药物分子的水溶性和膜通透性是影响其药效的关键因素,水溶性好的药物更容易在体内溶解和运输,而膜通透性高的药物则更容易进入细胞内发挥作用。TPSA 能够准确地反映分子中极性部分的表面积,从而为评估药物分子的这些性质提供依据。在 RDKit 中,使用Descriptors.TPSA(mol)函数可以方便地计算分子的 TPSA。对于上述阿司匹林分子,计算其 TPSA 的代码如下:
tpsa = Descriptors.TPSA(mol)print(f"阿司匹林的拓扑极性表面积: {tpsa}")
通过计算得到的 TPSA 值,我们可以初步判断阿司匹林的水溶性和膜通透性情况,为药物相互作用预测提供重要的特征信息。
脂溶性(LogP)也是一个重要的分子描述符,它反映了药物分子在油相和水相中的分配系数,对药物的吸收、分布和代谢过程有着重要影响。脂溶性适中的药物更容易通过生物膜,进入体内发挥作用,但如果脂溶性过高,药物可能会在脂肪组织中蓄积,导致不良反应的发生。在 RDKit 中,使用Descriptors.MolLogP(mol)函数可以计算分子的 LogP 值。对于阿司匹林分子,计算其 LogP 的代码如下:
logp = Descriptors.MolLogP(mol) print(f"阿司匹林的脂溶性(LogP): {logp}") |
通过计算得到的 LogP 值,我们可以了解阿司匹林在体内的分布情况,进一步分析其与其他药物发生相互作用的可能性。
氢键供体 / 受体数(HBD、HBA)是描述分子形成氢键能力的重要指标,氢键在药物与靶点的相互作用中起着关键作用。药物分子与靶点之间通过氢键相互作用,可以改变靶点的活性,从而影响药物的疗效。在 RDKit 中,使用Descriptors.NumHDonors(mol)函数可以计算分子的氢键供体数,使用Descriptors.NumHAcceptors(mol)函数可以计算分子的氢键受体数。对于阿司匹林分子,计算其氢键供体数和氢键受体数的代码如下:
hbd = Descriptors.NumHDonors(mol) hba = Descriptors.NumHAcceptors(mol) print(f"阿司匹林的氢键供体数: {hbd}") print(f"阿司匹林的氢键受体数: {hba}") |
通过计算得到的氢键供体数和氢键受体数,我们可以分析阿司匹林与其他药物或靶点之间形成氢键的可能性,为药物相互作用预测提供重要的特征信息。
这些分子描述符从不同维度刻画了药物分子的化学性质,综合起来能够全面地描述药物分子的特征。在药物相互作用预测模型中,将这些分子描述符作为输入特征,能够帮助模型更好地学习药物分子之间的相互作用模式,提高模型的预测准确性。
4.2 分子指纹生成
分子指纹作为一种将分子结构信息压缩成固定长度二进制向量的强大工具,能够高效地捕捉药物分子的结构特征,在药物相互作用预测中发挥着关键作用。其中,Morgan 指纹是一种应用广泛的分子指纹,它通过独特的算法,能够有效地编码分子结构的局部环境信息,为药物相互作用预测模型提供重要的输入特征。
在 Python 中,利用 RDKit 库可以方便地生成 Morgan 指纹。RDKit 库提供了丰富的函数和工具,使得分子指纹的生成过程变得简洁而高效。以生成半径为 2、位数为 2048 的 Morgan 指纹为例,首先需要将药物分子的 SMILES 字符串转换为 RDKit 中的分子对象mol,这一步可以通过Chem.MolFromSmiles函数实现。然后,使用AllChem.GetMorganFingerprintAsBitVect函数生成分子的 Morgan 指纹。具体代码如下:
from rdkit import Chem from rdkit.Chem import AllChem smiles = "CC(=O)OC1=CC=CC=C1C(=O)O" # 阿司匹林的SMILES字符串 mol = Chem.MolFromSmiles(smiles) fp = AllChem.GetMorganFingerprintAsBitVect(mol, radius=2, nBits=2048) |
在上述代码中,radius=2表示指纹计算时考虑的原子邻域半径,半径越大,指纹包含的分子结构信息越丰富,但计算量也会相应增加。nBits=2048表示生成的指纹向量的长度为 2048 位,较长的指纹向量能够更细致地描述分子结构,但也可能会增加数据的维度和模型训练的复杂度。通过调整这两个参数,可以根据实际需求和数据特点,生成最适合药物相互作用预测的分子指纹。
生成的 Morgan 指纹是一个固定长度的二进制向量,其中的每一位都代表了分子结构中的某种特征。这些特征可能是分子中的特定原子组合、化学键类型或局部结构模式等。通过将药物分子转换为 Morgan 指纹,我们可以将复杂的分子结构信息转化为易于计算机处理的数字特征,从而方便后续的模型训练和分析。在药物相互作用预测模型中,将 Morgan 指纹作为输入特征,可以帮助模型更好地识别具有相似相互作用模式的药物分子,提高模型的预测准确性。例如,在训练过程中,模型可以学习到不同药物分子的 Morgan 指纹与药物相互作用之间的关联,从而在遇到新的药物分子时,能够根据其 Morgan 指纹预测它与其他药物发生相互作用的可能性。
4.3 药物对特征构建
在药物相互作用预测中,仅考虑单个药物的特征是不够的,因为药物相互作用本质上是两个药物之间的相互关系。因此,构建药物对的特征对于准确预测药物相互作用至关重要。我们通过结合两个药物的特征,并进行差值、乘积等操作,能够挖掘出药物对之间的相互作用特征,为模型提供更丰富的信息。
以分子描述符为例,我们可以计算两个药物分子描述符的差值和乘积。假设药物 A 的分子量为mol_weight_A,药物 B 的分子量为mol_weight_B,则分子量差值diff_mol_weight可以通过diff_mol_weight = mol_weight_A - mol_weight_B计算得到。分子量差值能够反映两个药物在质量大小上的差异,这种差异可能与药物的药代动力学过程相关,从而影响它们之间的相互作用。例如,分子量差异较大的两个药物在体内的吸收、分布和代谢过程可能存在较大差异,这可能导致它们之间发生相互作用的可能性增加或减少。分子量乘积prod_mol_weight可以通过prod_mol_weight = mol_weight_A * mol_weight_B计算得到。分子量乘积从另一个角度反映了两个药物的特征组合,它可能与药物的某些协同作用或拮抗作用相关。在某些情况下,两个药物的分子量乘积可能与它们联合使用时的疗效或不良反应存在关联。
对于拓扑极性表面积(TPSA),同样可以计算差值和乘积。假设药物 A 的 TPSA 为tpsa_A,药物 B 的 TPSA 为tpsa_B,则 TPSA 差值diff_tpsa为diff_tpsa = tpsa_A - tpsa_B,TPSA 乘积prod_tpsa为prod_tpsa = tpsa_A * tpsa_B。TPSA 差值和乘积能够反映两个药物在极性和水溶性方面的差异和组合,这些性质对于药物在体内的跨膜转运和相互作用具有重要影响。例如,TPSA 差值较大的两个药物在细胞膜通透性上可能存在差异,这可能导致它们在细胞内的浓度分布不同,进而影响它们之间的相互作用。
在 Python 中,我们可以使用以下代码实现药物对特征的构建。假设drug_data是包含药物数据的 DataFrame,其中mol_weight列表示分子量,tpsa列表示拓扑极性表面积:
import pandas as pd# 假设drug_data是包含药物数据的DataFramedrug_data = pd.read_csv('drug_data.csv')# 假设数据集中已经计算好了每个药物的分子描述符,现在将数据转换为药物对的形式drug_pairs = []for i in range(len(drug_data)): for j in range(i + 1, len(drug_data)): drug_a = drug_data.iloc[i] drug_b = drug_data.iloc[j] pair = { 'drug_a_id': drug_a['drug_id'], 'drug_b_id': drug_b['drug_id'], 'mol_weight_a': drug_a['mol_weight'], 'mol_weight_b': drug_b['mol_weight'], 'tpsa_a': drug_a['tpsa'], 'tpsa_b': drug_b['tpsa'] } drug_pairs.append(pair)drug_pair_df = pd.DataFrame(drug_pairs)# 计算药物对的特征drug_pair_df['diff_mol_weight'] = drug_pair_df['mol_weight_a'] - drug_pair_df['mol_weight_b']drug_pair_df['prod_mol_weight'] = drug_pair_df['mol_weight_a'] * drug_pair_df['mol_weight_b']drug_pair_df['diff_tpsa'] = drug_pair_df['tpsa_a'] - drug_pair_df['tpsa_b']drug_pair_df['prod_tpsa'] = drug_pair_df['tpsa_a'] * drug_pair_df['tpsa_b']# 打印结果print(drug_pair_df.head())
上述代码首先将药物数据转换为药物对的形式,然后计算每个药物对的分子量差值、分子量乘积、TPSA 差值和 TPSA 乘积。通过这些计算,我们得到了一系列能够反映药物对之间相互作用特征的新特征,这些特征可以作为药物相互作用预测模型的输入,帮助模型更好地学习药物对之间的相互作用模式,提高预测的准确性。
4.4 特征选择与降维
在药物相互作用预测模型中,经过前面的步骤我们得到了大量的特征,然而并非所有特征都对预测任务具有同等的重要性。一些特征可能是冗余的,它们提供的信息已经包含在其他特征中;还有一些特征可能与药物相互作用的相关性较低,对模型的预测性能贡献不大。过多的特征不仅会增加模型的训练时间和计算成本,还可能导致过拟合问题,使模型在测试集上的表现不佳。因此,进行特征选择与降维是非常必要的,它能够去除冗余和无关特征,保留对预测任务最有价值的特征,从而提高模型的性能和泛化能力。
方差分析(Analysis of Variance,ANOVA)是一种常用的特征选择方法,它通过比较不同类别下特征的均值差异来判断特征的重要性。在药物相互作用预测中,我们可以将药物是否发生相互作用作为类别,计算每个特征在不同类别下的均值。如果某个特征在发生相互作用和不发生相互作用的药物对之间的均值差异显著,那么这个特征很可能对药物相互作用的预测具有重要意义。例如,对于药物的某种分子描述符,如果在发生相互作用的药物对中,该描述符的均值明显高于或低于不发生相互作用的药物对,说明这个描述符与药物相互作用存在关联。在 Python 中,使用scikit-learn库的f_classif函数可以方便地进行方差分析。假设X是特征矩阵,y是标签向量,代码如下:
from sklearn.feature_selection import f_classif # 计算每个特征的F值和p值 f_values, p_values = f_classif(X, y) |
上述代码中,f_classif函数返回每个特征的 F 值和 p 值,F 值越大,说明该特征在不同类别下的均值差异越显著,p 值越小,说明该特征越显著。我们可以根据 F 值或 p 值对特征进行排序,选择 F 值较大或 p 值较小的特征作为重要特征。
相关性分析也是一种常用的特征选择方法,它用于衡量两个变量之间的线性相关程度。在药物相互作用预测中,我们可以计算每个特征与药物相互作用标签之间的相关性,以及特征之间的相关性。对于与药物相互作用标签相关性较低的特征,它们对预测任务的贡献可能较小,可以考虑去除;对于相互之间相关性较高的特征,它们可能存在冗余信息,我们可以选择其中一个代表性的特征,去除其他相关性高的特征。在 Python 中,使用pandas库的corr函数可以计算特征之间的相关性矩阵。假设data是包含特征和标签的 DataFrame,代码如下:
import pandas as pd # 计算相关性矩阵 corr_matrix = data.corr() |
通过计算得到的相关性矩阵,我们可以直观地看到各个特征之间以及特征与标签之间的相关性。例如,如果某个特征与标签的相关性系数接近 0,说明该特征与药物相互作用的相关性较低;如果两个特征之间的相关性系数接近 1 或 - 1,说明这两个特征之间存在较强的线性相关关系,可能存在冗余。
主成分分析(Principal Component Analysis,PCA)是一种常用的降维方法,它通过线性变换将原始特征转换为一组新的正交特征,即主成分。这些主成分按照方差从大到小排列,方差越大表示该主成分包含的信息越多。在药物相互作用预测中,我们可以使用 PCA 将高维的特征空间转换为低维的主成分空间,从而降低特征的维度。在 Python 中,使用scikit-learn库的PCA类可以方便地实现主成分分析。假设X是特征矩阵,我们希望将特征维度降低到n_components维,代码如下:
from sklearn.decomposition import PCA # 创建PCA对象,设置目标维度为n_components pca = PCA(n_components=n_components) # 对特征矩阵进行PCA降维 X_reduced = pca.fit_transform(X) |
上述代码中,PCA类的n_components参数指定了降维后的目标维度。通过fit_transform方法,我们可以将原始特征矩阵X转换为降维后的特征矩阵X_reduced。在选择n_components时,我们可以根据解释方差比来确定,解释方差比表示每个主成分所包含的方差占总方差的比例。通常,我们选择使得累计解释方差比达到一定阈值(如 0.95)的主成分数量作为n_components的值,这样可以在保留大部分信息的同时,有效地降低特征维度。
五、模型构建与训练
5.1 传统机器学习模型
5.1.1 逻辑回归模型
逻辑回归是一种广泛应用于分类问题的线性模型,虽然其名称中包含 “回归”,但实际上它是一种分类算法,在药物相互作用预测中具有重要的应用价值。
逻辑回归的基本原理基于线性回归模型,通过引入 sigmoid 函数将线性回归的输出映射到 (0, 1) 区间,从而实现对样本的分类预测。假设我们有一个二分类问题,样本的特征向量为,模型的参数向量为
,则线性回归的输出为
。然后,通过 sigmoid 函数
将z映射到 (0, 1) 区间,得到样本属于正类(在药物相互作用预测中,可表示为药物之间存在相互作用)的概率
相关文章:
基于Python的药物相互作用预测模型AI构建与优化(下.代码部分)
四、特征工程 4.1 分子描述符计算 分子描述符作为量化分子性质的关键数值,能够从多维度反映药物分子的结构和化学特征,在药物相互作用预测中起着举足轻重的作用。RDKit 库凭借其强大的功能,为我们提供了丰富的分子描述符计算方法,涵盖了多个重要方面的分子性质。 分子量…...
【C语言】内存管理
【C语言】内存管理 文章目录 【C语言】内存管理1.概念2.库函数3.动态分配内存malloccalloc 4.重新调整内存的大小和释放内存reallocfree 1.概念 C 语言为内存的分配和管理提供了几个函数。这些函数可以在 <stdlib.h> 头文件中找到。 在 C 语言中,内存是通过…...
团体程序设计天梯赛-练习集——L1-029 是不是太胖了
前言 5分级别里面目前做到的最难的一道题,但是非常简单,5分的题看看写点代码就行了。 L1-029 是不是太胖了 据说一个人的标准体重应该是其身高(单位:厘米)减去100、再乘以0.9所得到的公斤数。已知市斤的数值是公斤数…...
appmatrix平台(一个汇集原创web APP的平台)服务规划
Appmatrix平台(一个汇集原创web APP的平台)服务规划 Web app是部署机器学习、深度学习等需要算力较大的应用的主要形式,一般都是独立、散在部署,对使用和相互交流造成了一定的不便。App Matrix将各类web应用汇集在一起࿰…...
vscode+WSL2(ubuntu22.04)+pytorch+conda+cuda+cudnn安装系列
最近在家过年闲的没事,于是研究起深度学习开发工具链的配置和安装,之前欲与天公试比高,尝试在win上用vscodecuda11.6vs2019的cl编译器搭建cuda c编程环境,最后惨败,沦为笑柄,痛定思痛,这次直接和…...
pytorch实现长短期记忆网络 (LSTM)
人工智能例子汇总:AI常见的算法和例子-CSDN博客 LSTM 通过 记忆单元(cell) 和 三个门控机制(遗忘门、输入门、输出门)来控制信息流: 记忆单元(Cell State) 负责存储长期信息&…...
洛谷P2651 添加括号III
题目链接:P2651 添加括号III - 洛谷 | 计算机科学教育新生态 题目难度:普及一 题目分析: a1肯定是分子,a2肯定是分母,那么尽可能多的是a3以后的变为分子,怎么办呢? a1/(a2/a3/a4/...)a1a3a4.../a2&#…...
Mysql进阶学习
目录 一.Mysql服务器内部架构(了解) 二.Mysql引擎 2.1 innodb引擎 2.2 myisam引擎 三.索引 3.1索引分类 3.2mysql索引数据结构 3.3聚簇索引和非聚簇索引 3.4回表查询 3.5索引下推 四.事务 数据库事务特征 事务隔离性,隔离级别 事务实现原理 五.锁 ①…...
白话DeepSeek-R1论文(二)| DeepSeek-R1:AI “升级打怪”,从“自学成才”到“全面发展”!
最近有不少朋友来询问Deepseek的核心技术,今天开始陆续针对DeepSeek-R1论文中的核心内容进行解读,并且用大家都能听懂的方式来解读。这是第二篇趣味解读。 DeepSeek-R1:AI “升级打怪”,从“自学成才”到“全面发展”!…...
WordPress eventon-lite插件存在未授权信息泄露漏洞(CVE-2024-0235)
免责声明: 本文旨在提供有关特定漏洞的深入信息,帮助用户充分了解潜在的安全风险。发布此信息的目的在于提升网络安全意识和推动技术进步,未经授权访问系统、网络或应用程序,可能会导致法律责任或严重后果。因此,作者不对读者基于本文内容所采取的任何行为承担责任。读者在…...
python 语音识别
目录 一、语音识别 二、代码实践 2.1 使用vosk三方库 2.2 使用SpeechRecognition 2.3 使用Whisper 一、语音识别 今天识别了别人做的这个app,觉得虽然是个日记app 但是用来学英语也挺好的,能进行语音识别,然后矫正语法,自己说的时候 ,实在不知道怎么说可以先乱说,然…...
2501,编写dll
DLL的优点 简单的说,dll有以下几个优点: 1)节省内存.同一个软件模块,若是源码重用,则会在不同可执行程序中编译,同时运行这些exe时,会在内存中重复加载这些模块的二进制码. 如果使用dll,则只在内存中加载一次,所有使用该dll的进程会共享此块内存(当然,每个进程会复制一份的d…...
Linux命令汇总
1、帮忙类 --help 直接在当前窗口显示帮助 command --help man 创建新窗口显示帮助 man command 2、目录操作类 2.1、查看目录 ls:以列表方式,查看目录中内容 tree:以树状方式,查看目录中内容 2.2、创建、删除文件及目录 touch:创建…...
漏洞扫描工具之xray
下载地址:https://github.com/chaitin/xray/releases 1.9.11 使用文档:https://docs.xray.cool/tools/xray/Scanning 与burpsuite联动: https://xz.aliyun.com/news/7563 参考:https://blog.csdn.net/lza20001103/article/details…...
Java手写简单Merkle树
Java手写Merkle树代码 package com.blockchain.qgy.component;import com.blockchain.qgy.model.MerkleTreeNode; import com.blockchain.qgy.util.SHAUtil;import java.util.*;public class MerkleTree<T> {//merkle树private List<MerkleTreeNode<T>> lis…...
vue之pinia组件的使用
1、搭建pinia环境 cnpm i pinia #安装pinia的组件 cnpm i nanoid #唯一id,相当于uuid cnpm install axios #网络请求组件 2、存储读取数据 存储数据 >> Count.ts文件import {defineStore} from piniaexport const useCountStore defineStore(count,{// a…...
升级到Mac15.1后pod install报错
升级Mac后,Flutter项目里的ios项目运行 pod install报错, 遇到这种问题,不要着急去百度,大概看一下报错信息,每个人遇到的问题都不一样。 别人的解决方法并不一定适合你; 下面是报错信息: #…...
力扣【1049. 最后一块石头的重量 II】Java题解(背包问题)
让石头分成重量相同的两堆(尽可能相同),相撞之后剩下的石头就是最小的。进一步转化成容量为重量总喝一半的背包最多可以装多少质量的石头。这样就转化成了背包问题。 最后求结果时,我们所最多能装的时dp[target],那另一…...
CSS 图像、媒体和表单元素的样式化指南
CSS 图像、媒体和表单元素的样式化指南 1. 替换元素:图像和视频1.1 调整图像大小示例代码:调整图像大小 1.2 使用 object-fit 控制图像显示示例代码:使用 object-fit 2. 布局中的替换元素示例代码:Grid 布局中的图像 3. 表单元素的…...
寒武纪MLU370部署deepseek r1
文章目录 前言一、平台环境准备二、模型下载三、环境安装四、代码修改五、运行效果 前言 DeepSeek-R1拥有卓越的性能,在数学、代码和推理任务上可与OpenAI o1媲美。其采用的大规模强化学习技术,仅需少量标注数据即可显著提升模型性能,为大模…...
Spring的AOP的JoinPoint和ProceedingJoinPoint
Spring的AOP的JoinPoint 在Spring AOP中,JoinPoint 是一个核心接口,用于表示程序执行过程中的一个连接点(如方法调用或异常抛出)。它提供了访问当前被拦截方法的关键信息的能力。以下是关于 JoinPoint 的详细说明: 一…...
每日一道算法题
题目:单词接龙 II 给定两个单词(beginWord 和 endWord)和一个字典 wordList,找出所有从 beginWord 到 endWord 的最短转换序列。转换需遵循如下规则: 每次转换只能改变一个字母。转换过程中的中间单词必须是字典中的…...
Node.js——body-parser、防盗链、路由模块化、express-generator应用生成器
个人简介 👀个人主页: 前端杂货铺 🙋♂️学习方向: 主攻前端方向,正逐渐往全干发展 📃个人状态: 研发工程师,现效力于中国工业软件事业 🚀人生格言: 积跬步…...
Java小白入门教程:两大类型的修饰符以及示例
目录 一、访问控制修饰符 1、default 就是啥都不写的那种 2、private 私有 3、public 公开 4、protected 受保护的 二、非访问控制修饰符 1、static 静态 2、final 最终 3、abstract 抽象 4、synchronized 锁 5、transient 瞬态 6、volatile 易变 一、访问控制修饰符…...
正则表达式入门
入门 1、提取文章中所有的英文单词 //1.先创建一个Pattern对象,模式对象,可以理解成就是一个正则表达式对象 Pattern pattern Pattern.compile("[a-zA-Z]"); //2.创建一个匹配器对象 //理解:就是 matcher匹配器按照p…...
云原生(五十二) | DataGrip软件使用
文章目录 DataGrip软件使用 一、DataGrip基本使用 二、软件界面介绍 三、附件文件夹到项目中 四、DataGrip设置 五、SQL执行快捷键 DataGrip软件使用 一、DataGrip基本使用 1. 软件界面介绍 2. 附加文件夹到项目中【重要】 3. DataGrip配置 快捷键使用:C…...
如何成为一名 Python 全栈工程师攻略
## 从零基础到全栈工程师:Python 学习路线(细化版) **目标:** 掌握 Python 编程,并能独立开发全栈应用。 **学习路线:** ### 第一阶段:Python 基础 (4-6 周) **目标:** 掌握 Pyt…...
无需云端服务器: 三步实现DeepSeek大模型本地化部署deepseek、Ollama和Chatbox
🎉无需云端!三步实现DeepSeek大模型本地化部署😎 还在为云端AI服务的高昂费用而苦恼?是否总担心数据隐私会在云端泄露?别愁啦!DeepSeek R1——这款与OpenAI o1性能相媲美的开源大模型,结合Olla…...
mysql教程
MySQL 教程 一、简介 MySQL 是一个开源的关系型数据库管理系统,广泛应用于各种规模的项目中。以下是一些基础知识和常用操作。 二、安装与启动 安装:根据操作系统选择合适的安装包进行安装。启动:通过命令行或服务管理工具启动 MySQL 服务…...
【自学笔记】JavaWeb的重点知识点-持续更新
提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 JavaWeb知识点一、基础概念二、项目结构三、Tomcat服务器四、数据库连接(JDBC)五、前端技术六、高级技术 总结 以下是JavaWeb知识点的MD格式…...
项目升级Sass版本或升级Element Plus版本遇到的问题
项目升级Sass版本或升级Element Plus版本遇到的问题 如果项目有需求需要用到高版本的Element Plus组件,则需要升级相对应的sass版本,Element 文档中有提示,2.8.5及以后得版本,sass最低支持的版本为1.79.0,所升级sass、…...
[EAI-028] Diffusion-VLA,能够进行多模态推理和机器人动作预测的VLA模型
Paper Card 论文标题:Diffusion-VLA: Scaling Robot Foundation Models via Unified Diffusion and Autoregression 论文作者:Junjie Wen, Minjie Zhu, Yichen Zhu, Zhibin Tang, Jinming Li, Zhongyi Zhou, Chengmeng Li, Xiaoyu Liu, Yaxin Peng, Chao…...
char和varchar的区别、varchar(?)中问号部分的含义、索引的作用
char和varchar的区别 char是固定长度类型,当输入字符不满设定的固定长度时依旧占用固定长度的空间,补充空字节。 最大长度为255个字符 优点:效率高,在涉及索引和排序时缺点:占用空间使用场景:存储密码的…...
.NET9增强OpenAPI规范,不再内置swagger
ASP.NETCore in .NET 9.0 OpenAPI官方文档ASP.NET Core API 应用中的 OpenAPI 支持概述 | Microsoft Learnhttps://learn.microsoft.com/zh-cn/aspnet/core/fundamentals/openapi/overview?viewaspnetcore-9.0https://learn.microsoft.com/zh-cn/aspnet/core/fundamentals/ope…...
qsort应用
每天都会收到ai个礼物,到第n天的时候,然然发现他的宿舍被礼物搞得一团糟,所以然然打算到超市买一个柜子装礼物。但是超市有m个柜子,每个柜子都有不同的容量bi,然然想知道每个柜子最多可以装多少天的礼物(可…...
仿真设计|基于51单片机的贪吃蛇游戏
目录 具体实现功能 设计介绍 51单片机简介 资料内容 仿真实现(protues8.7) 程序(Keil5) 全部内容 资料获取 具体实现功能 利用单片机8*8点阵实现贪吃蛇游戏的控制。 仿真演示视频: 51-基于51单片机的贪吃蛇游…...
Linux内核中的页面错误处理机制与按需分页技术
在现代操作系统中,内存管理是核心功能之一,而页面错误(Page Fault)处理机制是内存管理的重要组成部分。当程序访问一个尚未映射到物理内存的虚拟地址时,CPU会触发页面错误异常,内核需要捕获并处理这种异常,以决定如何响应,例如加载缺失的页面、处理权限错误等。Linux内…...
Baklib推动企业知识管理创新与效率提升的全面探讨
内容概要 在当今数字化转型的背景下,有效的知识管理显得尤为重要。知识是企业的核心资产,而传统的管理方式往往无法充分发挥这些知识的价值。因此,企业亟需一种高效、灵活的解决方案来应对这一挑战。Baklib作为一款先进的企业级知识管理平台…...
NLP自然语言处理通识
目录 ELMO 一、ELMo的核心设计理念 1. 静态词向量的局限性 2. 动态上下文嵌入的核心思想 3. 层次化特征提取 二、ELMo的模型结构与技术逻辑 1. 双向语言模型(BiLM) 2. 多层LSTM的层次化表示 三、ELMo的运行过程 1. 预训练阶段 2. 下游任务微调 四、ELMo的…...
计算机毕业设计Python+CNN卷积神经网络考研院校推荐系统 考研分数线预测 考研推荐系统 考研爬虫 考研大数据 Hadoop 大数据毕设 机器学习
温馨提示:文末有 CSDN 平台官方提供的学长联系方式的名片! 温馨提示:文末有 CSDN 平台官方提供的学长联系方式的名片! 温馨提示:文末有 CSDN 平台官方提供的学长联系方式的名片! 作者简介:Java领…...
【编译原理实验二】——自动机实验:NFA转DFA并最小化
本篇适用于ZZU的编译原理课程实验二——自动机实验:NFA转DFA并最小化,包含了实验代码和实验报告的内容,读者可根据需要参考完成自己的程序设计。 如果是ZZU的学弟学妹看到这篇,那么恭喜你,你来对地方啦! 如…...
Hive:复杂数据类型之Map函数
Map函数 是Hive里面的一种复杂数据类型, 用于存储键值对集合。Map中的键和值可以是基础类型或复合类型,这使得Map在处理需要关联存储信息的数据时非常有用。 定义map时,需声明2个属性: key 和 value , map中是 key value 组成一个元素 key-value, key必须为原始类…...
C++ 中的引用(Reference)
在 C 中,引用(Reference)是一种特殊的变量类型,它提供了一个已存在变量的别名。引用在很多场景下都非常有用,比如函数参数传递、返回值等。下面将详细介绍 C 引用的相关知识。 1. 引用的基本概念和语法 引用是已存在…...
密码学的数学基础1-整数 素数 和 RSA加密
数学公式推导是密码学的基础, 故开一个新的课题 – 密码学的数学基础系列 素数 / 质数 质数又称素数。 一个大于1的自然数,除了1和它自身外,不能被其他自然数整除的数叫做质数;否则称为合数(规定1既不是质数也不是合数࿰…...
Java锁自定义实现到aqs的理解
专栏系列文章地址:https://blog.csdn.net/qq_26437925/article/details/145290162 本文目标: 理解锁,能自定义实现锁通过自定义锁的实现复习Thread和Object的相关方法开始尝试理解Aqs, 这样后续基于Aqs的的各种实现将能更好的理解 目录 锁的…...
STM32-时钟树
STM32-时钟树 时钟 时钟...
android 圆形弹窗摄像头开发踩坑——源码————未来之窗跨平台操作
一、飘窗刷脸,拍照采用飘窗 刷脸认证安卓接口采用飘窗具有在不干扰用户主要操作的前提下以醒目方式引导用户完成认证,且能灵活定制样式以提升用户体验和认证效率的优点 二、踩坑只有一个扇形 <?xml version"1.0" encoding"utf-8&quo…...
markdown公式特殊字符
个人学习笔记 根号 在 Markdown 中,要表示根号 3,可以使用 LaTeX 语法来实现。常见的有以下两种方式: 行内公式形式:使用一对美元符号 $ 将内容包裹起来,即 $\sqrt{3}$ ,在支持 LaTeX 语法渲染的 Markdow…...
Web-3.0学习路线
方向学习内容✅ 区块链基础区块链、智能合约、共识机制✅ 智能合约Solidity / Rust(Ethereum / Solana)✅ 前端React.js, Next.js, Web3.js, ethers.js✅ 后端Node.js, Python, Golang(链上数据)✅ 存储IPFS, Arweave, Filecoin&a…...
【算法设计与分析】实验5:贪心算法—装载及背包问题
目录 一、实验目的 二、实验环境 三、实验内容 四、核心代码 五、记录与处理 六、思考与总结 七、完整报告和成果文件提取链接 一、实验目的 掌握贪心算法求解问题的思想;针对不同问题,会利用贪心算法进行问题建模、求解以及时间复杂度分析&#x…...