CMU2024暑期夏令营总结
省流版
以下是我把 项目方给的材料+我的每日总结+我的课堂笔记 喂给GPT生成的总结:
我非常荣幸能够在这个暑假参与卡内基梅隆大学(CMU)的"深度视觉与人工智能:探索视界未来"国际交流项目,这是一个独特的机会,让我深入了解了人工智能领域的前沿技术。该项目为期一个月,包括两周的线上预学习以及两周的线下课堂和文化体验。这次经历不仅让我提升了对深度学习和计算机视觉的认识,也让我有机会与来自全球的教授进行学术交流。
项目期间,课程内容涵盖了多个前沿主题,包括深度学习的基础理论、计算机视觉和3D视觉的最新研究进展。特别是Shubham Tulsiani教授的课程让我对3D视觉有了更深入的理解,学习了深度图、点云、网格等不同的表面表示方法,以及体素网格和隐函数等体积表示。课程还介绍了pinhole摄像机模型和齐次坐标等相关概念。我还学习了Retrival Augmented Generation (RAG) 模型和向量数据库的相关内容。RAG模型通过检索相关文档来增强生成式模型的回答能力,而向量数据库则在其中扮演了关键角色,能够进行嵌入的计算和比较。我们还学习了Hierarc ...
CTF101-安全攻防实践
课程主页:https://courses.zjusec.com/
课程简介
报名
这是一门短学期课程,报名需要提交一份Lab0实验报告或个人简历。提交Lab0的话只需要完成Prerequisite部分以及Misc, Reverse, Pwn, Web, Crypto部分五选一。但无论选择什么,上课之后最终都要把Lab0的五个方向做完,因为Lab0是课程的第一次作业,占5%。
授课教师
授课教师基本都是来自AAA的学长们,都非常牛而且人很好。
分数占比
考勤:5%
Lab0:5%
Lab1: 10% * 5 = 50%
Lab2、Lab3: 10% * 2 * 2 = 40%
基本上每一个Lab都有Bonus,只能溢出到同一个周的Lab里。
学长们给分都很捞,再加上有Bonus,拿满还是不难的:
课程
课程时长共两周,第一周是导论部分,五个方向都需要上并完成相应的Lab1,第二周是专题部分,可以选择两个专题上课并完成这两个方向的Lab2、Lab3。
基本内容
课程分为Misc, Reverse, Pwn, Web, Crypto五个方向。
这是一门实操大于理论的课程,做的笔记参考价值 ...
修复Windows的智能多宿主解析造成sing-box TUN模式出现DNS泄露
问题
最近使用sing-box的TUN模式进行网络代理的时候遇到了一个坑。具体表现为,当设置"strict_route": false时,WSL网络正常,宿主机浏览器访问google.com却返回*.facebook.com的证书,经查发现这是经典的DNS污染。然而我设置的分流策略中google.com是走远程DNS的,理论上不应该出现这个问题:
12345678910111213141516171819202122232425"dns": { "servers": [ { "tag": "dns-direct", "address": "dhcp://auto", "detour": "out-direct" }, { "tag": " ...
CS231n/EECS598 学习笔记(三)
Lecture 8
AlexNet (2012)
AlexNet是一个非常有影响力的卷积神经网络,Google Scholar显示,其原论文的引用已经达到了惊人的160203次。
AlexNet的结构就是(conv + [pool]) * 5 + (fc + dropout) * 3,随着层数的增加,图片的长宽不断减少,而通道数不断增多。当通道数达到一定数量时,它们会flatten后作为特征输入全连接神经网络中。
分析内存使用和参数量,可以发现AlexNet有趣的特征,随层数增加,内存占用变少,而参数量增多,即所有内存基本都在前面的卷积层,所有参数量基本都在后面的全连接层。
ZFNet (2013)
ZFNet基本上就是一个更大的AlexNet,但是其基本结构依然是相同的,前面是卷积层和池化层,后面是全连接层。
VGG (2014)
AlexNet和ZFNet的网络结构参数,即卷积核形状, 每层通道数,池化层形状,都是通过尝试人工设置出来的。这让网络的scale up变得困难。VGG提出了一种系统的卷积神经网络设计方法:
所有卷积层都是3x3, 步长为1, 填充为1:两个3x3的卷 ...
Softmax和交叉熵
Softmax 是一种机器学习中常用的归一化函数。我们可以从它的名字来理解其含义。
Softmax 和普通的max 函数不同,它更加“软”,max 函数给出一组数据中唯一的最
大值,而Softmax 则会将向量归一化,归一化后的向量就可以视作一组概率分布,具
有实际意义。Softmax 中的指数的性质使输入中越大的数值对应越大的概率,并拉开
差距,让最大值显得更加突出。
FPGA流水线设计的策略(翻译)
FPGA流水线设计的策略
发现一篇非常好的讲FPGA中流水线设计的文章,搬运并翻译一下。
本文是https://zipcpu.com/blog/2017/08/14/strategies-for-pipelining.html的中文翻译。
学习FPGA的学生常常面临一个棘手的问题,FPGA中所有而事情都是并行发生的。
许多同学来自计算机科学专业,他们理解算法如何工作,一个操作需要在另一个操作之后顺序执行。他们很难理解算法中的每一步都对应着一块逻辑电路,需要在相应的时钟周期执行——无论是否使用。
解决操作顺序的一个方法是创建一个巨大的状态机。FPGA往往会同时创建所有状态的逻辑,并且仅在每个时周期结束的时候选择正确的答案。因此,状态机可以非常想我们讨论过的简单的多ALU(算术逻辑单元)。
另一方面,如果FPGA无论如何都会实现操作的所有逻辑,那么为什么不讲这些操作安排成一个序列,每个阶段都做一些有用的事情呢?这种方法将算法重新排列为流水线。流水线往往比状态机方法更快速完成相同的算法,甚至在资源利用方面有时也更高效,尽管这不一定。
数字逻辑流水线的难点在于,即使流水线的输入尚未有效,流水线 ...
线性空间到底是什么?能不能用一句话定义线性空间?为什么线性空间一定有基?
线性空间到底是什么?
我们在学习线性代数的时候,通常见到的线性空间是由以下八个条件共同定义的:
设KKK是一个数域,VVV是一个非空集合,同时还定义了:
向量加法:+:V×V→V+: V \times V \rightarrow V+:V×V→V
标量乘法:⋅:K×V→V\cdot: K \times V \rightarrow V⋅:K×V→V(⋅\cdot⋅也可省略)
且两种运算满足以下八条:
则成VVV是定义在KKK上的线性空间,又称向量空间。
向量加法单位元存在:存在θ∈K\theta \in Kθ∈K使得α+θ=α,α∈V\alpha + \theta = \alpha, \quad \alpha \in Vα+θ=α,α∈V,称θ\thetaθ为KKK的零元素,即向量加法的单位元。
向量加法逆元存在:存在∀α∈V,∃β∈V\forall \alpha \in V, \exists \beta \in V∀α∈V,∃β∈V使得α+β=θ\alpha + \beta = \thetaα+β=θ,称β\betaβ为VVV的负元素,即向量加法的逆元。
向量加法结合律:(α+β ...
基于FPGA的魔塔游戏
这是浙江大学2024春夏数字逻辑设计的课程设计,我们小组基于FPGA制作了一个魔塔游戏。视频演示:
https://www.bilibili.com/video/BV1i9gkeAEEk/
其中,本人主要负责代码的编写,包括时钟控制模块、VGA模块、地图渲染、数字渲染、地图交互、COE文件生成脚本、地图编辑器、Vivado TCL脚本等。
开发环境使用Vivado,利用Vivado TCL脚本 + git来管理和协作开发。
VGA模块我编写的时候使用了一个RAM映射到VGA输出,这样其他模块可以通过写RAM来渲染,实现解耦合和其他的一些好处。没有采用给的参考代码里输出x, y输入color的方法。
主要的逻辑并不复杂,当相应的移动按键被按下之后,会生成一个预移动信号,检测移动目标位置是否符合特定规则(如目标为门且钥匙足够,目标为怪物且生命值足够等),如果符合规则,则会生成一个移动信号,更新人物坐标,否则保持原地不动。
开发过程中发现自己对时序逻辑的理解还不够深,经常出现仿真/下板结果和预期不符合,需要反复下板验证,由于项目到后期之后生成比特流的速度变得非常慢,制约了开发的速度。(该死 ...
Diffie–Hellman密钥交换以及OpenSSL中相关源码解析
什么是 Diffie–Hellman 密钥交换?
Diffie-Hellman是一种密钥交换方法,可以让双方从不安全信道中建立一个共同的密钥来加密通讯内容。
DH方法本身很简单,但它却是许多现代安全协议的基础,如TLS安全传输层协议,安全外壳协议以及IPSec互联网安全协议,都部分使用到了DH算法。
Diffie–Hellman 密钥交换的过程
Diffie-Hellman密钥交换的过程如下:
双方协定一个质数ppp和基数ggg。这两个数无需保密,可以随意协商或传输。
Alice生成一个随机数aaa,并计算 A=gamod pA=g^a \mod{p}A=gamodp 。
Bob生成一个随机数bbb,并计算B=gb(modp)B=g^b\pmod{p}B=gb(modp)。
Alice发送AAA给Bob。
Bob发送BBB给Alice。
Alice计算s=Ba(modp)s=B^a\pmod{p}s=Ba(modp)
Bob计算s=Ab(modp)s=A^b\pmod{p}s=Ab(modp)
由于 (ga)b≡gab≡(gb)a{(g^a)}^b \equiv g^{ab} ...
一种计算纯电阻网络等效电阻的算法
引入
我们早就学过了计算串并联电阻的等效电阻的公式:
针对混合的电阻网络,有些时候我们依然可以反复运用这两个公式来计算等效电阻。在有些电阻网络中,这样是无法得到答案的:
如果你熟悉星三角变换,你应该能很快算出答案。(或者你能看出这就是一个平衡桥,那就能口算了)
星三角变换固然是一种手工计算等效电阻的很好方法,但是对于计算机而言,利用这个方法计算电阻会很麻烦。下面,我将使用高斯消元法来计算两点之间的等效电阻。
建模
我们可以把两点之间的纯电阻网络看作是一张有向图,节点表示导线,边表示电阻,边权表示电阻的大小。要求源点和汇点之间的等效电阻大小。
为什么要建成有向边呢,因为虽然电阻是无向的,但是电流是有向的,我们一开始并不知道电流的方向,但是可以任意地假定一个方向,然后给每一条边赋上一个电流IiI_iIi,当IiI_iIi为正,表示电流方向与箭头同向,当IiI_iIi为负,表示电流方向与箭头反向。然后我们再假定汇点的电势为000,其余每个节点赋上一个电势φi\varphi_iφi。
若要求源点到汇点的等效电阻,只需要知道源点的电势φs\varphi_sφs和汇点的电势φt\ ...