Python学习(一)——配套《PyTorch深度学习实战》
记录一下Python学习过程中的一些问题:
1. 在JupyterLab中查询当前文件的地址
import os
print(os.getcwd())
#查询该文件的地址
2. 新建cell
在 JupyterLab 中新建一个单元格(cell)的方法有多种,以下是一些常用的方法:
- 使用快捷键:
B:在当前单元格下方新建一个单元格。A:在当前单元格上方新建一个单元格。
实测有效,虽然看起来挺神奇的,确实方便
使用工具栏按钮:
- 在工具栏上,你可以找到用于添加单元格的按钮。通常,这些按钮位于工具栏的中间部分,看起来像是一个带有加号的单元格图标。
使用右键菜单:
- 在工作区的空白处或者在已有单元格的边缘右键点击,然后选择“Insert Cell Above”或“Insert Cell Below”来在相应位置插入新单元格。
使用命令面板:
- 点击工具栏上的 "Commands" 图标(或者使用快捷键
Ctrl+Shift+P),在命令面板中搜索 "Insert Cell Below" 或 "Insert Cell Above" 并选择它。
- 点击工具栏上的 "Commands" 图标(或者使用快捷键
拖拽单元格:
- 你可以将一个单元格拖拽到工作区的空白处,然后释放鼠标,这将在该位置创建一个新的单元格。
使用菜单:
- 在 JupyterLab 的菜单栏中,点击 "Insert",然后选择 "Insert Cell Below" 或 "Insert Cell Above"。
使用侧边栏:
- 在 JupyterLab 的侧边栏中,点击 "+" 图标,然后选择 "Code" 或 "Markdown" 来创建一个新的单元格。
使用拖拽文件:
- 你也可以将一个
.py或.ipynb文件拖拽到 JupyterLab 的工作区中,这将创建一个新的单元格或打开一个新笔记本。
- 你也可以将一个
选择适合你的方法来新建单元格,然后你就可以在新单元格中输入代码或 Markdown 文本了。
3. 集合、列表、元祖的区别
在 Python 中,集合(set)、列表(list)和元组(tuple)是三种不同的数据结构,它们各自有不同的特性和用途:
列表(List):
- 列表是可变的,这意味着你可以在创建后修改它们(添加、删除或更改元素)。
- 列表可以包含重复的元素。
- 列表是有序的,即它们保持元素插入的顺序。
- 列表可以包含不同类型的元素。
- 列表支持索引和切片操作。
- 列表的典型用法包括创建一个有序的元素集合,或者当你需要修改集合中的元素时。
元组(Tuple):
- 元组是不可变的,一旦创建就不能修改(不能添加、删除或更改元素)。
- 元组可以包含重复的元素。
- 元组也是有序的,并且支持索引和切片操作。
- 元组可以包含不同类型的元素。
- 元组通常用于存储不应该改变的数据。
- 元组是创建不可变集合的推荐方式,它们还可以用作字典的键(因为字典的键必须是不可变的)。
集合(Set):
- 集合是无序的,这意味着集合中的元素没有固定的顺序,并且可能会在每次迭代时改变。
- 集合是可变的,你可以添加或删除元素。
- 集合不能包含重复的元素,每个元素都是唯一的。
- 集合不支持索引操作,因为它们是无序的。
- 集合的典型用法包括消除重复元素、进行集合运算(如并集、交集、差集)。
- 集合是不可哈希的,因此不能用作字典的键。
以下是一些示例:
# 列表
my_list = [1, 2, 3, 4, 5]
my_list.append(6) # 添加元素
my_list[1] = 20 # 修改元素
# 元组
my_tuple = (1, 2, 3, 4, 5)
# my_tuple[1] = 20 # 这会引发 TypeError,因为元组是不可变的
# 集合
my_set = {1, 2, 3, 4, 5}
my_set.add(6) # 添加元素
# my_set[1] # 这会引发 TypeError,因为集合不支持索引
选择使用哪种数据结构取决于你的具体需求,比如是否需要有序性、是否允许重复元素、是否需要修改集合等。
4. 张量的二维表达是矩阵
张量(Tensor)和矩阵(Matrix)是线性代数中的两个概念,它们有一定的联系,但在维度和应用上有所不同。
矩阵:
- 矩阵是一个二维数组,由行和列组成,可以看作是特殊的张量。
- 矩阵中的元素通常用两个索引来访问,如 ( a_{ij} ),其中 ( i ) 表示行索引,( j ) 表示列索引。
- 矩阵在数学、物理学和工程学中有广泛的应用,特别是在线性变换、系统方程和图形变换等领域。
张量:
- 张量是多维数组的推广,可以有任意数量的维度。例如,0维张量是一个标量,1维张量是一个向量,2维张量是一个矩阵。
- 张量中的元素可以用多个索引来访问,如 ( a_{ijk} ),其中 ( i )、( j ) 和 ( k ) 分别表示不同维度的索引。
- 张量在物理学中用于描述具有多个分量的物理量,如应力、应变等。在深度学习中,张量用于表示数据和权重,可以是多维的,以适应不同的网络结构和计算需求。
在深度学习和计算机科学中,张量的概念被广泛使用,尤其是在以下领域:
- 神经网络:张量用于表示网络的输入、输出和权重。
- 图像处理:图像可以表示为三维张量(高度、宽度、颜色通道)。
- 自然语言处理:文本数据可以表示为张量,用于模型的输入和处理。
在 PyTorch 和 TensorFlow 等深度学习框架中,张量是核心数据结构,它们提供了对多维数组的高效操作,并且可以利用 GPU 加速计算。这些框架中的张量操作通常包括基本的数学运算、矩阵乘法、卷积、池化等。
Python学习(一)——配套《PyTorch深度学习实战》的更多相关文章
- Python自然语言处理实战核心技术与算法,Python自然语言处理,PyTorch深度学习实战【下载】
本人买的,无私贡献给大家,无解压密码 下载地址: 链接:https://pan.baidu.com/s/1cJtnhEQSXHVMgygr8PHh9A 提取码:a54u
- 对比学习:《深度学习之Pytorch》《PyTorch深度学习实战》+代码
PyTorch是一个基于Python的深度学习平台,该平台简单易用上手快,从计算机视觉.自然语言处理再到强化学习,PyTorch的功能强大,支持PyTorch的工具包有用于自然语言处理的Allen N ...
- 基于Ubuntu+Python+Tensorflow+Jupyter notebook搭建深度学习环境
基于Ubuntu+Python+Tensorflow+Jupyter notebook搭建深度学习环境 前言一.环境准备环境介绍软件下载VMware下安装UbuntuUbuntu下Anaconda的安 ...
- PyTorch深度学习实践——反向传播
反向传播 课程来源:PyTorch深度学习实践--河北工业大学 <PyTorch深度学习实践>完结合集_哔哩哔哩_bilibili 目录 反向传播 笔记 作业 笔记 在之前课程中介绍的线性 ...
- PyTorch深度学习实践——多分类问题
多分类问题 目录 多分类问题 Softmax 在Minist数据集上实现多分类问题 作业 课程来源:PyTorch深度学习实践--河北工业大学 <PyTorch深度学习实践>完结合集_哔哩 ...
- PyTorch深度学习实践——处理多维特征的输入
处理多维特征的输入 课程来源:PyTorch深度学习实践--河北工业大学 <PyTorch深度学习实践>完结合集_哔哩哔哩_bilibili 这一讲介绍输入为多维数据时的分类. 一个数据集 ...
- SIGAI深度学习第四集 深度学习简介
讲授机器学习面临的挑战.人工特征的局限性.为什么选择神经网络.深度学习的诞生和发展.典型的网络结构.深度学习在机器视觉.语音识别.自然语言处理.推荐系统中的应用 大纲: 机器学习面临的挑战 特征工程的 ...
- 【PyTorch深度学习60分钟快速入门 】Part1:PyTorch是什么?
0x00 PyTorch是什么? PyTorch是一个基于Python的科学计算工具包,它主要面向两种场景: 用于替代NumPy,可以使用GPU的计算力 一种深度学习研究平台,可以提供最大的灵活性 ...
- Python学习(二)——深度学习入门介绍
课程二:深度学习入门 讲师:David (数据分析工程师) 这门课主要介绍了很多神经网络的基本原理,非常非常基础的了解. 零.思维导图预览: 一.深度神经网络 1.神经元 ...
- 【PyTorch深度学习】学习笔记之PyTorch与深度学习
第1章 PyTorch与深度学习 深度学习的应用 接近人类水平的图像分类 接近人类水平的语音识别 机器翻译 自动驾驶汽车 Siri.Google语音和Alexa在最近几年更加准确 日本农民的黄瓜智能分 ...
随机推荐
- SQLServer数据库事务级别
EFCore自动创建的数据库在SQLSERVER时是READ_COMMITTED_SNAPSHOT,SQLSERVER创建数据库默认是READ_COMMITTED. 因此记录一下查看和修改的方法,以便 ...
- LaMI-DETR:基于GPT丰富优化的开放词汇目标检测 | ECCV'24
现有的方法通过利用视觉-语言模型(VLMs)(如CLIP)强大的开放词汇识别能力来增强开放词汇目标检测,然而出现了两个主要挑战:(1)概念表示不足,CLIP文本空间中的类别名称缺乏文本和视觉知识.(2 ...
- 修复一个kubernetes集群
前几天有个朋友把他们的kubernetes集群搞挂了,让我帮忙恢复一下,由于很多现场都没有了,这里提供一下解决思路. 环境问题 该环境有一个master节点,即控制面pod(etcd.schedule ...
- Cartographer学习——地图概率更新过程
前言:最近一直在研究建图,对google的开源SLAM框架 Cartographer 进行了源码梳理,发现很多巧妙的算法设计,结合原论文 <Real-time Loop Closure in 2 ...
- 2024 Navicat Premium 16+17安装教程(附激活方法)
Navicat Premium,作为一款功能全面的集成数据库管理工具,无缝支持多样化的数据库类型,为用户带来前所未有的高效与便捷管理体验.它不仅涵盖了连接管理.数据导入导出.同步迁移.备份恢复等核心功 ...
- 看图对比Pytest、Unittest
- .NET 高性能异步套接字库,支持多协议、跨平台、高并发
前言 .NET 生态中有哪些值得推荐的网络通信框架?今天,给大家推荐一个非常优秀的开源项目--NetCoreServer. NetCoreServer 是一款 .NET 开源.免费.快速且低延迟的异步 ...
- AOT使用经验总结
一.引言 站长接触 AOT 已有 3 个月之久,此前在<好消息:NET 9 X86 AOT的突破 - 支持老旧Win7与XP环境>一文中就有所提及.在这段时间里,站长使用 Avalonia ...
- cnblogs的GitHub同步markdown文件的blog如何识别文章的唯一性(身份ID如何判定)
本篇blog是写在GitHub的对应的仓库中的. cnblogs会给终身用户提供一个把GitHub仓库中的markdown文件同步到cnblogs上的一个服务,本文就是使用这个服务同步到个人blog地 ...
- git rebase -i的时候用的不是 vi 编辑器是 nano编辑器不会用
今天给同事 rebase 代码 发现 git fetch && git rebase -i origin/develop 的时候 出现了 那个 nano 编辑器的界面 不会用,和vim ...