AI机器学习 | 基于librosa库和使用scikit-learn库中的分类器进行语音识别

专栏集锦,大佬们可以收藏以备不时之需

Spring Cloud实战专栏:https://blog.csdn.net/superdangbo/category_9270827.html

Python 实战专栏:https://blog.csdn.net/superdangbo/category_9271194.html

Logback 详解专栏:https://blog.csdn.net/superdangbo/category_9271502.html

tensorflow专栏:https://blog.csdn.net/superdangbo/category_8691332.html

Redis专栏:https://blog.csdn.net/superdangbo/category_9950790.html

AI机器学习实战:

AI机器学习实战 | 使用 Python 和 scikit-learn 库进行情感分析

Python实战:

Python实战 | 使用 Python 和 TensorFlow 构建卷积神经网络(CNN)进行人脸识别

Spring Cloud实战:

Spring Cloud 实战 | 解密Feign底层原理,包含实战源码

Spring Cloud 实战 | 解密负载均衡Ribbon底层原理,包含实战源码

1024程序员节特辑文章:

1024程序员狂欢节特辑 | ELK+ 协同过滤算法构建个性化推荐引擎,智能实现“千人千面”

1024程序员节特辑 | 解密Spring Cloud Hystrix熔断提高系统的可用性和容错能力

1024程序员节特辑 | ELK+ 用户画像构建个性化推荐引擎,智能实现“千人千面”

1024程序员节特辑 | OKR VS KPI谁更合适?

1024程序员节特辑 | Spring Boot实战 之 MongoDB分片或复制集操作

Spring实战系列文章:

Spring实战 | Spring AOP核心秘笈之葵花宝典

Spring实战 | Spring IOC不能说的秘密?

国庆中秋特辑系列文章:

国庆中秋特辑(八)Spring Boot项目如何使用JPA

国庆中秋特辑(七)Java软件工程师常见20道编程面试题

国庆中秋特辑(六)大学生常见30道宝藏编程面试题

国庆中秋特辑(五)MySQL如何性能调优?下篇

国庆中秋特辑(四)MySQL如何性能调优?上篇

国庆中秋特辑(三)使用生成对抗网络(GAN)生成具有节日氛围的画作,深度学习框架 TensorFlow 和 Keras 来实现

国庆中秋特辑(二)浪漫祝福方式 使用生成对抗网络(GAN)生成具有节日氛围的画作

国庆中秋特辑(一)浪漫祝福方式 用循环神经网络(RNN)或长短时记忆网络(LSTM)生成祝福诗词

在这里插入图片描述

目录

  • 1、普通人在学习 AI 时结合以下10个方面开展
  • 2、机器学习应用场景
  • 3、机器学习面对的挑战
  • 4、机器学习步骤
  • 5、语音识别具体步骤
      • 1. 环境准备
      • 2. 数据准备
      • 3. 特征提取
      • 4. 模型训练
      • 5. 模型评估
  • 6、语音识别相关资料
      • 1. 学习资料
      • 2. 开源技术
      • 3. 完整代码介绍
      • 4. 调优
      • 5. 案例分享

1、普通人在学习 AI 时结合以下10个方面开展

普通人在学习 AI 时可以采取以下具体措施和对应案例:

  1. 学习基础知识:
    • 阅读书籍:《人工智能:一种现代的方法》(作者:Stuart Russell 和 Peter Norvig)
    • 在线课程:斯坦福大学 CS224n(计算机视觉)和 CS221(机器学习)
  2. 学习编程语言:
    • 选择 Python 作为入门编程语言,因为它易于学习且在 AI 领域广泛应用。
  3. 学习数学和统计学:
    • 线性代数:学习矩阵运算、向量空间和线性变换等概念。
    • 概率论与统计学:学习概率分布、假设检验和回归分析等概念。
  4. 学习 AI 相关库和框架:
    • TensorFlow:一个广泛用于深度学习的开源库。
    • PyTorch:另一个流行的深度学习框架。
    • scikit-learn:一个用于机器学习的库,包含多种分类、回归和聚类算法。
  5. 动手实践:
    • 项目案例:使用 TensorFlow 实现 MNIST 手写数字识别。
    • 参考教程:https://www.tensorflow.org/tutorials/sequential/mnist
  6. 学习具体应用领域:
    • 自然语言处理(NLP):使用 spaCy 库进行文本分类和情感分析。
    • 计算机视觉(CV):使用 OpenCV 库实现图像处理和目标检测。
  7. 关注行业动态:
    • 阅读 AI 领域的论文和研究:如《深度学习》(作者:Ian Goodfellow、Yoshua Bengio 和 Aaron Courville)
    • 关注顶级会议:如 NeurIPS(神经信息处理系统会议)和 CVPR(计算机视觉和模式识别国际会议)
  8. 加入社群交流:
    • 参与线上论坛:如 Reddit、知乎等,关注 AI 相关话题。
    • 参加线下活动:如 AI 沙龙、技术讲座和研讨会。
  9. 结合实际工作或兴趣爱好:
    • 工作案例:使用 AI 优化供应链管理或客户服务。
    • 个人兴趣:利用 AI 制作音乐、游戏或艺术作品。
  10. 持续学习:
  • 参加在线课程:如 Coursera、Udacity 等,不断提升自己的 AI 技能。
  • 阅读博客和论文:了解最新的 AI 研究和应用。
    通过以上具体措施和案例,普通人可以逐步掌握 AI 技术,并在实际应用中发挥重要作用。只要不断学习、实践和探索,普通人在 AI 领域也能取得很好的成果。

