在 Jupyter 中使用 Matlab
Jupyter 为创建交互式脚本提供了一个强大且广泛的平台,在这里介绍一种在 Jupyter 中调用 Matlab 的方法。假设已经安装了 Miniconda 或者 Anaconda, Matlab 版本是 2020a,安装在路径:/usr/local/MATLAB 下。
创建虚拟环境因为 Matlab 2020a 对应的 Python 版本最高为 3.7,所以这里安装对于版本,虚拟环境名字命名为 jmatlab
各版本对应关系:matlab-python-compatibility
1conda create -vv -n jmatlab python=3.7 jupyter
激活 jmatlab 环境1conda activate jmatlab
安装 jupyterlab 和 matlab 内核123pip install jupyterlabpip install matlab_kernelpython -m matlab_kernel install
查看安装的内核1jupyter kernelspec list
您应该在可用内核列表中看到 Matlab.
安装 ...
在 Ubuntu 上挂载 ISO 文件
我这里需要安装 MATLAB,但是下载的软件是 ISO 文件,无法直接读取,需要挂在到 Ubuntu 上才能读取,因此,使用如下方法挂载和卸载 ISO 文件
创建挂在点文件夹1sudo mkdir /media/iso
挂载 ISO 文件到挂载点1sudo mount -o loop /home/jinzhongxu/Matlab98R2020a_Lin64.iso /media/jinzhongxu
卸载1sudo umount /media/iso
参考链接
How to mount an ISO file?
分组卷积、深度卷积和全局深度卷积
卷积能够提取图像特征,不同的卷积操作能够获得不同的效果,同时有些卷积能够降低待学习的参数量,达到正则化的目的。
分组卷积分组卷积(Group Convolution)最早见于2012年 ImageNet 竞赛中的 AlexNet 网路中,被用来切分网络,使得模型能够在2个GPU上并行运行,AlexNet 的网络结构如下:
分组卷积的定义对于常规卷积,如果输入的特征图是 $C * H * W$,卷积核个数是 $N$,输出特征图的数量也是 $N$,其与卷积核的数量相同。假设卷积和的尺寸是 $C * K * K$,那么 $N$ 个卷积核的总参数量为 $N * C * K * K$,输入特征图与输出特征图的连接方式如下左图:
分组卷积是对输入特征图先分组,然后每组分别卷积。假设输入特征图的尺寸仍为 $C * H * W$,输出特征图的数量为 $N$个,如果要分成 $G$ 个组,则每组的输入特征通道数为 $\frac{C}{G}$,每组的输出特征图通道数为 $\frac{N}{G}$,每个卷积核的尺寸为 $\frac{C}{G} * K * K$,卷积核的总数仍为 $N$个,但每组的卷 ...
Windows 远程连接 Ubuntu 桌面
想从 Windows 10 远程桌面访问 Ubuntu,通过使用 xrdp 来达成这一目的。
Ubuntu 上安装软件安装远程桌面协议 (RDP) 服务器 xrdp
1sudo apt install xrdp
运行远程桌面共享服务器xrdp
1sudo systemctl enable --now xrdp
为传入流量打开防火墙端口 3389
1sudo ufw allow from any to any port 3389 proto tcp
Windows上远程连接移至 Windows 10 主机并打开远程桌面连接客户端。使用搜索框搜索远程关键字,然后单击打开按钮。
输入 Ubuntu 的 IP 地址和端口号 3389,验证连接
可能问题在启动到 Xrdp 远程桌面协议 (RDP) 服务器的远程连接后,我有时会收到黑屏。虽然我不确定如何完全解决这个问题,但在建立远程连接之前从 Ubuntu 桌面注销至少暂时解决了这个问题。
参考链接
Ubuntu 20.04 Remote Desktop Access from Windows 10
无人驾驶6个等级划分
美国汽车工程师学会 (SAE) 定义了6个无人驾驶等级 — 从 0 级(完全手动)到 5 级(完全自动)。这些无人驾驶等级准则已经被美国交通部采纳。
0 级(无自动驾驶)在当今的道路上行驶的大多数汽车都是 0 级:手动控制。由人来完成”动态驾驶任务”,尽管可能有相应的系统来辅助驾驶员,例如紧急制动系统,但从技术方面来讲,该辅助系统并未主动”驱动”车辆,所以算不上自动化驾驶。
1 级(驾驶员辅助)这是自动化的最低级别。车辆具有单独的自动化驾驶员辅助系统,例如转向或加速(巡航控制)。自适应巡航控制系统可以让车辆与前车保持安全距离,驾驶员负责监控驾驶的其他方面(例如转向和制动),因此符合 1 级标准。
2 级(部分自动驾驶)这指的是高级驾驶员辅助系统或 ADAS。车辆能够控制转向以及加速或减速。因为有驾驶员坐在汽车座位上,并且可以随时控制汽车,所以这一阶段的自动驾驶还算不上无人驾驶。特斯拉的 Autopilot 和凯迪拉克的(通用汽车)Super Cruise 系统都符合 2 级标准。
3 级(受条件制约的自动驾驶)从技术角度来看,从 2 级到 3 级实现了重大飞跃,但从驾驶人员 ...
PyTorch 模型保存和加载
在训练深度学习模型时,需要定时保存最优模型;当模型训练时间过长,中断训练判断是否继续训练时,需要保存模型;当训练好的模型拿给别人推断时,需要保存模型,等等。模型的保存和加载在深度学习模型的研究和推理时经常使用。本文介绍如何在 PyTorch 中保存和加载模型。
基本方法torch.save()将序列化对象保存到磁盘。此函数使用 Python 的 pickle 实用程序进行序列化。使用此功能可以保存各种对象的模型、张量和字典。
1torch.save(obj, f, pickle_module=<module 'pickle' from '/usr/local/miniconda/lib/python3.8/pickle.py'>, pickle_protocol=2)
1234obj – 保存对象f - 类文件对象 (返回文件描述符)或一个保存文件名的字符串,一般保存文件的扩展名为 .pth 或者 .ptpickle_module – 用于 pickling 元数据和对象的模块pickle_protocol – 指定 pickl ...
PyTorch 中的 nn 和 nn.functional
PyTorch 中有两个模块 torch.nn 和 torch.nn.functional 都可以用来构造深度学习神经网络模型,实现相同的功能,然而它们之间有着重要的差别。
大体上来说,torch.nn 更抽象,是对 torch.nn.functional 更高一层的实现,有点 keras vs. tensorflow(1.x) 的感觉。torch.nn 中的,如 ReLU、Conv2d等,是类,而 torch.nn.functional 中的,如 relu、conv2d 等,是函数。
torch.nntorch.nn 里面的类是 torch.nn.functional 中函数的封装,两者都继承于 torch.nn.Module,因此 torch.nn 除了具有 torch.nn.functional 的功能外,还附带了 torch.nn.Module 相关的属性和方法,如 train(), eval(), load_state_dict, state_dict 等。
torch.nn 需要先实例化,然后对实例化对象传入数据:
1234567import torchinputs ...
清理 Linux 系统内存 Cache
每个 Linux 系统都有三个选项可以在不中断任何进程或服务的情况下清除缓存。本篇代码以 root 身份在 Ubuntu 18.04演示。
仅清除页面缓存(Clear PageCache only)1sync; echo 1 > /proc/sys/vm/drop_caches
清除目录项和inode(Clear dentries and inodes)1sync; echo 2 > /proc/sys/vm/drop_caches
清理三者(Clear PageCache, dentries and inodes)1sync; echo 3 > /proc/sys/vm/drop_caches
同步 (sync) 将刷新文件系统缓冲区。命令以 “;” 分隔依次运行。在执行序列中的下一个命令之前,shell 等待每个命令终止。正如内核文档中提到的,写入 drop_cache 将清除缓存而不杀死任何应用程序/服务,命令 echo 正在执行写入文件的工作。
如果您必须清除磁盘缓存,第一个命令在企业和生产中是最安全的“…echo 1 > …”。只会 ...
深度学习中的欠拟合和过拟合
人类专家在完成某项任务的准确性可以作为深度学习完成同样任务合理目标的参考。由于人类专家人类专家也有犯错的概率,因此,利用他们准备的数据集训练模型,不能期望100%的准确率。在深度学习模型训练中常遇到欠拟合和过拟合,我认为这主要是因为数据量和模型不匹配导致的。当模型简单时,如线性模型、参数量少等,训练数据量需求相对较少;当模型复杂时,如指数、参数量多等,训练数据量需求就会相对较多。
欠拟合当模型的训练误差明显大于理想模型的预期误差时,说明发生了欠拟合。在深度学习中,当模型在训练集上表现不佳时,称模型具有高偏差(bias)。
解决欠拟合处理欠拟合模型的最佳方法是尝试更大的神经网络(添加新层或增加现有层中的神经元数量)或对模型进行更长时间的训练。
更大的神经网络
这是因为欠拟合的神经网络可能不足以捕捉训练数据集中的模式。在这种情况下,添加更多层或增加神经元数量可能有助于解决问题。
更长时间的训练
欠拟合的模型是尚未找到参数最佳值,增加训练时间可能会有帮助。
过拟合当模型在训练集上表现良好,但在使用验证集或测试数据集时无法达到良好的准确性时,就会发生过拟合。这类问题称为高方差(va ...
Python 逻辑运算
Python 的逻辑运算符包括 and, or, not,但位运算符 & (按位与运算符), | (按位或运算符) 有时也可以达到 and, or 的效果,有时,只有位运算符才能完成,如 pandas 中。下面进行总结,主要介绍 and, or 和 &, |.
基本介绍离散数学中,假设 p 和 q 都是命题,那么
p 且 q: 当 p 和 q 都取值为真时结果才为真;
p 或 q: 当 p 和 q 都取值为假时结果才为假;
Python 逻辑运算命题为逻辑变量时当命题为逻辑变量时,即取值为 True, False 布尔值时,and, or 和 &, | 相对应的运算符用法基本一致,除了在pandas中。
也就是说,以下的表达式结果都为 True
123456789(True & True) == (True and True)(True & False) == (True and False)(False & True) == (False and True)(False & False) == (False and F ...
Mac 电脑重设密码
当某天突然 Mac 电脑无法通过输入密码正常进入系统,但密码正确无误,不知什么原因,可通过如下方式重设密码。
关机按住开机键3秒,电脑强制关机
进入恢复模式按住 command + r 键保持住,然后按开机键开机,进入恢复模式
通过终端命令重设密码在左上角菜单栏找到 实用程序,选择 Terminal,输入 resetpassword 回车
此时会弹出一个界面,请同时设定所有用户的密码,可以重设管理员密码。
重设确认后,重启电脑即可。
其他重设密码方法如果能够正常进入 Mac 系统,可以使用如下方法重设密码
打开 系统便好设置 找到 用户和群组 打开小锁, 点击更改密码
如果勾选了运行用户使用Apple ID重设密码,那么开无法登陆系统时可尝试 Apple ID 找回密码。
参考链接1.mac系统登录密码对的但无法登录