webporter 是一个基于垂直爬虫框架 webmagic 的 Java 爬虫应用,旨在提供一套完整的数据爬取,持久化存储和可视化展示的实践样例。 webporter 寓意“我们不生产数据,我们只是互联网的搬运工~” 如果觉得不错,请先在这个仓库上点个 star 吧,这也是对我的肯定和鼓励,谢谢了。 目前只提供了知乎用户数据的爬虫示例。不定时进行调整和补充,需要关注更新的请 watch、star、fork
2024-11-14 07:46:55 66KB 爬虫 java
1
标题和描述中提到的"IEC/ISO 11172"和"IEC/ISO 13818"是两个国际标准,分别涉及音频编码和视频编码技术,对于理解和开发数字媒体处理系统至关重要。这些标准由国际电工委员会(IEC)和国际标准化组织(ISO)联合发布,用于规范数字音频和视频的压缩和传输,从而实现高效的数据存储和流媒体服务。 IEC/ISO 11172标准,通常被称为MPEG-1音频层,是在1994年制定的,主要关注音频编码。该标准定义了三个音频编码层(Layer 1、Layer 2和Layer 3),其中Layer 3就是我们熟知的MP3格式。它通过复杂的数学算法将音频数据进行有损压缩,以显著减小文件大小,同时保持可接受的音质。这个标准在CD音乐的数字化存储和网络传播中起到了重要作用。 而IEC/ISO 13818标准,又称为MPEG-2视频,同样于1994年发布,是一个更全面的多媒体编码标准,包括视频、音频、系统和一致性测试等多个部分。MPEG-2视频编码是DVD、有线电视和数字卫星电视等应用的基础,它允许在有限带宽下传输高质量的视频。13818标准的各个部分分别涵盖了不同的领域: 1. IEC/ISO 13818-1:这是核心规范,定义了MPEG-2视频的语法和解码过程。 2. IEC/ISO 13818-2:规定了MPEG-2音频的编码方法,包括多声道音频支持。 3. IEC/ISO 13818-3:涵盖了高级音频编码(AAC),是MPEG-2音频的一个扩展。 4. IEC/ISO 13818-4:描述了节目和系统信息处理,用于管理和传输多媒体内容。 5. IEC/ISO 13818-5:定义了数据流的封装格式,用于混合音频、视频和其他数据。 6. IEC/ISO 13818-6:涉及交互式服务,如电子节目指南(EPG)。 7. IEC/ISO 13818-7:定义了Advanced Audio Coding (AAC) 音频的系统部分。 8. IEC/ISO 13818-8:涵盖了MPEG-2视频的二进制流语法和解码。 9. IEC/ISO 13818-9:可能涉及到其他扩展或特定的应用。 从压缩包子文件的文件名称列表来看,包含了MPEG-1的部分文档(MPEG1_2.pdf和MPEG1_3.pdf)以及MPEG-2的多个部分(如13818-1到13818-9的PDF文档)。这些文档详细阐述了上述标准的具体技术细节,如编码算法、帧结构、错误检测与恢复机制等,是工程师和研究人员深入理解MPEG标准的重要参考资料。 总结来说,IEC/ISO 11172和13818标准代表了数字音频和视频编码的重要里程碑,它们推动了数字媒体产业的发展,使得高效存储和传输音频和视频成为可能。通过深入研究这些标准,我们可以了解其背后的编码原理,为现代多媒体技术如流媒体服务、高清电视和在线视频提供理论基础。
2024-11-13 21:56:08 6.31MB
1
标题中的“预瞄跟踪控制算法”是汽车动态控制系统中的一个重要概念,它涉及到车辆在行驶过程中的路径跟踪和稳定性。预瞄跟踪控制(Predictive Path Tracking Control)是一种先进的控制策略,其核心思想是根据车辆当前状态和未来可能的行驶路径,预测未来的车辆行为,并据此调整车辆的驾驶参数,如转向角或油门深度,以实现精确的路径跟踪。 描述中提到的“单点或多点驾驶员模型”是模拟驾驶员行为的不同方法。单点模型通常简化驾驶员为一个点,考虑其对车辆输入的影响,而多点模型则更复杂,可能包括驾驶员的身体各部位的动作以及视线等多方面的因素,以更真实地模拟驾驶行为。这里的“横制”可能指的是车辆横向动态控制,即车辆在侧向的稳定性和操控性。 “纯跟踪算法”是另一种路径跟踪控制策略,其目标是使车辆尽可能接近预定的行驶轨迹,通常通过优化控制器参数来实现最小误差跟踪。这种算法在自动驾驶和高级驾驶辅助系统(ADAS)中有着广泛应用。 “carsim和MATLAB Simulink联合仿真”意味着使用了两种强大的工具进行系统仿真。CarSim是一款专业的车辆动力学仿真软件,常用于车辆动态性能分析;MATLAB Simulink则是一个图形化建模环境,适合构建和仿真复杂的系统模型。将两者结合,可以创建出详尽的车辆控制系统模型,并进行实时仿真,以便测试和优化控制算法。 标签中的“matlab 算法 范文/模板/素材”表明提供的内容可能包含MATLAB编程的示例、算法实现模板或者相关研究素材,可以帮助学习者理解和应用预瞄跟踪控制算法。 压缩包内的文件可能是关于这个控制算法的详细解释、仿真步骤或者代码示例。"工程项目线上支持预瞄跟踪.html"可能是项目介绍或教程文档,"工程项目线上支持预瞄跟踪控制算.txt"可能是算法描述或代码片段,而"sorce"可能是一个源代码文件夹,包含了实际的MATLAB代码。 这个资料包提供了一个全面的学习资源,涵盖了预瞄跟踪控制算法的设计、驾驶员模型的建立、车辆横向控制的仿真,以及如何使用MATLAB和CarSim进行联合仿真。对于研究汽车控制系统的学者、工程师或是学生来说,这是一个非常有价值的学习材料。通过深入学习和实践,可以掌握高级的车辆动态控制技术,并提升在自动驾驶和汽车电子领域的能力。
2024-11-13 15:54:43 49KB matlab
1
文件名:ARPG Project v1.1.1.unitypackage ARPG Project 是一个专为 Unity 开发的角色扮演游戏(ARPG)框架,旨在为开发者提供一个全面的基础,以便快速构建和迭代他们的动作角色扮演游戏。该插件整合了多种功能和工具,使得游戏开发过程更加高效和灵活,适合各种风格的 ARPG 项目。 主要功能 角色控制: 提供全面的角色控制系统,包括移动、跳跃、攻击、技能释放等,支持多种输入方式(如键盘、手柄)。 战斗系统: 内置动态战斗机制,包括近战和远程攻击,技能冷却、组合攻击、状态效果等,支持丰富的战斗风格和策略。 技能系统: 开发者可以轻松创建和管理各种技能,支持技能树和升级机制,玩家可以根据个人风格定制角色能力。 敌人 AI: 包含基本的敌人 AI 行为系统,支持巡逻、追击、攻击、逃跑等多种行为模式,能够创建多样化的敌人挑战。 物品和装备系统: 提供物品管理系统,包括道具、装备、材料等,支持装备和物品的属性、效果和组合,方便玩家收集和使用。 任务和剧情系统: 集成任务管理功能,支持主线和支线任务,玩家可以通过完成任务来获得
2024-11-12 21:11:36 45.59MB Unity插件
1
在IT行业中,网络设备的配置是至关重要的环节,特别是对于企业级网络,交换机的配置直接决定了网络的稳定性和安全性。本文将详细讲解中兴交换机的配置流程和常用配置命令,以中兴ZXR10 2826E和3952为例。 1. **基础配置** - `enable` 命令用于进入特权模式,此时可以执行更高级别的配置。 - `adminpass` 用于设置管理员密码,确保设备安全。 - `hostname` 命令用于设置交换机的主机名,便于识别。 - `set date` 和 `set time` 用于设置日期和时间,有助于日志记录和故障排查。 2. **配置Telnet** - `create user` 创建用户账户,例如 `admin`,用于远程登录。 - `loginpass` 设置登录密码,保障远程访问的安全性。 - `line-vty timeout` 设置虚拟终端线路(VTY)超时时间,防止无人操作时资源被占用。 3. **配置路由** - `config router` 进入路由器配置模式。 - `set ipport` 配置接口IP地址和子网掩码。 - `set ipport vlan` 将接口绑定到特定VLAN。 - `set ipport enable` 开启接口。 - `iproute` 定义默认路由,即所有未匹配的流量都将通过指定的下一跳IP地址转发。 4. **配置VLAN** - `set vlan enable` 开启VLAN功能。 - `creat vlan` 创建VLAN,并可为其命名,方便管理。 5. **配置接口/端口信息** - `set vlan add port` 将端口添加到VLAN,untag表示该端口为接入端口,tag表示为中继端口。 - `set port pvid` 设置端口的PVID(Port VLAN ID),决定端口的默认VLAN。 6. **配置Spanning-Tree** - `set stp enable` 启用STP(Spanning Tree Protocol),防止环路。 - `set stp forceversion rstp` 设置为Rapid Spanning Tree Protocol,实现更快的收敛速度。 7. **保存配置信息** - `save config` 保存当前配置,确保重启后配置依然有效。 在中兴ZXR10 3952交换机中,配置流程略有不同,但基本原理相同: 1. **配置VLAN** 直接在全局模式下使用`vlan database`进入VLAN配置模式,然后创建并命名VLAN。 2. **配置基本信息** 修改主机名、设置启用密码、配置接口IP地址、设置默认路由和系统时间。 3. **配置Telnet** 创建用户,设置登录密码,以及VTY和控制台的超时时间。 4. **配置接口信息** 对于光口和电口,需要设置为trunk模式,并指定允许的VLAN。 以上就是中兴交换机的基本配置流程和命令,理解并熟练掌握这些配置对于管理和维护网络环境至关重要。在实际操作中,应根据具体网络需求灵活调整参数,确保网络的高效、安全运行。
2024-11-12 18:03:31 14KB 中兴交换机
1
Vcpkg 是一个开源的库管理系统,由微软开发并维护,专为简化 C 和 C++ 开发者在 Windows、Linux 和 macOS 上管理依赖库而设计。这个系统使得跨平台的库集成变得更加便捷,大大减轻了开发者手动配置和编译第三方库的工作负担。 ### Vcpkg 的核心功能 1. **跨平台支持**:Vcpkg 支持多种操作系统,包括 Windows(x86 和 x64)、Linux 以及 macOS。这使得开发者可以在不同的平台上统一管理库,降低了多平台开发的复杂性。 2. **广泛的库集合**:Vcpkg 包含了大量的 C 和 C++ 库,涵盖了各种领域,如图形处理、网络通信、数学算法、并发编程等。开发者可以通过简单的命令行接口来安装、升级或卸载所需的库。 3. **自动化构建**:Vcpkg 负责下载源代码、配置编译选项、执行编译和安装过程,极大地简化了库的构建流程。它支持多个编译器,如 Visual Studio、GCC 和 Clang。 4. **可扩展性**:如果 Vcpkg 中没有你需要的库,你可以编写自己的“portfile”来添加新库。Portfile 是一个描述如何获取、配置和构建特定库的脚本,这使得 Vcpkg 易于扩展和维护。 5. **版本控制**:Vcpkg 支持库的不同版本,允许你选择安装特定版本的库,这对于保持项目一致性或回滚到以前的稳定版本非常有用。 6. **依赖关系管理**:Vcpkg 自动处理库之间的依赖关系,确保所有必要的库都被正确地安装和链接,减少了手动解决依赖问题的时间。 7. **社区驱动**:Vcpkg 的发展得益于开放源代码社区的贡献,这意味着库的更新和改进会及时反映在 Vcpkg 中,保持其与最新技术同步。 ### 使用 Vcpkg 的步骤 1. **安装 Vcpkg**:你需要克隆 `vcpkg` 仓库(如 `vcpkg-master`),然后根据官方文档设置环境变量和路径。 2. **初始化 Vcpkg**:运行 `bootstrap-vcpkg.sh`(Linux 和 macOS)或 `bootstrap-vcpkg.bat`(Windows)以构建必要的工具。 3. **选择和安装库**:通过 `vcpkg install ` 命令来安装所需库,例如 `vcpkg install boost` 安装 Boost 库。 4. **配置项目**:安装完成后,Vcpkg 会在特定的目录下生成库的头文件和库文件。你需要在你的项目中配置这些路径,以便编译器能够找到它们。 5. **更新和管理库**:使用 `vcpkg update` 检查可用的库更新,`vcpkg upgrade` 更新已安装的库,`vcpkg remove ` 卸载不再需要的库。 ### Vcpkg 对开发者的益处 1. **提高效率**:通过自动化库的管理和构建,开发者可以更专注于实际的开发工作,而不是花费大量时间在配置环境上。 2. **增强项目的可移植性**:由于 Vcpkg 在多个平台上都可用,因此它有助于保证项目在不同操作系统上的兼容性。 3. **减少错误**:手动管理库时容易出错,而 Vcpkg 通过自动处理依赖关系和构建过程,降低了出错的可能性。 4. **简化持续集成**:在 CI/CD 环境中,Vcpkg 可以快速、一致地设置和更新库,提高了构建的可靠性和速度。 Vcpkg 是一个强大且实用的工具,它为 C 和 C++ 开发者提供了一种标准化和高效的方式来管理库,促进了跨平台开发的便利性。通过学习和熟练使用 Vcpkg,开发者可以大大提高生产力,同时确保项目能够利用最新的库功能和安全修复。
2024-11-11 10:53:03 6.23MB vcpkg
1
电工技术基础和技能课程标准.doc
2024-11-08 12:10:04 224KB
1
卷积和全连接神经网络实现手写数字识别 本文档介绍了使用卷积神经网络和全连接神经网络实现手写数字识别的方法。文档中首先介绍了实验的内容和实验原理,然后详细讲解了全连接神经网络和卷积神经网络的原理和结构。文档还提供了实验步骤,指导读者如何使用 Keras 实现手写数字识别。 一、实验内容 本实验的目的是使用 Keras 实现手写数字识别。实验中,我们将使用 MNIST 数据集,该数据集包含 60000 张手写数字图片,每张图片的大小是 28x28 个像素点。我们将使用全连接神经网络和卷积神经网络两种方法来实现手写数字识别。 二、实验原理 ### 2.1 数据集 MNIST 数据集是手写数字识别的常用数据集。每张图片由 28x28 个像素点构成,每个像素点用一个灰度值表示。可以将这 28x28 个像素展开为一个一维的行向量,作为输入,也就是有 784x1 的向量。 ### 2.2 神经元 人工神经网络(ANN,Artificial Neuron Network)是模拟生物大脑的神经网络结构,它是由许多称为人工神经细胞(Artificial Neuron,也称人工神经元)的细小结构单元组成。简易模型如下所示: x1 … xn:表示神经细胞的输入,也就是输入神经细胞的信号。 w1 … wn:表示每个输入的权重,就好比生物神经网络中每个轴突和树突的连接的粗细,强弱的差异。 b:偏置权重 threshold:偏置(可以将 threshold * b 看作是前面提到的生物神经细胞的阈值) 蓝色部分:细胞体。 黄色球形是所有输入信号以的求和。 红色部分是表示求和之后的信号的激励函数(即达到阈值就处于兴奋状态,反之抑制,当然作为人工神经细胞,其激励函数很多,阶跃(型)激励函数,sigmoid(s 型)激励函数,双曲正切(tanh)激励函数,ReLu(Rectified Linear Units)激励函数等等) ### 2.3 全连接神经网络 全连接神经网络模型是一种多层感知机(MLP),感知机的原理是寻找类别间最合理、最具有鲁棒性的超平面,感知机最具代表的是 SVM 支持向量机算法。神经网络同时借鉴了感知机和仿生学,神经元接受一个信号后会发送各个神经元,各个神经元接受输入后根据自身判断,激活产生输出信号后汇总从而实现对信息源实现识别、分类。 包含两个隐藏层的神经元网络结构如下: 每个结点和下一层所有几点都有运算关系,实践中全连接神经网络通常有多个隐藏层,增加隐藏层可以更好的分离数据的特征,但过多的隐藏层也会增加训练时间以及会产生过拟合。 训练神经网络中需要使用 bp 算法,先是通过前向传播,得到预测结果,再反向传播去调整模型权重。反向传播:反向传播根据前向传播产生的损失函数值,沿输出端向至输入端优化每层之间参数,在此过程中运算利用梯度下降法优化参数,神经网络求解参数本质上仍然是规则中求最优解问题,现在的机器学习框架如 Tensorflow、pytorch、keras 将梯度下降法、Booting、Bagging 这些优化中常用技巧封装起来,我们只用关注数据建模即可。 ### 2.4 卷积神经网络 卷积神经网络可以利用空间结构关系减少需要学习的参数量,提高反向传播算法的训练效率。一般的 CNN 有多个卷积层构成,每个卷积层会进行如下操作: 图像通过多个不同的卷积核的滤波,并加偏置(bias),提取出局部特征,每一个卷积核会映射出一个新的 2D 图像。将前面卷积核的滤波输出结果进行非线性的激活函数处理。对激活函数的结果再进行池化操作(即降采样),目前一般是使用最大池化,保留最显著的特征,并提升模型的畸变容忍能力。 这几个步骤就构成最常见的卷积层,当然也可以在加上一个 LRN 层(Local Response Normalization,局部响应归一化层)。 CNN 的要点是卷积核的权值共享(Weight Sharing)、局部连接模式(Local Connection)和池化层(Pooling)中的降采样(Down-Sampling)。局部连接和权值共享降低了参数量,使训练复杂度大大下降,减轻过拟合并降低计算量。同时权值共享还赋予了 CNN 对平移的容忍性,而池化层降采样则进一步降低了输出层参数,并赋予模型轻度形变的容忍性,提高模型的泛化能力。 每个卷基层包含三个部分:卷积、池化和非线性激活函数使用卷积提取空间特征降采样的平均池化层、双曲正切或 S 型的激活函数、MLP 作为最后的分类器层与层之间的稀疏连接减少计算复杂度。 三、实验步骤 ### 3.1 全连接神经网络实现 1. 获取数据集 Keras 中集成了 MNIST 数据集,直接从其中导入数据,并对数据进行整理。从之可以看出,数据为 28*28,一共 60000 张。 2. 对数据集中的数据进行可视化 3. 对数据进行维度转换把每一张 28 x 28 的图片分别转为长度为 784 的向量,再合并成一个大的像素矩阵,每个维度表示一个像素点的灰度值/255。 4. 对输出结果进行格式转化将经过神经网络训练完后的内容,转化为 10 个类别的概率分布。 本文档介绍了使用卷积神经网络和全连接神经网络实现手写数字识别的方法。使用 Keras 实现手写数字识别可以使用 MNIST 数据集,并使用全连接神经网络和卷积神经网络两种方法来实现手写数字识别。
1
LitJSON.dll和websocket-sharp.dll
2024-11-06 15:24:18 132KB
1
HMC7044 是一款高性能时钟发生器芯片。 一、芯片配置 电源连接:确保正确连接芯片的电源引脚,包括 VDD 和 GND。通常需要稳定的电源供应以保证芯片正常工作。 输入时钟:根据设计需求,将合适的参考时钟信号连接到芯片的输入时钟引脚。输入时钟的频率和特性应符合芯片的规格要求。 控制接口:HMC7044 通常提供多种控制接口,如 SPI(Serial Peripheral Interface)或 I2C(Inter-Integrated Circuit)。通过这些接口,可以对芯片进行配置和控制。 SPI 配置:连接 SPI 总线的时钟、数据输入和数据输出引脚到相应的微控制器或控制电路。根据芯片的数据手册,了解 SPI 通信协议和寄存器地址,以便进行正确的配置。 I2C 配置:连接 I2C 总线的时钟线和数据线到微控制器或其他 I2C 主控设备。使用合适的 I2C 地址和命令来配置芯片的功能。 输出配置:根据应用需求,配置芯片的输出时钟参数,如频率、相位、占空比等。可以通过控制寄存器来设置这些参数。 二、使用说明 初始化:在使用 HMC7044 之前,需要进行初始化操作。这包括设置控制
2024-11-06 09:35:52 6.31MB FPGA
1