2、机器学习应用场景

AI 和机器学习技术在以下具体应用场景中发挥着重要作用,并且具有广阔的前景:

  1. 金融领域:AI 机器学习技术可以用于风险评估、投资决策、欺诈检测等,有助于金融机构提高效率和降低风险。
  2. 医疗健康:AI 机器学习技术在医疗影像分析、基因测序、疾病预测等方面具有巨大潜力,有助于提高诊断准确率和治疗效果。
  3. 自然语言处理:AI 机器学习技术在语音识别、文本分析、情感分析、机器翻译等领域具有广泛应用,为人类提供便捷的语言交互方式。
  4. 计算机视觉:AI 机器学习技术在图像识别、目标检测、人脸识别等方面有着广泛应用,助力智能监控、自动驾驶等场景。
  5. 零售业:通过分析消费者行为和购买偏好,AI 机器学习技术可以帮助零售商实现精准营销和库存管理。
  6. 制造业:AI 机器学习技术可以用于智能制造、机器人、自动化生产线等,提高生产效率和质量。
  7. 能源领域:AI 机器学习技术在智能电网、能源优化等方面具有潜力,有助于实现可持续能源发展和降低能源成本。
  8. 物流行业:AI 机器学习技术可以应用于路径规划、仓储管理、配送优化等,提高物流效率。
  9. 城市规划:AI 机器学习技术在交通优化、基础设施规划、城市安全等方面具有价值。
  10. 环境保护:AI 机器学习技术可以帮助实现更有效的环境监测、污染源识别和生态评估。
  11. 教育:AI 机器学习技术可以用于智能教育辅导、学习分析、教育内容推荐等,提高教学质量和个人学习能力。
  12. 医疗诊断:AI 机器学习技术可以辅助医生进行疾病诊断,提高诊断准确率和治疗效果。
  13. 网络安全:AI 机器学习技术在入侵检测、恶意代码分析、网络流量监控等方面具有重要意义。
  14. 艺术创作:AI 机器学习技术在生成艺术、音乐生成、绘画等方面具有潜力,为艺术家提供新的创作工具和思路。
  15. 农业领域:AI 机器学习技术在智能农业、作物病虫害预测、农业自动化等方面具有价值。
    总之,AI 机器学习技术具有广泛的应用场景和前景,随着技术的不断发展,其在各个领域的应用将更加广泛,为人类带来更多便利和创新。

3、机器学习面对的挑战

挑战:

  1. 数据隐私和安全:在数据收集、存储和处理过程中,保护用户隐私和数据安全成为重要挑战。
  2. 模型可解释性:AI 和机器学习模型往往具有很高的复杂性,解释模型决策的过程和结果对于提高透明度和信任度至关重要。
  3. 算法偏见和歧视:由于数据来源和训练过程中的偏见,AI 和机器学习模型可能出现不公平和歧视现象。
  4. 技术成熟度:AI 和机器学习技术仍处于快速发展阶段,需要不断优化和完善,以满足实际应用的需求。
  5. 人才培养:AI 和机器学习领域的人才供应与需求之间存在较大差距,人才培养成为制约行业发展的重要因素。
  6. 社会伦理和法律问题:随着 AI 和机器学习技术在各个领域的应用,如何解决伦理和法律问题日益凸显。
    综上所述,AI 和机器学习技术在众多应用场景中具有广阔的前景,但同时也面临着诸多挑战。为了实现可持续发展和广泛应用,行业需要不断探索创新,解决技术和社会问题。

4、机器学习步骤

机器学习代码的编写可以分为以下几个步骤:

  1. 数据预处理:在编写机器学习代码之前,首先需要对原始数据进行预处理。这包括数据清洗、特征提取和特征缩放等操作。以下是一个简单的数据预处理代码示例:
import pandas as pd
# 读取数据  
data = pd.read_csv('data.csv')
# 数据清洗  
data = data.drop_duplicates()  
data = data.drop_na()
# 特征提取  
X = data.iloc[:, :-1].values  
y = data.iloc[:, -1].values
# 特征缩放(标准化)  
scaler = StandardScaler()  
X = scaler.fit_transform(X)  
  1. 模型选择与训练:根据任务需求选择合适的机器学习算法,然后使用训练数据对模型进行训练。以下是一个使用决策树算法(from sklearn.tree import DecisionTreeClassifier)进行训练的示例:
from sklearn.model_selection import train_test_split  
from sklearn.metrics import accuracy_score
# 划分训练集和测试集  
X_train, X_test, y_train, y_test = train_test_split(X, y, test_size=0.2, random_state=42)
# 创建并训练决策树模型  
clf = DecisionTreeClassifier()  
clf.fit(X_train, y_train)
# 使用训练好的模型进行预测  
y_pred = clf.predict(X_test)
# 计算预测准确率  
accuracy = accuracy_score(y_test, y_pred)  
print("决策树模型预测准确率:", accuracy)  
  1. 模型评估:使用测试数据评估模型的性能,如准确率、召回率、F1 分数等。以下是一个评估决策树模型准确率的示例:
from sklearn.metrics import accuracy_score
# 使用训练好的模型进行预测  
y_pred = clf.predict(X_test)
# 计算预测准确率  
accuracy = accuracy_score(y_test, y_pred)  
print("决策树模型预测准确率:", accuracy)  
  1. 模型优化:根据模型评估结果,对模型进行优化。这可能包括调整模型参数、使用更先进的算法或集成学习等。
  2. 实际应用:将训练好的模型应用于实际问题,如预测、分类、聚类等。以下是一个使用训练好的决策树模型进行预测的示例:
# 预测新数据  
new_data = pd.DataFrame({'特征 1': [1, 2, 3], '特征 2': [4, 5, 6]})  
new_data['预测结果'] = clf.predict(new_data.iloc[:, :-1].values)  
print(new_data)  

以上代码只是一个简单的机器学习项目示例,实际应用中可能需要根据具体任务和数据类型进行调整。此外,根据实际需求,您可能还需要学习更多的机器学习算法和高级技巧,如神经网络、深度学习、集成学习等。

5、语音识别具体步骤

语音识别是机器学习中的一个重要应用领域。下面是一个使用Python和简单方法的语音识别示例:

  1. 环境准备:
    首先,确保安装了以下库:
    • numpy
    • pandas
    • matplotlib
    • seaborn
    • scikit-learn
    • librosa
  2. 数据准备:
    对于这个简单的示例,我们将使用一个预先准备好的数据集。这个数据集应该包含两个文件:一个包含语音特征的CSV文件和一个包含对应语音标签的CSV文件。
  3. 特征提取:
    使用librosa库来提取语音特征。通常,我们会使用梅尔频谱系数(Mel-frequency cepstral coefficients (MFCCs))作为特征。
  4. 模型训练:
    使用scikit-learn库中的分类器(如SVM、 Random Forest等)来训练模型。
  5. 模型评估:
    使用测试集评估模型的性能。
    现在,让我们开始实施这个示例:

1. 环境准备

首先,确保您已经安装了上述库。您可以使用以下命令来安装它们:

pip install numpy pandas matplotlib seaborn scikit-learn librosa

2. 数据准备

假设您已经有一个名为speech_data.csv的CSV文件,其中包含语音特征,以及一个名为speech_labels.csv的CSV文件,其中包含对应的语音标签。

3. 特征提取

我们可以使用librosa库来提取MFCC特征。以下是一个简单的特征提取脚本:

import librosa
import librosa.display
import numpy as np
def extract_mfcc(file_path, n_mfcc=13):
    # 加载音频文件
    y, sr = librosa.load(file_path, sr=None)
    
    # 计算MFCC
    mfccs = librosa.feature.mfcc(y=y, sr=sr, n_mfcc=n_mfcc)
    
    # 返回MFCC的平均值和标准差
    return mfccs.mean(axis=1), mfccs.std(axis=1)
# 加载数据
data = pd.read_csv('speech_data.csv')
labels = pd.read_csv('speech_labels.csv')
# 提取MFCC特征
mfcc_features = []
for i, row in data.iterrows():
    file_path = row['file_path']
    mfcc_mean, mfcc_std = extract_mfcc(file_path)
    mfcc_features.append(np.hstack([mfcc_mean, mfcc_std]))
# 转换为DataFrame
mfcc_features = pd.DataFrame(mfcc_features)

4. 模型训练

我们可以使用scikit-learn中的SVM分类器来训练模型。以下是训练模型的脚本:

from sklearn.model_selection import train_test_split
from sklearn.svm import SVC
from sklearn.metrics import accuracy_score
# 准备数据
X = mfcc_features
y = labels['label']
# 分割训练集和测试集
X_train, X_test, y_train, y_test = train_test_split(X, y, test_size=0.2, random_state=42)
# 训练SVM分类器
clf = SVC(kernel='linear', C=1)
clf.fit(X_train, y_train)
# 预测
y_pred = clf.predict(X_test)
# 计算准确率
accuracy = accuracy_score(y_test, y_pred)
print(f"Accuracy: {accuracy * 100:.2f}%")

5. 模型评估

您可以使用测试集评估模型的性能。您可以根据需要调整模型参数或尝试其他分类器来优化性能。
这只是一个简单的示例,实际应用中的语音识别系统可能更复杂。实际应用中,您可能需要使用深度学习模型(如卷积神经网络)和更大的数据集来获得更好的性能。

6、语音识别相关资料

语音识别是人工智能领域的一个关键方向,涉及到大量的机器学习和深度学习技术。下面提供一个关于语音识别的概述,包括学习资料、开源技术和完整代码介绍,以及如何进行调优和案例分享。

1. 学习资料

  • 书籍:
    • 《Speech Recognition: A Machine Learning Approach》 - Michael A. Riley
    • 《Speech Processing: A Practical Guide to信号 Processing in Speech Recognition》 - Tomoki Hayashi
  • 在线课程:
    • Coursera上的"Deep Learning for Natural Language Processing"
    • edX上的"Introduction to Deep Learning"
  • 研究论文:
    • “Deep Learning for Speech Recognition: A Review” - Yoshua Bengio et al. (2017)
    • “End-to-End Speech Recognition in TensorFlow” - TensorFlow.org

2. 开源技术

  • TensorFlow: 谷歌的TensorFlow框架是一个流行的深度学习库,支持语音识别任务。
  • Keras: Keras是一个高级神经网络API,可以在TensorFlow或其他后端上运行。
  • PyTorch: PyTorch是另一个流行的深度学习框架,也可以用于语音识别。
  • ESPNet: ESPNet是一个基于PyTorch的语音处理库,包括语音识别功能。

3. 完整代码介绍

  • TensorFlow Example:
    import tensorflow as tf
    
    # Load your dataset
    dataset = ...
    
    # Build your model
    model = tf.keras.Sequential([
        tf.keras.layers.Dense(64, activation='relu', input_shape=(40, 1)),
        tf.keras.layers.Dense(64, activation='relu'),
        tf.keras.layers.Dense(len(dataset.class_names))
    ])
    
    # Compile the model
    model.compile(optimizer='adam', loss='sparse_categorical_crossentropy', metrics=['accuracy'])
    
    # Train the model
    model.fit(dataset)
    
  • PyTorch Example:
    import torch
    import torch.nn as nn
    import torch.optim as optim
    
    # Load your dataset
    dataset = ...
    
    # Define your model
    class SpeechRecognitionModel(nn.Module):
        def __init__(self):
            super(SpeechRecognitionModel, self).__init__()
            self.fc1 = nn.Linear(40, 64)
            self.fc2 = nn.Linear(64, 64)
            self.fc3 = nn.Linear(64, len(dataset.class_names))
            
        def forward(self, x):
            x = torch.relu(self.fc1(x))
            x = torch.relu(self.fc2(x))
            x = self.fc3(x)
            return x
    
    # Initialize the model, loss function, and optimizer
    model = SpeechRecognitionModel()
    criterion = nn.CrossEntropyLoss()
    optimizer = optim.Adam(model.parameters())
    
    # Train the model
    for epoch in range(num_epochs):
        for inputs, labels in dataset:
            optimizer.zero_grad()
            outputs = model(inputs)
            loss = criterion(outputs, labels)
            loss.backward()
            optimizer.step()
    

4. 调优

  • 数据增强: 对数据进行预处理,如添加噪声、时间反转、平滑处理等,可以增加训练样本数量。
  • 模型结构调优: 尝试不同的网络结构,如卷积神经网络、递归神经网络等。
  • 超参数调优: 使用超参数搜索算法,如GridSearch或RandomSearch,找到最优的超参数组合。

5. 案例分享

  • 语音命令识别: 使用语音识别技术实现对用户命令的识别,如智能家居控制。
  • 实时语音翻译: 将一种语言的语音翻译成另一种语言的文本。
  • 会议记录: 将会议内容实时转录成文本。
    以上就是关于语音识别的概述,希望能对您有所帮助!

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Python 利用PIL由多张图片合成gif动画

Python 由多张图片合成gif动画 案例 import os figure_save_path "file_fig_test" import warnings warnings.filterwarnings("error") import numpy as np np.random.seed(0) import matplotlib.pyplot as plt from PIL import Image import timenum 1…

​软考-高级-系统架构设计师教程(清华第2版)【第15章 面向服务架构设计理论与实践(P527~554)-思维导图】​

软考-高级-系统架构设计师教程(清华第2版)【第15章 面向服务架构设计理论与实践(P527~554)-思维导图】 课本里章节里所有蓝色字体的思维导图

Halcon (0):C# 联合Halcon方式简介和就业市场说明

文章目录 文章专栏前言相关视频联合C#开发直接导出C#代码Halcon引擎调用开发函数封装库工程导出 总结就业市场 文章专栏 Halcon开发 前言 根据我的测试,我发现Halcon和WPF中的halcon插件,代码具有对应性。就是你会了Halcon,WPF也差不多久会了…

Windows10下Mysql8.0安装教程

文章目录 1.下载Mysql8.02.解压Mysql安装包到指定目录3.初始化Mysql服务4.安装Mysql服务5.启动Mysql服务6.登录Mysql服务7.修改Mysql密码8.重启Mysql服务停止服务启动服务 1.下载Mysql8.0 链接:https://pan.baidu.com/s/1uP2xZj8g05xg-oHX_nfnmA 提取码:…

【Python数学练习1】

一、题目 中文描述&#xff1a; 给出正整数N&#xff0c;输出满足条件的数对(a,b)的个数&#xff0c;满足gcd(a,b)b, a,b < n 数学描述&#xff1a; 二、解法 解法1&#xff1a; 对应Python代码&#xff1a; def num_fact(n):num 0for i in range(1, n 1):if n % i …

CTF-PWN-tips

文章目录 overflowscanfgetreadstrcpystrcat Find string in gdbgdbgdb peda Binary ServiceFind specific function offset in libc手工自动 Find /bin/sh or sh in library手动自动 Leak stack addressFork problem in gdbSecret of a mysterious section - .tlsPredictable …

Confluence 快速安装教程

安装jdk yum install -y java-1.8.0-openjdk.x86_64 java -version 安装MySQL mkdir -p /data/mysql/data chmod 777 /data/mysql/datadocker rm -f mysql docker run -d --name mysql \-p 3306:3306 \-e MYSQL_ROOT_PASSWORDfingard1 \-v /data/mysql/data:/var/lib/mysql …

【代码随想录】算法训练计划25

1、216. 组合总和 III 题目&#xff1a; 找出所有相加之和为 n 的 k 个数的组合&#xff0c;且满足下列条件&#xff1a; 只使用数字1到9 每个数字 最多使用一次 返回 所有可能的有效组合的列表 。该列表不能包含相同的组合两次&#xff0c;组合可以以任何顺序返回。 思路&am…

【算法每日一练]-图论(保姆级教程 篇5(LCA,最短路,分层图)) #LCA #最短路计数 #社交网络 #飞行路线 # 第二短路

今天讲最短路统计和分层图 目录 题目&#xff1a;LCA 思路&#xff1a; 题目&#xff1a;最短路计数 思路&#xff1a; 题目&#xff1a;社交网络 思路&#xff1a; 题目&#xff1a;飞行路线 思路&#xff1a; 题目&#xff1a;第二短路 思路&#xff1a; 题目&a…

谷歌投资Character.AI,展现AI领域的战略布局和创新能力

谷歌&#xff08;Google&#xff09;作为全球最大的互联网公司之一&#xff0c;一直在人工智能&#xff08;AI&#xff09;领域发挥着引领和推动的作用。近日&#xff0c;据消息人士透露&#xff0c;谷歌正与人工智能初创公司 Character.AI 进行投资谈判&#xff0c;计划投资数…

掌握未来技术趋势,Python编程引领人工智能时代

掌握未来技术趋势&#xff0c;Python编程引领人工智能时代 摘要&#xff1a;Python作为一种高级编程语言&#xff0c;在人工智能领域中扮演着越来越重要的角色。本文将通过介绍Python编程的特点、应用场景及发展前景&#xff0c;展望Python未来的发展趋势&#xff0c;并结合代…

【springboot笔记】程序可用性检测ApplicationAvailability

1.背景 springboot-3.1.5 ApplicationAvailability LivenessState ReadinessState AvailabilityChangeEvent 我们可以通过ApplicationAvailability获取当前应用程序的可用性&#xff0c;这个可用性包括ApplicationContext和对外请求路由两种。 LivenessState 是表示Applicatio…

解决docker运行elastic服务端启动不成功

现象&#xff1a; 然后查看docker日志&#xff0c;发现有vm.max_map_count报错 ERROR: [1] bootstrap checks failed [1]: max virtual memory areas vm.max_map_count [65530] is too low, increase to at least [262144] 解决办法&#xff1a; 1. 宿主机&#xff08;运行doc…

腾讯云新用户优惠活动有哪些可以参加?腾讯云新人服务器优惠活动

腾讯云作为国内领先的云服务提供商&#xff0c;不仅为用户提供稳定可靠的云服务器&#xff0c;还为新用户带来了一系列的优惠活动和代金券&#xff0c;以降低购买成本&#xff0c;提高业务效益。在这里&#xff0c;我们将为您详细介绍腾讯云服务器的新人优惠活动及代金券&#…

进程程序替换与exec系统调用

进程程序替换 进程程序替换是指将一个正在运行的进程替换为另一个可执行程序。它的本质是调用了Linux操作系统中的exec系统调用。而exec系统调用是一个家族函数&#xff0c;例如execl、execv、execle、execve等。它们的共同特点是当当前进程执行到该函数时&#xff0c;就会直接…

竞赛 题目:基于深度学习的中文对话问答机器人

文章目录 0 简介1 项目架构2 项目的主要过程2.1 数据清洗、预处理2.2 分桶2.3 训练 3 项目的整体结构4 重要的API4.1 LSTM cells部分&#xff1a;4.2 损失函数&#xff1a;4.3 搭建seq2seq框架&#xff1a;4.4 测试部分&#xff1a;4.5 评价NLP测试效果&#xff1a;4.6 梯度截断…

美颜sdk是什么?美颜sdk技术解析与比较

美颜SDK的出现为开发者提供了快速实现高质量美颜效果的工具&#xff0c;然而&#xff0c;在众多美颜SDK中&#xff0c;技术实现和效果差异巨大。本文将对美颜SDK进行技术解析&#xff0c;并进行比较&#xff0c;以帮助开发者更好地选择适合其应用需求的美颜SDK。 一、美颜SDK…

GCD:异步同步?串行并发?一文轻松拿捏!

GCD 文章目录 GCD进程线程进程与线程的关系进程与线程的区别 任务&#xff08;执行的代码&#xff09;队列线程与队列的关系 队列任务**同步执行任务&#xff08;sync&#xff09;**辅助方法**异步执行任务&#xff08;async)**总结栅栏任务迭代任务 队列详细属性QoSAttributes…

视频剪辑技巧:简单步骤,批量剪辑并随机分割视频

随着社交媒体平台的广泛普及和视频制作需求的急剧增加&#xff0c;视频剪辑已经成为了当今社会一项不可或缺的技能。然而&#xff0c;对于许多初学者来说&#xff0c;视频剪辑可能是一项令人望而生畏的复杂任务。可能会面临各种困难&#xff0c;如如何选择合适的软件和硬件、如…

Vue3 shallowRef 和 shallowReactive

一、shallowRef 使用shallowRef之前需要进行引入&#xff1a; import { shallowRef } from vue; 使用方法和ref 的使用方法一致&#xff0c;以下是二者的区别&#xff1a; 1. 如果ref 和 shallowRef 都传入的是普通数据类型的数据&#xff0c;那么他们的效果是一样的&#x…