@echo off echo Delete HKEY_CURRENT_USER\Software\PremiumSoft\Data for /f %%i in ('"REG QUERY "HKEY_CURRENT_USER\Software\PremiumSoft\Data" /s | findstr /E Info"') do ( reg delete %%i /va /f ) echo. echo Delete Info folder under HKEY_CURRENT_USER\Software\Classes\CLSID for /f %%i in ('"REG QUERY "HKEY_CURRENT_USER\Software\Classes\CLSID" /s | findstr /E Info"') do ( reg delete %%i /va /f ) echo. echo Finish pause
目录 什么是Typora?
现状况:
Typora使用:
什么是Typora? 在介绍Typora软件之前,需要先介绍一下MARKDOWN。MARKDOWN是一种轻量型标记语言,它具有“极简主义”、高效、清晰、易读、易写、易更改纯文本的特点。
Typora 是一款支持实时预览的 Markdown 文本编辑器。它有 OS X、Windows、Linux 三个平台的版本,并且由于仍在测试中,是完全免费的。
Typora 首先是一个 Markdown 文本编辑器,它支持且仅支持 Markdown 语法的文本编辑,但是他还有很多实用的扩展语法与自定义样式的功能,还可以把.md文件导出成多种文件,如.pdf,.html,.docx。
但是现在Typora已经发布正式版且不再免费,需要付费使用了,网站为Typora 官方中文站。
博主本人肯定还是支持正版的,奈何生活拮据不能做一个正版人士。所以现在用的还是低版本的Typora了。博主现在用的Typora版本号为0.9.78,下载安装后切记不再更新。如果有需要的可以私信找我领取安装包,或者评论留言,我看到的第一时间就会回复的。
现状况: Typora 目前采用买断制,价格为 14.99 美元/89 元人民币,支持 macOS、Windows、Windows(ARM)、Linux 系统,最多可在 3 台设备上使用, 还提供 15 天的免费试用。
Typora使用: Typora支持主题切换,不同风格的主题会有不一样的显示效果。具体使用哪种主题还是看个人喜好来定。
首先,我们写文本的时候大多写的是中文,可是输入法在输中文时使用的标点为全角标点如,。? ! ( ) [ ] : ; 这些标点是不被Markdown 所认可的,也是无法转义的。
我建议大家写 Markdown 的时候都用半角标点,即英文标点,如,] : ; " ” 且每个半角标点在文本使用时加上后置空格,符合英文标点的书写规范,也更加美观.
一、二分法的原理 二分法查找针对的是一个有序的数据集合,每次通过与区间的中间元素对比,将待查找的区间缩小为之前的一半,直到找到要查找的元素,或者区间被缩小为0.
故时间复杂度就是O(logn)
二、非递归实现 1、二分查找非递归实现
第一种写法,我们定义 target 是在一个在左闭右闭的区间里,也就是[Left, Right] 1、循环退出的条件
注意这里要写成Left<= Right,而不是Left< Right,因为当Left==Right,区间[Left, Right]依然有效,比如区间[2, 2],这里还有一个值2。只有Left +1 > Right,比如[2,3],while循环才退出
2、Left与Right的赋值
if (nums[middle] > target) Right要赋值为 middle - 1,因为当前这个nums[middle]一定不是target,那么接下来要查找下个位置就是 middle - 1,同理Left要赋值为 middle + 1
3、middle的取值
如果写成 middle= (Left+Right)/2是有问题的,数字较大就可能溢出,计算机位运算比除法快,故可改成low+((high-low)>>1)
class Solution { public: int search(vector<int>& nums, int target) { int left = 0; int right = nums.size() - 1; // 定义target在左闭右闭的区间里,[left, right] while (left <= right) { // 当left==right,区间[left, right]依然有效,所以用 <= int middle = left + ((right - left) >> 1 );// 防止溢出 等同于(left + right)/2 if (nums[middle] > target) { right = middle - 1; // target 在左区间,所以[left, middle - 1] } else if (nums[middle] < target) { left = middle + 1; // target 在右区间,所以[middle + 1, right] } else // (nums[middle] == target) return middle; // 数组中找到目标值,直接返回下标 } } // 未找到目标值 return -1; } }; 第二种写法:
因为数据库的数据信息建于12年,很多地区三级关系和名称都跟不上了,让我手动一个个添加又觉得麻烦,怎么说我也是一个码农而不是文员,上代码:
#! /usr/bin/env python
# coding=utf-8
import requests
from lxml import etree
import sys
import xlwt
import re
import copy
import json
from lxml.html import fromstring,tostring
import HTMLParser
import re
#初始化
reload(sys)
sys.setdefaultencoding('utf8')
#根据网页源码,匹配并返回源码内指定的整个a标签
def get_content(data,str,num=999):
content = []
data1 = etree.HTML(data).xpath(str)
i = 0
for x in data1:
i += 1
#如果大于指定的数,就跳出循环
if i>num:
continue;
content.append(HTMLParser.HTMLParser().unescape(tostring(x)))
#删除第一次获取数据时,多余的第一第二个数据
if num == 36:
del content[0],content[0]
return content
#根据网站首页的编码,获取各个省的链接,并且返回三级地区的所有a标签
def get_url(url):
文章目录 0 概述1 打开软件2 新建工程3 STM32CubeMX配置MCU4 LED闪烁代码编写,编译及烧录5 实验现象 0 概述 本文主要通过新建LED控制工程来简要介绍STM32CubeIDE的简单使用方法
1 打开软件 双击桌面快捷方式或者通过Start目录打开软件
在弹出的界面中选择Workspace地址
本人理解此workspace是软件的工作空间,存放软件配置的一些文件
2 新建工程 点击新建工程图标或者在菜单栏中选择新建工程
弹出加载界面等待完成即可
按下图方式选择MCU型号
输入工程名,并按下图配置
在弹出的窗口中点击yes跳转到STM32CubeMX可视化芯片配置界面
3 STM32CubeMX配置MCU 配置界面1
界面1配置调试接口(根据需求配置即可,可不配)
界面1配置时钟(根据需求配置即可)
界面1配置LED对应的芯片管脚模式
界面1配置LED对应的芯片管脚属性
(我这里配置了3个LED,配置完效果如下)
界面2配置时钟(根据需求进行配置即可)
界面3配置默认文件放置类型(根据需求进行配置即可,可不配)
配置完成,在菜单栏中选择生成代码,如下图
在弹出的窗口中点击yes,开始生成代码
成功生成代码后界面如下
4 LED闪烁代码编写,编译及烧录 按下图方式编写LED控制对应代码
按照下面3种方式之一编译代码
编译成功显示如下
按照下面方式下载(第一次要进行下载器配置)
第一次下载需要配置下载器,在配置界面配置下载方式(按照实际下载方式配置即可)
出现如下界面信息即下载成功
5 实验现象 下载完程序后即完成操作,附我实现的结果如下:
结果视频
Git分支 Git 的分支,其实本质上仅仅是指向提交对象的可变指针。 Git 的默认分支名字是 master。 在多次提交操作之后,你其实已经有一个指向最后那个提交对象的 master 分支。 master 分支会在每次提交时自动向前移动。
同时并行推进多个功能开发,提高开发效率
各个分支在开发过程中,如果某一个分支开发失败,不会对其他分支有任何影响。失败的分支删除重新开始即可。
分支操作 创建分支(git branch) 创建分支即创建了一个可以移动的新的指针。 比如,创建一个 testing 分支, 你需要使用 git branch 命令:
git branch [分支名] git branch testing 查看分支(git branch -v) git branch -v 切换分支(git checkout) git checkout [分支名] $ git checkout testing 这样 HEAD 就指向 testing 分支了 通常我们会在创建一个新分支后立即切换过去,这可以用一条命令搞定。 $ git checkout -b <newbranchname> 相当下面两条: $ git branch testing $ git checkout testing 合并分支(git merge) 第一步:切换到接受修改的分支(被合并,增加新内容)上
从零开始的图像语义分割:FCN复现教程(Pytorch+CityScapes数据集) 前言一、图像分割开山之作FCN二、代码及数据集获取1.源项目代码2.CityScapes数据集 三、代码复现1.数据预处理2.代码修改3.运行结果 总结参考网站 前言 摆了两周,突然觉得不能一直再颓废下去了,应该利用好时间,并且上个月就读了一些经典的图像分割论文比如FCN、UNet和Mask R-CNN,但仅仅只是读了论文并且大概了解了图像分割是在做什么任务的,于是今天就拉动手复现一下,因为只有代码运行起来了,才能进行接下来的代码阅读以及其他改进迁移等后续工作。
本文着重在于代码的复现,其他相关知识会涉及得较少,需要读者自行了解。
看完这篇文章,您将收获一个完整的图像分割项目(一个通用的图像分割数据集及一份可正常执行的代码)。
一、图像分割开山之作FCN 图来自FCN,Jonathan Long,Evan Shelhamer,Trevor Darrell CVPR2015
图像分割可以大致为实例分割、语义分割,其中语义分割(Semantic Segmentation)是对图像中每一个像素点进行分类,确定每个点的类别(如属于背景、人或车等),从而进行区域划分。目前,语义分割已经被广泛应用于自动驾驶、无人机落点判定等场景中。
FCN全程Fully Convolutional Networks,最早发表于CVPR2015,原论文链接如下:
FCN论文链接:https://arxiv.org/abs/1411.4038
正如其名称全卷积网络,实则是将早年的网络比如VGG的全连接层代替为卷积层,这样做的目的是让模型可以输入不同尺寸的图像,因为全连接层一旦被创建输入输出维度都是固定的,追根溯源就是输入图片的尺寸固定,并且语义分割是像素级别操作,替换为卷积层也更加合理(卷积操作就是像素级别,这些都是后话了)。
更具体的学习视频可以跳转到b站FCN网络结构详解(语义分割)
二、代码及数据集获取 1.源项目代码 进入FCN论文链接,点击Code&Data再进入Community Code跳转到paperwithcode网站。
很神奇地是会发现有两个FCN的检索链接,本文所需要的pytorch项目代码在红框这个链接中
Star最高的就是本文所需项目,这个大佬还有自己的个人网页,而且号称是FCN最简单的实现,我可以作证此言不虚,的确是众多代码中最简洁明朗的。
2.CityScapes数据集 CityScapes数据集官方下载链接:CityScapes Download
然而下载这个数据集需要注册账号,而且需要的是教育邮箱,可能是按照是否带edu.cn域名判断的吧,本人使用学校邮箱成功注册下载了数据集。读者若有不便可以上网其他途径获取或淘宝买个账号。
只需下载前3个数据集即可,gtFine_trainvaltest是精确标注(最主要最关键部分),gtCoarse是粗略标注,leftimg8bit_trainvaltest是原图。虽然模型训练的时候只需要用到gtFine但是因为接下来还需要预处理数据集,因此要将三个数据集下载好,才能执行官方给的预处理代码。
重构数据集
将三个zip解压然后新建一个文件夹命名为CityScapes,然后将三个解压文件里的内容按上图目录放置好,为数据集预处理做准备。
三、代码复现 1.数据预处理 这里需要先下载官方的脚本:cityscapesScripts
接下来对其中的一些地方进行修改,最重要的两个文件为项目下cityscapesscripts\helpers\labels.py和cityscapesscripts\preparation\createTrainIdLabelImgs.py。
蓝色框为原本的代码,直接注释掉添加红框处代码,即指定自己本地的数据集目录,比如我就将CityScapes放到了E盘的dataset目录下。
然后是在label.py文件里按照训练的需要更改trainid,255为不被模型所需要的id,因为FCN中为19类+背景板,所以为20类,刚好符合所以不需要更改label文件中任何内容。
最后运行createTrainIdLabelImgs.py,如果报错的话大概率是因为缺少上图蓝框所示的库,将其直接注释掉就可以了。
2.代码修改 之所以需要修改是因为原本的代码里面数据预处理那块太慢了,Cityscapes_utils.py要将trainId写入npy文件,运行速度极慢,这也是先前用官方预处理脚本cityscapesScripts来预处理的原因,预处理的目的其实也只是生成TrainIds的mask图片,和labelIds的png图片是同理的,只是每个像素所对应类别按照label.py里面的label表进行改变。
其实pytorch官方有给出加载CityScapes的数据集代码,但其直接拿来用并不能满足我们要求,所以需要修改一下,就原项目代码的Cityscapes_loader.py和torchvision.datasets.Cityscapes的代码结合,得到如下可执行代码。读者只需用其替换train.py文件即可。
# -*- coding: utf-8 -*- # Author: Reganzhx from __future__ import print_function import random from tqdm import tqdm # 由于训练缓慢,添加进度条方便观察 import imageio import torch import torch.
function getViewportSize() { //可视区域的宽度和高度 return { width: document.documentElement.clientWidth, height: document.documentElement.clientHeight }; } class LayerMove { /** * 弹层移动 * @param $setCanMoveAreaName 鼠标点击哪个区域可以移动容器 * @param $moveContainerName 要移动的容器 */ static execute($setCanMoveAreaName, $moveContainerName, $iframe) { let viewport = getViewportSize(); $setCanMoveAreaName.mousedown(function (e) { e.stopPropagation(); e.preventDefault(); let x = e.clientX - $moveContainerName.offset().left; let y = e.clientY - $moveContainerName.offset().top; $(`#${$iframe}`).find('iframe')[0].contentWindow.init(x, y); $(document).mousemove(function (e) { let left = e.clientX - x; let top = e.clientY - y; let currentLeft = viewport.
如果按照文档从git上拉下代码后安装依赖一定会报错的,因为package.json中的"tui-editor": "1.3.3"依赖改名字了
目前有两种解决方案,一种是直接把相关的页面和依赖删除,参考:vue-element-admin安装依赖报错--解决 - Private! - 博客园
这个依赖主要是解决富文本的问题,还有一种方法是安装更改名字后的版本
参考:npm或cnpm install 安装tui-editor报错解决方案,亲测有效 _ 潘子夜个人博客
这样依赖就安装好了,运行npm run dev可能还会有一个问题就是core.js模块报错,这个手动
npm install core-js -s就可以解决
还不能运行的话应该是python没装
文章目录 1 前言1 课题背景2 实现效果3 项目实现3.1 概述3.2 数据采集3.3 数据清洗与预处理 4 数据分析与可视化Flask框架介绍 5 最后 1 前言 🔥 Hi,大家好,这里是丹成学长的毕设系列文章!
🔥 对毕设有任何疑问都可以问学长哦!
这两年开始,各个学校对毕设的要求越来越高,难度也越来越大… 毕业设计耗费时间,耗费精力,甚至有些题目即使是专业的老师或者硕士生也需要很长时间,所以一旦发现问题,一定要提前准备,避免到后面措手不及,草草了事。
为了大家能够顺利以及最少的精力通过毕设,学长分享优质毕业设计项目,今天要分享的新项目是
🚩 大数据招聘岗位数据分析与可视化 - 爬虫 python 大屏可视化
🥇学长这里给一个题目综合评分(每项满分5分)
难度系数:4分工作量:4分创新点:3分 🧿 选题指导, 项目分享:
https://gitee.com/yaa-dc/BJH/blob/master/gg/cc/README.md
1 课题背景 随着科技的飞速发展,数据呈现爆发式的增长,任何人都摆脱不了与数据打交道,社会对于“数据”方面的人才需求也在不断增大。因此了解当下企业究竟需要招聘什么样的人才?需要什么样的技能?不管是对于在校生,还是对于求职者来说,都显得很有必要。
本文基于这个问题,针对 boss 直聘网站,使用 Scrapy 框架爬取了全国热门城市大数据、数据分析、数据挖掘、机器学习、人工智能等相关岗位的招聘信息。分析比较了不同岗位的薪资、学历要求;分析比较了不同区域、行业对相关人才的需求情况;分析比较了不同岗位的知识、技能要求等。
2 实现效果 岗位情况分析可视化
3 项目实现 3.1 概述 该项目一共分为三个子任务完成,数据采集—数据预处理—数据分析/可视化。
项目流程图
项目架构图
3.2 数据采集 Scrapy 爬虫介绍
Scrapy是基于Twisted的爬虫框架,它可以从各种数据源中抓取数据。其架构清晰,模块之间的耦合度低,扩展性极强,爬取效率高,可以灵活完成各种需求。能够方便地用来处理绝大多数反爬网站,是目前Python中应用最广泛的爬虫框架。Scrapy框架主要由五大组件组成,它们分别是调度器(Scheduler)、下载器(Downloader)、爬虫(Spider)和实体管道(Item Pipeline)、Scrapy引擎(Scrapy Engine)。各个组件的作用如下:
调度器(Scheduler):说白了把它假设成为一个URL(抓取网页的网址或者说是链接)的优先队列,由它来决定下一个要抓取的网址是 什么,同时去除重复的网址(不做无用功)。用户可以自己的需求定制调度器。
下载器(Downloader):是所有组件中负担最大的,它用于高速地下载网络上的资源。Scrapy的下载器代码不会太复杂,但效率高,主要的原因是Scrapy下载器是建立在twisted这个高效的异步模型上的(其实整个框架都在建立在这个模型上的)。
爬虫(Spider):是用户最关心的部份。用户定制自己的爬虫(通过定制正则表达式等语法),用于从特定的网页中提取自己需要的信息,即所谓的实体(Item)。 用户也可以从中提取出链接,让Scrapy继续抓取下一个页面。
实体管道(Item Pipeline):用于处理爬虫(spider)提取的实体。主要的功能是持久化实体、验证实体的有效性、清除不需要的信息。
Scrapy引擎(Scrapy Engine):Scrapy引擎是整个框架的核心.它用来控制调试器、下载器、爬虫。实际上,引擎相当于计算机的CPU,它控制着整个流程。
Scrapy 官网架构图
文章目录 效果图关键代码源码地址 效果图 RecyclerView是谷歌推出的融合了ListView和GridView且功能更加强大组件,可以在有限的屏幕上显示更多内容,支持三种不同布局:线性LinearLayoutManager、网格GridLayoutManager、瀑布流StaggeredGridLayoutManager。此外,RecyclerView的复用机制是它的核心部分。线性布局的示例如下:
关键代码 class MainActivity : AppCompatActivity() { override fun onCreate(savedInstanceState: Bundle?) { super.onCreate(savedInstanceState) setContentView(R.layout.activity_main) val recyclerView = findViewById<RecyclerView>(R.id.recyclerView) val layoutManager: RecyclerView.LayoutManager = LinearLayoutManager(this) recyclerView.layoutManager = layoutManager val dataSet = arrayOf("one", "two", "three", "four", "five") val recyclerViewAdapter: RecyclerView.Adapter<*> = RecyclerViewAdapter(dataSet) recyclerView.adapter = recyclerViewAdapter // 设置分割线 val dividerItemDecoration = DividerItemDecoration(this, DividerItemDecoration.VERTICAL) recyclerView.addItemDecoration(dividerItemDecoration) } } RecyclerView的适配器代码:
class RecyclerViewAdapter(private val data: Array<String>) : RecyclerView.Adapter<RecyclerViewAdapter.ViewHolder>() { override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): ViewHolder { val itemView = LayoutInflater.
记录一下,这是2020年第一篇帖子,今年立了一个flag–经常写帖子。因为疫情的原因,只能每天在家养肚皮,躺床上为社会做贡献。实在是坐不住了,就开始写这篇文章吧。希望新的一年自己越来越厉害,也希望疫情早点过去
(一)什么是插件化 插件化技术最初源于免安装运行apk的想法,这个免安装的apk就可以理解为插件,而支持插件的app我们一般称之为宿主
(二)为什么要插件化 1.app功能模块越来越多,体积越来越大,维护变得困难;
2.模块之间的耦合度高,协同开发沟通成本越来越高;
3.方法数目可能超过65535,APP占用的内存越来越大;
4.增加功能只敢做加法。
(三)插件化和模块(模块)化的爱恨纠葛 组件化开发主要是通过gradle配置,将一个app分成多个模块,每个模块都是一个组件,开发的过程中我们可以让这些组件相互依赖或者单独调试部分组件等,但是最终发布的时候是将这些组件同意合并成一个apk,这就是组件化开发。插件化和组件化略有不同,插件化开发是将整个apk拆分成多个模块,这些模块包括一个宿主和多个插件,每个模块都是一个apk,最终打包的时候宿主apk和插件apk分开打包。插件化其实是建立在模块化基础上的,插件化在实施之前需要先进性模块化。 (四)核心-插件化原理(方案之一) 各大平台方案对比
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传
不再一一介绍原理,本次主题是基于 360的DroidPlugin
接下来是插件化的核心:
如何加载插件的类?如何加载插件的资源?如何调用插件的类(四大组件)? 一. 如何加载插件的类 1. 类加载器 毫无疑问,类是通过类加载器classLoader加载的,我们先看几种类加载器.
1.1 PathClassLoader和DexClassLoader区别 首先我们来看DexClassLoader:
DexClassLoader 用于加载.jar .apk .dex中的类,也可以用来加载不是应用程序中的代码
api-25-7.1 -->
api-26-8.0 -->
api-28-9.0 -->
可以发现,DexClassLoader里什么也没有做,只是重写了BaseDexClassLoader的构造函数,注意api28里面的这段标红注释:该参数在api 26之后就废弃了,后面会讲到。
再看BaseDexClassLoader:
api-25-7.1 -->
api-26-8.0 & api-28-9.0 -->
我们把焦点放在optimizedDirectory上:应该被写入的dex所在的目录。通过构造三个版本的函数可以看出:8.0之前使用了optimizedDirectory参数,8.0及8.0之后不再使用该参数。
我们再移步看一下PathClassLoader:PathClassLoader是系统类和系统应用的类加载器:
PathClassLoader8.0前后并没有什么区别,同样重写了四个参数的构造函数,optimizedDirectory为null。
总结:
8.0之前,DexClassLoader供系统(谷歌工程师)使用,PathClassLoader提供给开发者使用;8.0及之后并无区别。后来谷歌工程师越来越觉得写两个加载器简直是闲得蛋疼,干脆就不再区分了。 区别: 在8.0之后并无区别,
1.2 BootClassLoader 和PathClassLoader /** *注意这个类派生自AppCompatActivity,而非Activity */ public class MainActivity extends AppCompatActivity { private static final String TAG = "
windowsy官网地址:https://code.visualstudio.com/docs/cpp/config-mingw
vscode用wsl:https://code.visualstudio.com/docs/cpp/config-wsl(本文不涉及,用于后续研究)
以win10 64位为例
1.安装vscode 此处省略
2.在vscode中安装c/c++插件 在vscode中安装如下 插件
3.windows系统下,安装编译器(MinGW-x64) MinGW-x64是windows下的编译开发环境,提供一个terminal窗口供用户编译、调试。
安装(参考网址https://www.jianshu.com/p/e79cdf4c32ef)
网址:https://www.msys2.org/。
安装需要的工具链
需要在 MinGW-x64中执行以下语句(坑1: 一定要执行,否则没有gdb):
pacman -S --needed base-devel mingw-w64-x86_64-toolchain 将MinGW 编译器的路径添加到环境变量“path”中** C:\msys64\ # add gdb env to path C:\msys64\mingw64\bin 在MinGW-x64中执行,一下命令,查看是否可以正常调用g++,gdb。 gcc --version g++ --version gdb --version Administrator@I6HCU75VXKC3B6C MINGW64 ~ # gcc --version gcc.exe (Rev4, Built by MSYS2 project) 12.2.0 Copyright (C) 2022 Free Software Foundation, Inc. This is free software; see the source for copying conditions. There is NO warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
良好的代码规范无论是对个人还是团队都是十分重要的。遵循一致的代码规范能够显著增强代码可读性、可维护性,使得代码结构简洁清晰,还能减少bug的出现。对于团队开发来说,还能减少部分沟通成本,让大家都专注于功能开发上。
Prettier 简介
Prettier 是一款代码格式美化工具,用于统一代码风格,提高代码可维护性。
ESLint
内置规则和自定义规则共用一套规则 API内置的格式化方法和自定义的格式化方法共用一套格式化 API额外的规则和格式化方法能够在运行时指定规则和对应的格式化方法并不强制捆绑使用 ESLint 结合 Prettier 使用
美化代码结构的Prettier,检查代码质量的ESLint,强强结合会碰撞出什么样的火花呢?
1. 安装
要使用ESLint和Prettier当然先得安装他们啦,然后还需要安装 eslint-plugin-prettier。
为了防止Prettier和ESLint格式化功能冲突,还需要安装 eslint-config-prettier 来关闭ESLint中的代码格式化功能
npm install --save-dev --save-exact prettier npm install eslint --save-dev npm install --save-dev eslint-plugin-prettier npm install --save-dev eslint-config-prettier 在 .prettierignore 和 .eslintignore 文件中可以添加那些不需要格式化的文件或文件夹,在美化代码挑bug时忽略这些文件。
// .prettierignore /dist/* .local .output.js /node_modules/** **/*.svg **/*.sh /public/* // .eslintignore *.sh node_modules *.md *.woff *.ttf .vscode .idea dist /public /docs .husky .local /bin Dockerfile 2.
一、按年/月/周/日/小时分组查询(日期时间类型为date或者datetime) 在DATE_FORMAT(create_time,'%Y%m%d')中设置需要分组的类型和格式,如下:
'%Y%m%d'表示:20221122
'%Y-%m-%d'表示:2022-11-22
可根据自己的需要设置,年月日都是如此
如下图user表
user idnameagebirthdaygendercreate_time1张三202000-01-01男2022-11-22 11:11:112李四212001-02-02男2022-11-19 00:00:003王五231999-05-06女2022-11-20 23:59:59 按日分组查询并排序 SELECT DATE_FORMAT(create_time,'%Y-%m-%d') days,COUNT(id) FROM user WHERE create_time > "2022-11-11 00:00:00" AND create_time < "2022-12-01 00:00:00" GROUP BY days ORDER BY days DESC; 按周分组查询 SELECT DATE_FORMAT(create_time,'%Y-%u') weeks,COUNT(id) FROM user GROUP BY weeks; 按月分组查询 SELECT DATE_FORMAT(create_time,'%Y-%m') months,COUNT(id) FROM user GROUP BY months 按年分组查询 SELECT DATE_FORMAT(create_time,'%Y') months,COUNT(id) FROM user GROUP BY years 按小时分组查询 SELECT DATE_FORMAT(create_time,'%Y-%m-%d %H') hours,COUNT(id) FROM user WHERE create_time > "
前言: 前些日志QQ群有朋友发了一个Toast的崩溃日志。Toast如此简单的用法怎么会崩溃呢?所以顺便就学习了一下Toast在源码中的实现,不算复杂,但内容挺多的,这里就来分享一下,方便读者。
一.基本使用方式 主要有两种实现方式:
1.最基本的使用方式: 使用方式很简单,直接沟通过静态方法构传入context,显示内容以及显示时长三个参数,构造Toast对象,然后通过show显示。
Toast toast = Toast.makeText(getBaseContext(), "显示内容", Toast.LENGTH_LONG); toast.show(); 2.自定义View的实现方式 这种使用使用方式也很简单,首先构造一个View,然后通过setView方法传入这个自定义View,最终也是通过show方法显示。
View selfToastView = View.inflate(getBaseContext(), R.layout.self_toast, null); Toast toast = Toast.makeText(getBaseContext(), "显示内容", Toast.LENGTH_LONG); toast.setView(selfToastView); toast.show(); 3.使用方式总结 两种使用方式都很简单,区别只是第二种方式多传入了一个自定义View而已。但是为什么要分开来讲呢?因为虽然使用时仅仅只差一步,但是其实现原理是完全不一样的。一个是通过NotificationManagerService去显示的,而另外一个则是APP自身处理的。接下来,我们就依次的讲一下两种使用方式的实现原理。
二.Toast的创建显示流程原理讲解 1.Toast.makeText 这个的实现方式还是比较简单的,最终的生成方式传入4个参数,分别为
Context:绑定的上下文对象
Looper:绑定线程的Looper,可以为空。为空时则默认使用当前线程的looper。PS:每个线程都只能绑定唯一的一个Looper,想了解这一块的可以看我的另外一篇文章:android源码学习-Handler机制及其六个核心点_失落夏天的博客-CSDN博客_安卓开发handler机制
text:显示内容
duration:持续时间。有两种参数:
Toast.LENGTH_LONG:显示时间较长,为3.5S。其3500ms的值定义在NotificationManagerService.LONG_DELAY。
Toast.LENGTH_SHORT:显示时间较短,为2S。其2000ms的值定义在NotificationManagerService.SHORT_DELAY。
但是真实显示的时间,却不是3.5和2S,实际显示时间会比这两个时间更长一些,这个后面会讲。
最终生成一个Toast对象返回,这里需要注意的是,原生Toast和自定义View的Toast的唯一区别就是原生Toast对象中mNextView对象为null。
public static Toast makeText(@NonNull Context context, @Nullable Looper looper, @NonNull CharSequence text, @Duration int duration) { //这里默认配置为true,走上面这个判断逻辑 if (Compatibility.isChangeEnabled(CHANGE_TEXT_TOASTS_IN_THE_SYSTEM)) { Toast result = new Toast(context, looper); result.mText = text; result.
import datetime def is_weekend(date_param: str): """ 是否是周末 @:param: date_param 日期。如 2020-01-01 """ # 标准日1 sd1 = '2022-11-19' # 标准日2 sd2 = '2022-11-20' # 日期格式 format = '%Y-%m-%d' # 时间间隔。七整天 interval = 7 sd1 = datetime.datetime.strptime(sd1, format) sd2 = datetime.datetime.strptime(sd2, format) the_date = datetime.datetime.strptime(date_param, format) compute_interval1 = abs((the_date-sd1).days / interval) compute_interval2 = abs((the_date-sd2).days / interval) return compute_interval1 == int(compute_interval1) or compute_interval2 == int(compute_interval2) if __name__ == '__main__': print(is_weekend('2022-03-27'))
文章目录 0 前言2 相关技术2.1 VGG-Net模型2.2 VGG-Net在植物识别的优势(1) 卷积核,池化核大小固定(2) 特征提取更全面(3) 网络训练误差收敛速度较快 3 VGG-Net的搭建3.1 Tornado简介(1) 优势(2) 关键代码 4 Inception V3 神经网络4.1 网络结构 5 开始训练5.1 数据集5.2 关键代码5.3 模型预测 6 效果展示6.1 主页面展示6.2 图片预测6.3 三维模型可视化 7 最后 0 前言 🔥 Hi,大家好,这里是丹成学长的毕设系列文章!
🔥 对毕设有任何疑问都可以问学长哦!
这两年开始,各个学校对毕设的要求越来越高,难度也越来越大… 毕业设计耗费时间,耗费精力,甚至有些题目即使是专业的老师或者硕士生也需要很长时间,所以一旦发现问题,一定要提前准备,避免到后面措手不及,草草了事。
为了大家能够顺利以及最少的精力通过毕设,学长分享优质毕业设计项目,今天要分享的新项目是
🚩 基于深度学习的植物识别算法研究与实现
🥇学长这里给一个题目综合评分(每项满分5分)
难度系数:4分工作量:4分创新点:3分 🧿 选题指导, 项目分享:
https://gitee.com/yaa-dc/BJH/blob/master/gg/cc/README.md
2 相关技术 2.1 VGG-Net模型 Google DeepMind公司研究员与牛津大学计算机视觉组在2014年共同研发出了一种全新的卷积神经网络–VGG-Net。在同年举办的ILSVRC比赛中,该网络结构模型在分类项目中取得了十分出色的成绩,由于其简洁性和实用性,使得其在当时迅速,飞快地成为了最受欢迎的卷积神经网络模型。VGG-Net卷积神经网络在近年来衍生出了A-E七种不同的层次结构,本次研究使用其中的D结构,也就是VGG-16Net结构,该结构中包含了13个卷积层,5个池化层和3个全连接层。针对所有的卷积层,使用相同的5x5大小的卷积核,针对所有的池化层,使用相同的3x3大小的池化核。VGG-Net结构如图所示。
2.2 VGG-Net在植物识别的优势 在针对植物识别问题上,VGG-Net有着一些相较于其他神经网络的优势,主要包括以下几点:
(1) 卷积核,池化核大小固定 网络中所有的卷积核大小固定为3x3,所有的池化核大小固定为5x5。这样在进行卷积和池化操作的时候,从数据中提取到的特征更加明显,同时在层与层的连接时,信息的丢失会更少,更加方便后续对于重要特征的提取和处理。
(2) 特征提取更全面 VGG-Net网络模型中包含了13个卷积层。卷积层数目越多,对于特征的提取更加的全面。由于需要对于植物的姿态、颜色等进行判定,植物的特征较多,需要在提取时更加的全面,细致,才有可能得到一个更加准确的判定。VGG-Net符合条件。
(3) 网络训练误差收敛速度较快 VGG-Net网络在训练时收敛速度相对较快,能够较快地得到预期的结果。具有这一特点的原因有两个,一个是网络中每一个卷积层和池化层中的卷积核大小与池化核大小固定,另一个就是对于各个隐藏层的参数初始化方法使用专门针对ReLU激活函数的Kaiming正态初始化方法。
3 VGG-Net的搭建 本次研究基于Pytorch深度学习框架进行网络的搭建,利用模块化的设计思想,构建一个类,来对于整个的网络进行结构上的封装。这样搭建的好处是可以隐藏实现的内部细节,提高代码的安全性,增强代码的复用效率,并且对于一些方法,通过在内部集成,可以方便之后对于其中方法的调用,提升代码的简洁性。 在网络搭建完成后,将数据集传入网络中进行训练,经过一段时间后即可得到植物识别的分类识别结果。
nodejs-(一)win10安装配置nodejs(v12.20)环境
一、什么是Nodejs?
Node.js是一个基于Chrome V8擎JavaScript运行时环境。Node.js听名字好像是个JS库,其实Node.js是C++开发的JavaScript运行时环境。
使用Node.js可以访问读写txt文本、访问数据库,开发Web网站等等。
二、下载地址
官网:
https://nodejs.org/zh-cn/
其它版本:
https://nodejs.org/zh-cn/download/releases/
源码地址:
https://github.com/nodejs
三、node和npm两个重要的命令行工具介绍
node,是Nodejs的执行命令,输入node可以进入Nodejs环境,键入标准js可以在控制台查看输出内容。如果想独立运行hello.js文件,可以输入命令:node hello.js 查看执行结果。
npm,(Node Package Manager)是Nodejs包管理工具,可以安装我们需要的依赖包到本地。通过package.json文件来管理插件包的包管理工具,包都存在node_modules里面,安装node环境会自动集成npm工具,不需要额外安装。
四、搭建环境和修改配置
下面以v12.20.0为例在win10中配置一个Nodejs环境,我们使用zip包手动安装Nodejs。
1.下载文件
下载地址:https://nodejs.org/download/release/v12.20.0/
下载node-v12.20.0-win-x64.zip文件
2.将文件解压到D:\nodejs\node-v12.20.0-win-x64目录
node.exe 文件应在此路径下 D:\nodejs\node-v12.20.0-win-x64\node.exe;
在根目录新建 node_global 、node_cache 文件夹,用于存放全局包;
后续使用命令配置全局包和国内镜像地址:
3.配置环境变量
3.1 新建 NODE_HOME 变量,指向node命令目录:D:\nodejs\node-v12.20.0-win-x64
3.2 新建 NODE_PATH 变量,指向全局包所在目录:%NODE_HOME%\node_global\node_modules
3.3 在Path变量中添加三个路径
%NODE_HOME%
%NODE_HOME%\node_global
%NODE_PATH%
注:后续如果需要安装其它版本的Nodejs只需要修改NODE_HOME变量值即可。
4.验证Nodejs是否安装成功
分别键入node -v 和 npm -v 看到版本号就算成功了。
node -v
v12.20.0
npm -v
6.14.8
5.修改npm全局包的默认存放路径和国内镜像地址;
npm config set prefix “D:\nodejs\node-v12.20.0-win-x64\node_global”
npm config set cache “D:\nodejs\node-v12.
文章目录 效果图关键代码源码地址 效果图 NavigationView提供了侧边栏导航,一般在HeaderLayout使用背景图片,在menu部分使用分组的菜单,提高布局美感。
关键代码 class MainActivity : AppCompatActivity() { private var mDrawerToggle: ActionBarDrawerToggle? = null override fun onCreate(savedInstanceState: Bundle?) { super.onCreate(savedInstanceState) setContentView(R.layout.activity_main) val drawerLayout = findViewById<DrawerLayout>(R.id.drawer_layout) val toolbar = findViewById<Toolbar>(R.id.toolbar) setSupportActionBar(toolbar) supportActionBar!!.setHomeButtonEnabled(true) supportActionBar!!.setDisplayHomeAsUpEnabled(true) mDrawerToggle = ActionBarDrawerToggle( this, drawerLayout, toolbar, R.string.drawer_open, R.string.drawer_close) mDrawerToggle!!.syncState() drawerLayout.addDrawerListener(mDrawerToggle!!) val navigationView = findViewById<View>(R.id.navigation_view) as NavigationView navigationView.getHeaderView(0).setOnClickListener { drawerLayout.closeDrawer(navigationView) Toast.makeText(this@MainActivity, "Header View is clicked!", Toast.LENGTH_SHORT).show() } navigationView.setNavigationItemSelectedListener { item -> when (item.itemId) { R.id.menu_home -> Toast.
1、添加框架依赖
implementation 'org.apache.flink:flink-java:1.16.0' implementation 'org.apache.flink:flink-streaming-java:1.16.0' implementation 'org.apache.flink:flink-connector-kafka:1.16.0' implementation 'org.apache.flink:flink-clients:1.16.0' implementation 'org.apache.flink:flink-json:1.16.0' implementation 'org.apache.flink:flink-table-api-scala-bridge_2.12:1.16.0' implementation 'com.alibaba:fastjson:2.0.19.graal' implementation 'org.apache.hadoop:hadoop-client:3.2.2' implementation 'org.apache.flink:flink-connector-jdbc:1.16.0' implementation 'org.apache.phoenix:phoenix-client-hbase-2.4:5.1.2' 2、flink读取kafka数据
kafka数据源数据格式
{"common":{"ar":"110000","ba":"iPhone","ch":"Appstore","is_new":"1","md":"iPhone 8","mid":"mid_368770","os":"iOS 13.3.1","uid":"63","vc":"v2.1.132"},"displays":[{"display_type":"activity","item":"1","item_type":"activity_id","order":1,"pos_id":3}],"page":{"during_time":19393,"page_id":"home"},"ts":1605368266000} 编写flink读取kafka数据源
public class ReadKafkaToFlinkFunction { public static StreamExecutionEnvironment getEnv() { StreamExecutionEnvironment.createRemoteEnvironment(String host, int port, String... jarFiles); StreamExecutionEnvironment executionEnvironment = StreamExecutionEnvironment.getExecutionEnvironment(); executionEnvironment.setParallelism(1); executionEnvironment.enableCheckpointing(5 * 60000L, CheckpointingMode.EXACTLY_ONCE); executionEnvironment.getCheckpointConfig().setCheckpointTimeout(10 * 60000L); executionEnvironment.getCheckpointConfig().setMaxConcurrentCheckpoints(2); executionEnvironment.setRestartStrategy(RestartStrategies.fixedDelayRestart(3, 5000L)); executionEnvironment.setStateBackend(new HashMapStateBackend()); executionEnvironment.getCheckpointConfig().setCheckpointStorage("hdfs://server115:9000/flink/ck"); System.setProperty("HADOOP_USER_NAME", "wucf"); return executionEnvironment; } /** * ID | CH | MD | MID | OS | DURING_TIME | PAGE_ID | TS * 将kafka的数据读取到flink */ public static void kafkaNewFlinkStream() { try { StreamExecutionEnvironment env = getEnv(); // 将kafka数据作为source KafkaSource<String> kafkaConsumer = KafkaUtils.
技术关键词:mesa、OpenGL、dri、gpu、kmd、xsever
目录
一、mesa概述
二、mesa架构
1. 架构设计
2. 模块划分
三、mesa与linux图形系统中的其他模块的关系
四、mesa的编译
五、链接资源
总结
一、mesa概述 mesa是OpenGL、OpenGL ES、Vulkan、OpenCL的一个开源实现(Open source implementations of OpenGL, OpenGL ES, Vulkan, OpenCL, and more)。对于了解和研究图形渲染与并行计算实现的科研人员和从业者,mesa是一个较好的研究资料。
mesa是基于linux内核的OS上所使用的OpenGL的标准实现。计算机领域的国产化生态中,国产OS的内核都是基于linux,因此国产GPU的OpenGL的支持都是通过mesa。在计算机核心技术(cpu-os-gpu-safe)国产化的时代大浪潮下,与mesa相关的研究与应用呈现出一定的就业机会。
本专栏专注于mesa的OpenGL实现,其他方面不做细致分析。
二、mesa架构 1. 架构设计 随着mesa的版本的迭代,mesa的整个架构和模块设计已经相对完善,本专栏基于较新的22.*的版本,基于gallium架构的实现进行分析。
gallium架构实现了API、 OS、 HW的分层设计,每层通过稳定接口对接,能够更容易的适配不同的OS和HW,但对初接触者,更复杂了。virt gl 使用gallium架构的整体分层设计如下:
采用gallium架构的分层设计图(本图来自mesa架构演进)
2. 模块划分 从大的划分看,可以划分为前端和后端:前端包括libGL、libEGL、libgbm、libglapi等,后端为libgallium_dri。具体的模块关系概略图(每个模块的详略图请看后续的内容)如下:
mesa 模块及关系图
三、mesa与linux图形系统中的其他模块的关系 linux的图形显示系统的软件组成可以概括为:xserver、应用层app(如2D\3D应用软件)、mesa、kmd(kernel mode driver)。mesa与其他三部分的关系如下:
linux 系统软件模块关系图
四、mesa的编译 mesa库使用了meson和ninja来构建。使用ptyhon3.* 的pip3来安装meson,ninja下载源码构建即可。
五、链接资源 mesa官网
mesa架构演进
ninja官网
总结 本文从mesa是什么、gallium架构简述了mesa。后续会针对本文图片的内容进行分解,详细分析mesa实现渲染和送显的实现。
我们想要对一个字符串中的大小写和数字进行区分,那么我们就必须用到三个内置的函数对我们输入的字符串内容进行判断
1.str.isupper()#用来判断是否为大写字母
2.str.islower()#用来判断是否为小写字母
3.str.isdigit#用来判断是否为数字
if 'M'.isupper(): print('M') #输出结果为M #剩余两个函数同样的用法,用来判断一个字符串中的某一字符是否为其结果,如果对整体字符串进行判断则全真为真 if 'Mako'.isupper(): print('Mako') #输出结果为None 有了对于以上三个函数用法的初步认识,我们开始编写整体程序
list1=[] list2=[] list3=[]#首先创建三个空列表用来盛装不同类型的对象 a=input('输入')#要求输入一段字符串 for i in a:#对于我们输入的字符串从第0项进行单个循环并对每个单独的字符进行判断是否为我们所找的对象类型 if i.isupper():#如果字符为大写字母,则进入第一个分支 list1.append(i)#将满足条件的对象放入第一个列表中 if i.islower(): list2.append(i) if i.isdigit(): list3.append(i) print('大写字母数为',len(list1))#列表的长度即元素的个数,元素的个数即满足我们条件的对象的个数这样我们就解决了问题 print('小写字母数为',len(list2)) print('数字的个数为',len(list3))
Spark持久化 1 血缘,缓存,rdd机制 rdd算子本身记录的是元数据,比如某个数据在某个区。他自己不存储数据本身。
(只存储分区和计算方法的数据)
所以 血缘关系(运算流程)或者RDD可以重用 但是数据不可重用
这意味着每次调用都需要 重新运算。
这也是为什么 缓存或者持久化可以提升运行10倍运行速度的原因
因为之前数据虽然在内存里计算,但是并没有存储下来。持久化和缓存才是记录了数据。
rdd1=map(sss) rdd2=rdd1.reducebykey rdd1实际没有保存数据,只记录了血缘。所以当rdd2调用rdd1时。rdd1得重头计算一次。
2 RDD中cache,persist,checkpoint的区别 cache 数据会被缓存到内存来复用
血缘关系中添加新依赖
作业执行完毕时,数据会丢失
persist 保存在内存或磁盘
因为有磁盘IO,所以性能低,但是数据安全
作业执行完毕,数据会丢失
checkpoint 数据可以长时间保存到磁盘中
涉及磁盘IO,读取慢但安全。
独立作业
与cache配合使用,比如checkpoint后再cache一下,这样后续调用可以从cache里取
会切断血缘信息,重新建立新的血缘
checkpoint相当于改变数据源
3 Tips 触发方式:并不是立即缓存,当有action被触发时才调用。
object StorageLevel { //不缓存 val NONE = new StorageLevel(false, false, false, false) //只在硬盘缓存 val DISK_ONLY = new StorageLevel(true, false, false, false) //在硬盘缓存两份 val DISK_ONLY_2 = new StorageLevel(true, false, false, false, 2) //只在内存缓存 val MEMORY_ONLY = new StorageLevel(false, true, false, true) //在内存缓存两份 val MEMORY_ONLY_2 = new StorageLevel(false, true, false, true, 2) //在内存序列化缓存 val MEMORY_ONLY_SER = new StorageLevel(false, true, false, false) //在内存序列化缓存两份 val MEMORY_ONLY_SER_2 = new StorageLevel(false, true, false, false, 2) //同时在内存和硬盘缓存 val MEMORY_AND_DISK = new StorageLevel(true, true, false, true) //同时在内存和硬盘缓存两份(推荐) val MEMORY_AND_DISK_2 = new StorageLevel(true, true, false, true, 2) //同时在内存和硬盘序列化缓存 val MEMORY_AND_DISK_SER = new StorageLevel(true, true, false, false) //同时在内存和硬盘序列化缓存两份 val MEMORY_AND_DISK_SER_2 = new StorageLevel(true, true, false, false, 2) //对外内存 val OFF_HEAP = new StorageLevel(false, false, true, false) .
Mediapipe是Google的轻量ML框架,包括了人体姿态识别、手势识别、头发分割等多种功能。Mediapipe支持跨平台,目前提供了Python、Android、IOS、JS等多种解决方案,但暂不支持Unity。
Github有大牛做了Unity的实现,链接。
这个项目将MediaPipe API (c++)移植到c#,这样就可以从Unity调用它。当需要在循环中调用多个api时,这种方法可能会牺牲性能,但它提供了使用MediaPipe的可能性。
直接将代码Clone到本地,用Unity(2021.3.3f1)打开会缺失环境,DLL的配置等。
作者也提供了all-in-one的package。
其中最新的版本v0.10.1是首次预编译好的包。
下载第一个,打开后,得到
使用时,直接用Unity Hub对应的Unity版本打开这个文件夹新建一个文件夹,其中Samples~后面的~要删掉,不然在Unity Editor资源里看不到这个文件夹。
我直接打开是有错的,显示的错误是找不到某个目录下的txt等文件,但实际上这些文件存在的。测试后,运行时,Model Complexity不能选Lite,要选为Full;Running Mode选Sync才是实时的,但是Sync延迟比较明显,换NonBlockingSync(无阻塞同步),延迟会降低,但是会帧一闪一闪的,个人理解是降低了每帧里处理的图像的数量,所以延迟降低,但会闪帧。
延迟情况,用USB3.0而不是2.0,会好一点。
此外,运行时需关闭本机的其他相机应用,比如Windows自带的相机!
在2022年19月28日 用户信息进行了调整
导致获取不到用户的头像和昵称
可以登录小程序管理后台,进入「设置 - 基本设置 - 基础库最低版本设置」进行配置。
根据使用的接口来配置版本即可。
之前研究过通过mycat进行分库分表的配置,最近发现很多项目上用的都是sharding-proxy来实现,所以也来进行一个学习。下面来简单记录一下搭建的过程。
下载 首先自然是去官网下载软件,这里我下载的是最新版5.1.2,下载地址如下:
https://www.apache.org/dyn/closer.lua/shardingsphere/5.1.2/apache-shardingsphere-5.1.2-shardingsphere-proxy-bin.tar.gz
直接在centos虚拟机上用 wget命令进行下载即可,下载完成后,输入 tar -zxvf apache-shardingsphere-5.1.2-shardingsphere-proxy-bin.tar.gz进行解压,最终解压出来一个文件夹,进行下一步。
配置 进入文件夹,可以看到一个十分眼熟的文件结构,非常像tomcat。可能apache家的软件都是这个结构?(笑)
进入conf,首先我们修改 server.yaml这个配置文件,这个配置文件主要是用来设置一个虚拟的登录用户以及密码。
进去之后我们可以看到官方已经提供了样例配置,都被注释掉了。我们只需要放开需要修改的注释,并进行修改即可。这里我主要修改的内容如下:
rules: - !AUTHORITY users: - root@%:123456 - sharding@:sharding props: proxy-default-port: 3333 这里的配置,是开放了两个用户,root和sharding,作为连接我们sharding-proxy的用户。以及修改了应用启动的端口号,默认使用的是3307,但我还有其他的应用占用了3307,所以这里改成了3333。
接着我们修改config-sharding.yaml这个配置文件,这个文件就是我们分库分表的主要配置文件了。
这个文件也是官方提供了样例配置,我们同样只需要放开注释,进行修改:
###################################################################################################### # # If you want to connect to MySQL, you should manually copy MySQL driver to lib directory. # ###################################################################################################### databaseName: aki_sharding dataSources: ds_0: url: jdbc:mysql://127.0.0.1:3306/aki_ds_0?serverTimezone=UTC&useSSL=false username: root password: 123456 connectionTimeoutMilliseconds: 30000 idleTimeoutMilliseconds: 60000 maxLifetimeMilliseconds: 1800000 maxPoolSize: 50 minPoolSize: 1 # ds_1: # url: jdbc:mysql://127.
笔者在重新尝试用深度学习的各个模型对序列进行预测,就LSTM进行一些使用记录
一、一些优化 和keras一样的权重初始化 有时候我们torch训练的LSTM, 没有keras好,可以将权重按keras的方式进行初始化 增加attention 捕捉序列的周期与相似性尝试用self-attention 二、网络结构LSTM+Attention import torch from torch import nn import torch.nn.functional as F from torch.utils.data import DataLoader, TensorDataset import typing as typ import numpy as np from tqdm import tqdm from sklearn.model_selection import KFold from collections import OrderedDict class LSTMRegressor(nn.Module): def __init__(self, input_size, hidden_size=128): super(LSTMRegressor, self).__init__() self.lstm = nn.LSTM(input_size, hidden_size, batch_first=True, bidirectional=False) self.header = nn.Sequential(OrderedDict([ ('fc1', nn.Linear(hidden_size, 32)), ('relu1', nn.ReLU(inplace=True)), ('dropout', nn.Dropout(0.01)), ('fc2', nn.Linear(32, 1)), ('relu2', nn.
ref() ref()接受一个内部值,返回一个响应式的、可更改的 ref 对象,此对象只有一个指向其内部值的property.value。类型 使用泛型 推荐使用接口使用Ref // 使用泛型 推荐 import { ref } from 'vue' const initCode = ref<string | number>('200') // 使用interface import { ref } from 'vue' interface User { name: string age: string | number } const user = ref<User>({ name:'前端开发爱好者', age: 20 }) reactive() reactive() 返回一个对象的响应式代理。类型 直接添加 推荐使用泛型 // 直接给声明的变量添加类型 推荐 import { reactive } from 'vue' interface User { name: string age: string | number } const user:User = reactive({ name:"
目录
一、PHP 文件是什么?
二、由于PHP可以在不同平台上运行、与几乎所有浏览器兼容、提供广泛的数据库、免费并且易于学习,在服务器上运行高效的优点,因此要使用PHP。
三、PHP基本语法
四、PHP定界符EOF(定义字符串)
五、数据类型
应用:
六、字符串变量
七、类型比较
八、运算符
九、if...else语句与switch语句同c语言一样,循环语句中while语句,do...while语句,for语句均与c语言用法一样。下面介绍独特的foreach语句(用于遍历数组):
十、数组
遍历关联数组:遍历并打印关联数组中的所有值,您可以使用 foreach 循环,如下所示:
十一、数组排序
十二、超级全局变量(全部作用域均可作用)类型有:
$_REQUEST—用于收集HTML表单提交的数据
十三、函数(函数是通过调用函数来执行的)
十四、魔术常量
十五、PHP类定义
访问控制
十六、$_GET变量(预定义的 $_GET 变量用于收集来method="get" 的表单中的值)
$_POST 变量(预定义的 $_POST 变量用于收集来自 method="post" 的表单中的值)
一、PHP 文件是什么? PHP 文件可包含文本、HTML、JavaScript代码和 PHP 代码PHP代码在服务器上执行 ,结果以纯 HTML 形式返回给浏览器PHP 文件的默认文件扩展名是 ".php" 通过 PHP:1.您不再限于输出 HTML。
2.您可以输出图像、PDF 文件,甚至 Flash 电影。您还可以输出任意的文本,比如 XHTML 和 XML。
3.收集表单数据,发送和接受cookies(cookie其实就是一些数据信息,类型为“小型文本文件”,存储于电脑上的文本文件中。)
4.可以添加、删除、修改您的数据库中的数据,可对自己的网站或数据进行限制或加密,即可以加安全盾。
二、由于PHP可以在不同平台上运行、与几乎所有浏览器兼容、提供广泛的数据库、免费并且易于学习,在服务器上运行高效的优点,因此要使用PHP。 三、PHP基本语法 1.PHP脚本可从文档的任意位置开始,以<?php开始,以?>为结束,在中间写代码。(脚本中通常包含HTML标签)。
2.同c语言一般用分号将每个代码行分隔开,但输出可用echo,print(前者可输入多个字符串且速度快,后者只能输入一条字符串,返回值总是1)。
3.PHP上手快在于对于每个变量只需为$x(x为你要输入的变量名),在给变量第一次赋值时 便被创建,并不要明确变量类型以及声明变量(但同时变量名必须以字母或下划线字符开始,只能包含字母、数字以及下划线如A-z、0-9 和 _,不能包含空格)变量对大小写敏感。 4.print_r
打印关于变量的易于理解的信息,如果给出的是 string、integer 或 float,将打印变量值本身。如果给出的是 array,将会按照一定格式显示键和元素。object 与数组类似。 记住,print_r() 将把数组的指针移到最后边。使用 reset() 可让指针回到开始处。
总目录 文章目录 总目录前言一、问题现象二、解决问题三、修改环境变量最后:提醒总结 前言 写这篇博文的主要原因是因为自己遇到了这个问题,所以分享出来。
事情起因就是装系统的时候,使用了微软的账户信息,导致登录系统后,用户目录名称就是一串数字,个人忍不了,所以就对它动手了。
一、问题现象 系统用户目录名称为一串数字
cmd命令窗口的路径也是这一串数字以及各种软件安装时的路径都是这串数字 二、解决问题 1、新建一个管理员账户
新建一个管理员账户,具体操作可查我的另一篇文章:Win10 如何添加一个本地用户
2、修改用户目录名称
使用新建的管理员账户登录,然后找到系统用户目录,将那串数字的用户文件夹名称修改为自己想要的名称
系统用户目录:在C盘中,找【用户】文件夹,即可找到
3、修改注册表
仅仅是修改的用户目录名称还不行,还需要修改注册表中的信息win+r 打开运行框,输入regedit 打开注册表按照如下路径,找到ProfileList目录
HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows NT\CurrentVersion\ProfileList\然后ProfileList目录下,一般为第四个文件目录(如果第四个找不到逐个文件找下),找到需要修改的那串数字 用户名,然后双击修改即可。
下图是我已经将那串 13681那串数字修改为了lzk
最后重启电脑,选择使用已经修改用户名的用户登录即可。 三、修改环境变量 对于已经在原先的那串数字用户名下,已经安装过很多软件的同学,需要配置一下环境变量,
将环境变量中涉及到先前的那串数字均修改为 当前的用户名即可。
Win + X 选择【系统】进入【系统设置界面】,选择【高级系统设置】然后会进入到【系统属性】窗口,在该选择【环境变量】将涉及的环境变量均进行修改即可。环境变量详情可以查看:Windows环境变量 最后:提醒 由于该操作涉及到注册表的操作,因此对于电脑小白需谨慎操作。
总结 本文为本人实操,主要是因为之前碰到了这种情况,所以记录在博文中。一来个人有记录的习惯,二来分享给同样遇到该问题的同学,希望能对于问题的解决有一点帮助。
参考
官方资料 - 重命名用户帐户不会自动更改配置文件路径
获取 Git 仓库 通常有两种获取 Git 项目仓库的方式:
1. 将尚未进行版本控制的本地目录转换为 Git 仓库;
2. 从其它服务器 克隆 一个已存在的 Git 仓库。
两种方式都会在你的本地机器上得到一个工作就绪的 Git 仓库。
(git init)在已存在目录中初始化仓库 如果你有一个尚未进行版本控制的项目目录,想要用 Git 来控制它,那么首先需要进入该项目目录中。
$ cd /c/user/my_project 之后执行:
$ git init 该命令将创建一个名为 .git 的子目录,这个子目录含有你初始化的 Git 仓库中所有的必须文件,这些文件是Git仓库的骨干。
(git clone)克隆现有的仓库 克隆仓库的命令是 git clone <url> 。 比如,要克隆 Git 的链接库 libgit2,可以用下面的命令:
$ git clone https://github.com/libgit2/libgit2 这会在当前目录下创建一个名为 “libgit2” 的目录,并在这个目录下初始化一个 .git 文件夹, 从远程仓库拉取下所有数据放入 .git 文件夹,然后从中读取最新版本的文件的拷贝。 如果你进入到这个新建的 libgit2 文件夹,你会发现所有的项目文件已经在里面了,准备就绪等待后续的开发和使用。
如果你想在克隆远程仓库的时候,自定义本地仓库的名字,你可以通过额外的参数指定新的目录名:
这会执行与上一条命令相同的操作,但目标目录名变为了 mylibgit。
$ git clone https://github.com/libgit2/libgit2 mylibgit 记录每次更新到仓库 请记住,你工作目录下的每一个文件都不外乎这两种状态:已跟踪 或 未跟踪。
本篇文章讲究的是每一步操作都记录,争取每一位看该文章的朋友都能安装成功,并且会提供下载好的安装软件
1、下载RabbitMQ安装包 RabbitMQ官方地址:https://www.rabbitmq.com/download.html
不想去官网下载的小伙伴可以使用我提供的资料
百度网盘链接:RaabbitMQ安装资料
提取码:Eric
2、上传安装包到Linux中 将上面三个软件上传到/usr/local/software 目录下(如果没有 software 需要自己创建)
3、安装文件(分别按照以下顺序安装) 进入software文件夹,依次使用如下命令
rpm -ivh erlang-21.3-1.el7.x86_64.rpm yum install socat -y rpm -ivh rabbitmq-server-3.8.8-1.el7.noarch.rpm 4、常用命令(按照以下顺序执行) 1)添加开机启动 RabbitMQ 服务
chkconfig rabbitmq-server on 2)启动服务
/sbin/service rabbitmq-server start // 或者使用 systemctl start rabbitmq-server 如果启动失败,可以看这篇文章:解决启动RabbitMQ报错
3)查看服务状态
/sbin/service rabbitmq-server status // 或者使用 systemctl status rabbitmq-server 看到这个绿色的active就说明启动成功了
5、进入RabbitMQ Web管理页面 RabbitMQ和Tomcat、Nacos一样,是自带web管理页面的
开启 web 管理插件,需要执行如下命令
rabbitmq-plugins enable rabbitmq_management 然后在window浏览器中访问即可,地址为:虚拟机ip地址:15672
例如:192.168.1.7:15672
我们用默认账号密码()guest)访问地址 http://192.168.1.7:15672/出现权限问题
此时我们需要添加一个新用户,步骤如下:
// 第一步:创建账号 rabbitmqctl add_user admin 123 // 第二步:设置用户角色 rabbitmqctl set_user_tags admin administrator // 第三步:设置用户权限 rabbitmqctl set_permissions -p "
向日葵、ToDesk,想控制手机。【收费】、【收费】、【收费】、【收费】
作为编程人员,这钱我有点不想花。手里有常开机电脑,于是我萌生想法,使用frp做代理,用adb命令将手机的屏幕截图后展示在网页上,按秒刷新。反正自己服务器的没有1.2T流量从来每用完过,然后通过网页上点击判断坐标位置通过adb命令让手机执行。完美,本着这个想法去实现,项目已经搭建,frp服务已经开启。突然发现了宝藏【RustDesk】,果断放弃曾认为完美的计划,开舔【RustDesk】。这就是我和它的故事!
废话不说,一次字:开始干!
1:访问RustDesk,下载对应文件。 RustDesk | 开源远程桌面软件
不想看图找,直接赋链接:Releases · rustdesk/rustdesk-server · GitHub
下载Linux的文件。
2:解压上传至服务器,方法很多,可以用宝塔、xftp等,哪个顺手用哪个吧。 3:开启守护进程,给到启动hbbs和hbbr。(宝塔软件商店安装:【进程守护管理器】免费) 安装成功后设置首页展示
然后进到首页开始添加守护进程,注意上传hbbs和hbbr路径填写正确
注意,进程数设置一个就行,不用设置多。设置完成会自动启动,没有成功就说明文件路径和命令不正确,按照截图对照你的路径排查吧。
4:开放防火墙端口号: TCP(21115, 21116, 21117, 21118, 21119)UDP(21116) 不管所以然,按照官方文档开整。
先开放服务器的防火墙:
firewall-cmd --zone=public --add-port=21115/tcp --permanent firewall-cmd --zone=public --add-port=21116/tcp --permanent firewall-cmd --zone=public --add-port=21117/tcp --permanent firewall-cmd --zone=public --add-port=21118/tcp --permanent firewall-cmd --zone=public --add-port=21119/tcp --permanent firewall-cmd --zone=public --add-port=21116/udp --permanent firewall-cmd --reload firewall-cmd --reload firewall-cmd --reload firewall-cmd --query-port=21115/tcp firewall-cmd --query-port=21116/tcp firewall-cmd --query-port=21117/tcp firewall-cmd --query-port=21118/tcp firewall-cmd --query-port=21119/tcp firewall-cmd --query-port=21116/udp 开启阿里云安全组:
mysql中如何将存在分隔符号的一列进行拆分,成为多行 -- ****************************** 写在前面的说明 ********************************** /* student 为 上面左图的表名,表内字段名称见上图; 1.一个中文符号或者文字长为3,一个英文字母或者一个英文状态下得符号长为1 ; 2.函数substring_index(string,sep,num),即substring_index(字符串,分隔符,序号),参数说明: string:用于截取目标字符串的字符串。可为字段,表达式等; sep:分隔符,string存在且用于分割的字符,比如“,”、“.”等; num:序号,为非0整数。若为整数则表示从左到右数,若为负数则从右到左数。 例子:比如“www.mysql.com”截取字符‘www’,分割符为“.”,从左到右序号为1,即substring_index("www.mysql.com",'.',1);若从右开始获取“com”则为序号为-1即substring_index("www.mysql.com",'.',-1)。 */ -- ****************************** 写在前面的说明 ********************************** -- -------------------------------------------------------------------------------- -- ****************************** 具体的sql及注释********************************** SELECT a.sage, -- /*先正着取出几部分*/,然后在此基础再倒着取出最后那一部分 substring_index( substring_index(a.sname,',',b.help_topic_id + 1),',' ,- 1 ) AS split_name from -- 将原数据先取出来 like中的符号与实际表里字段中的分割符对应 (select sname,sage from student where sname like '%,%') a -- 如果表内还存在没有分隔符,就单个值的则直接select sname,sage from student 就行,总之目的是取出要处理的数据 join mysql.help_topic b -- mysql帮助表 内含字符等 ,help_topic_id是从0开始的,其实使用的是它的计数功能 ON -- on的条件筛选结束后,如果改行此字段分割完后有三部分,则总共产生3条记录 b.help_topic_id < ( length(a.
这里我们以 JpaRepository.class 为例。
JpaRepository是Spring Data JPA中非常重要的类。它继承自Spring Data的统一数据访问接口——Repository
1.找到该类,然后右键打开菜单,选择show diagrams 2.如下图,打开的界面就是该类的关系层次 从上图可以看出:
JpaRepository继承自PagingAndSortingRepository接口,而PagingAndSortingRepository接口继承自CrudRepository接口。CrudRepository和Repository接口则是Spring Data底层通用的接口,定义了几乎所有的数据库接口方法,统一了数据访问的操作。
参考书籍《springboot从入门到实战-章为忠著》
文章目录 1.让选择的包的程序不运行2. 让已经取消不运行的包再次运行 1.让选择的包的程序不运行 选择不要运行的包,右键 -> 选择 Mark Directory as , 接着选择Excluded
就可以在运行时不自动运行你选的包的程序了
2. 让已经取消不运行的包再次运行 同样,要把选择不运行的包再次运行时,也是右键 -> 选择 Mark Directory as,接着选择 Cancel Excluded,就可以再次运行选择的包了
一、配置过程 1.打开控制面板win+r,输入cmd在出现的终端中输入ipconfig找到自己在以太网适配器下的域名,如下图所示
2. 在burpsuite中点击proxy,在options中点击edit,接下来在证书地址上输入自己的域名点击确定即可。
3.接下来为浏览器配置,以火狐为例
点击右上角三道横杠,点击设置。
点击手动配置代理,在HTTP代理中输入相同的域名,点击确定即可。
二、抓百度过程 点击proxy,让其处于开启拦截请求(Intercept is on 表示开启拦截请求,Intercept is off 表示关闭拦截请求),随后点击open browser。
点此页面输入www.baidu.com(可以是你要抓包的网址),回车,出现以下情况
看到左上角一直在转圈,右边出现抓到浏览器的数据。(forward表示放包,可让浏览器数据通过,即恢复正常。drop表示丢包,即让浏览器的数据丢失导致页面无法出现) 这是丢包后的页面。
点击action,再点击send to repeater,
可以看到自己要抓包的数据,随后点击repeater这一栏,再点击send,就会在response看到自己抓包得到的数据。即抓包完成。
作者 | 叶润源 编辑 | 极市平台
原文链接:https://www.yuque.com/yerunyuan/ar9831/tsm0id#Kfi4w
点击下方卡片,关注“自动驾驶之心”公众号
ADAS巨卷干货,即可获取
点击进入→自动驾驶之心【模型部署】技术交流群
后台回复【模型部署工程】获取基于TensorRT的分类、检测任务的部署源码!
导读
YOLOX将近两年来目标检测领域的各个角度的优秀进展与YOLO进行了巧妙地集成组合并且重回Anchor Free的怀抱。本文详细的介绍了作者将FCOS+ATSS模型换成YOLOX模型的全过程并附带相关代码。
YOLOX的Anchor Free(Anchor Based针对数据集聚类分析得到Anchor Box的方式,怕对泛化会有影响,尤其前期缺乏现场数据时)以及更有效的Label Assignment(SimOTA),使我下决心将目前所用的FCOS+ATSS模型换成YOLOX模型。
这次改动将YOLOX添加到了Yolov5上,在Yolov5的框架下,训练150个epoch的yolox-s模型的mAP也达到了39.7(且未使用mixup数据增强和random resize)。
一、实验环境: 实验机器:
1台PC:CPU: AMD Ryzen 7 1700X Eight-Core Processor, 内存: 32G, 显卡: 2张GeForce GTX 1080 Ti 11G
1台PC:CPU: AMD Ryzen 5 2600 Six-Core Processor, 内存: 32G, 显卡: 2张GeForce GTX 1080 Ti 11G
目标部署硬件:A311D开发板(带8位整型5TOPS算力的NPU)
软件版本:Python版本为3.7.7,Pytorch版本为1.7.1,Cuda版本为10.1
官方YoloX版本:https://github.com/Megvii-BaseDetection/YOLOX.git
Commits: 29df1fb9bc456fcd5c35653312d7c22c9f66b9f8 (Aug 2, 2021)
官方Yolov5版本:https://github.com/ultralytics/yolov5.git
Commits: f409d8e54f9391ce21436d33334beff3a2fd4042 (Aug 4, 2021)
二、选择适合NPU的架构试验: 1、速度实验: 注:a、 模型在NPU上的速度实验,并不需要把模型完整地训练一遍,那样太耗时,只需要将模型导出(初始化后导出或者少量图片train一个epoch),再量化转换为NPU的模型即可。
1
mac系统出了新版本 13.0.1 后,androidstudio push, pull 代码一直报错:
如下:
Permission denied (publickey).
fatal: Could not read from remote repository.
Please make sure you have the correct access rights
and the repository exists.
经过几翻操作,重新生成id_rsa.pub 也是不行,
最后发现是rsa加密方式的问题,苹果mac升级系统后,默认不支持rsa方式加密git通讯,
所以如果要继续使用这个pub文件加密的方式,则要手动添加cofig配置文件来支持:
如下在 ~/.ssh/ 目录下新增config文件,
然后在 ~/.ssh/config 中新增:
Host *
PubkeyAcceptedKeyTypes +ssh-rsa
HostKeyAlgorithms +ssh-rsa
1.通过dropdownClassName添加class 1.通过dropdownClassName添加class <a-range-picker dropdownClassName="rangePickerIceGai" v-model:value="form.selectTime" show-time /> 2.显示框的样式 <style scoped> :deep(.ant-picker-range){ background: var(--color-background); border: 1px solid var(--color-border); border-radius: 2px; } :deep(.ant-picker-input > input){ color: var(--color-text); } :deep(.ant-picker-separator){ color: var(--color-text); } :deep(.ant-picker-suffix){ color: var(--color-text); } </style> 3.点击日期界面样式(注意:此处加入scoped无效),样式内的var()可以替换成例(#ffffff) <style lang="scss"> .rangePickerIceGai{ background: none !important; .ant-picker-panel-container{ background: var(--color-background); color: var(--color-text); } .ant-picker-panel{ border: 1px solid var(--color-border); } .ant-picker-header{ color: var(--color-text); } .ant-picker-content th,td{ color: var(--color-text); } .ant-picker-content td:hover>.ant-picker-cell-inner{ background: var(--color-background); } .ant-picker-cell:hover:not(.ant-picker-cell-in-view) .
二进制流的主要编码格式是base64码。可以在网上找一些在线转base64编码的网站进行尝试转换。
例如:http://imgbase64.duoshitong.com/然后通过前端展现和下载。
一、前端查看、下载功能实现 前端显示二进制流图片(src中放置base64码及二进制流)
<img src="http://dl.ppt123.net/pptbj/201603/2016030410235232.jpg" alt=""> /* * 提示:该行代码过长,系统自动注释不进行高亮。一键复制会移除系统注释 * <img src="" alt=""> */ 前端下载二进制流文件(herf中放置base64码及二进制流,download后面放置下载后的文件名称,如果有需要可以拼接下载文件名)
<a href="data:text/plain;base64,xOPV5suno6zV4srHvNm7sA==" download="6.txt">下载txt</a> /* * 提示:该行代码过长,系统自动注释不进行高亮。一键复制会移除系统注释 * <a href="" download="6.png">下载图片</a> */ 后端只要实现对数据库表字段的增加和修改接口api就可以正常使用了。然后在使用查的接口进行对相关字段遍历赋予src、herf、download中。就可以正常实现查看和下载了。 二、前端将文件转换成二进制流 主要代码是与input的file属性连用。将文件转为base64码。 <html> <head></head> <body> <input id="fujian" type="file"/> </body> <script> $("#fujian").change(function(){ var reader = new FileReader(); var AllowImgFileSize = 2100000; //上传图片最大值(单位字节)( 2 M = 2097152 B )超过2M上传失败 var file = $("#fujian")[0].files[0]; var imgUrlBase64; if (file) { //将文件以Data URL形式读入页面 imgUrlBase64 = reader.readAsDataURL(file); console.
git创建分支及合并
1、在远端创建自己的分支
2、在本地创建自己的分支,并切换到自己的分支
git branch newbranch
git checkout newbranch
3、将远端和本地分支关联起来
git branch --set-upstream-to=origin/newbranch newbranch
git pull
4、在本地分支修改代码,切到master后更新最新代码,并将自己的分支与master合并,修改冲突,修改完成后,更新到远端分支
git checkout master
git pull
git merge newbranch
修改冲突,并更新到远端自己的分支
git add .
git commit -m “”
git push -u origin newbranch
5、在远端请求合并,将自己的分支与主分支进行合并,并merge删除远端分支,并重复第1-3步
目录
1.React环境搭建
2.React项目结构
3.React优点和缺点
1.声明式设计
2.高效-React通过对DOM的模拟(创建虚拟DOM),最大限度地减少DOM操作(底层是Diff算法)
3.单向响应的数据流
4.组件化开发-复用和便于维护
5.缺点:React本身能做的事并不多,想做大的项目必须用React插件(全家桶)eg:网络请求库,UI库等这些没有
4.接受React的中二设定:JS中遇到了<> 会当作标签解析,标签中遇到了{},就会把这个{}中的表达式判定为JS语法
5.快速创建组件
1.React环境搭建 1.安装React脚手架(安装一次就好)
npm install -g create-react-app
2.验证脚手架是否安装完毕/查询版本
create-react-app -V
3.创建项目(如果丢包了,npm i 一下)
create-react-app 项目名称 (js版本)
create-react-app 项目名称 --template typescript (TS版本)
4.进入项目目录
cd 项目名称
5.启动项目
npm run start
2.React项目结构 (1)node_modules: 这里面包含了react项目中会用到的一些组件,install的时候下载下来的,你可以进去看看,有一些如base64之类的我们可能会用到的组件,或者一些第三方库;
(2)public:里面包含了我们项目中的启动页面,react比较适合单页面项目应用开发,所以暂时只包含一个index.html,并且这也是react工程的入口页面,入口页面怎么理解,就是你启动项目后,打开的首页,第一眼呈现的那个页面;
(3)src:里面包含了一些我们自己使用的js文件,css文件,img文件等等,但你打开src文件夹你会发现很混乱,不要管什么app.js,你就看到index.js即可,系统默认将index.html对准了index.js,index.js也就是我们项目的入口js,他和index.html所对应。
(4)修改:让目录结构更易懂:接下来,我们改动一下src里面的内容和结构,让首次接触react的小伙伴尽量能觉得他有点亲切的感觉,事实证明,越亲切的事物我们越希望去接近。src文件夹下原来的所有东西,除了index.js之外,都可以删掉,这样就可以轻装上阵了
3.React优点和缺点 1.声明式设计 2.高效-React通过对DOM的模拟(创建虚拟DOM),最大限度地减少DOM操作(底层是Diff算法) 3.单向响应的数据流 React 实现了单向响应的数据流,从而减少了重复代码,这也是它为什么比传统数据绑定更简单。
4.组件化开发-复用和便于维护(推荐使用函数组件) 5.缺点:React本身能做的事并不多,想做大的项目必须用React插件(全家桶)eg:网络请求库,UI库等这些没有 4.接受React的中二设定:JS中遇到了<></> 会当作标签解析,标签中遇到了{},就会把这个{}中的表达式判定为JS语法 JSX的理解:
JSX 是 JavaScript 语法的扩展。React 开发不一定使用 JSX ,但我们建议使用它。
JavaScript XML:JS中可以用标签,标签里面也可以用JS语言。
JS中遇到了<></> 会当作标签解析,标签中遇到了{},就会把这个{}中的表达式判定为JS语法
//js - string 变量中保存的是一个字符串 let a = '<div>hello react!
场景 因为特殊情况,开发中子组件又需要引入父组件,即子组件中再创建一个父组件的Vue实例。
比如一个展示组件Rack,内部有一个子组件RackDialog,然后RackDialog里又需要引入Rack组件
问题 使用常用的组件引入注册方式在RackDialog组件中引入Rack
import Rack from "Rack.vue" export default { components: { Rack } } 上面的方式运行时会报错组件未注册
解决方案 使用异步组件引入方式,即在RackDialog中使用如下方式引入Rack
export default { components: { Rack: () => import("@/components/Equipment/Rack/Rack.vue"), } } 组件注册机制 Vue底层在进行组件注册时采用的是递归注册的形式,会将一个顶级组件的所有后代组件进行递归注册。
但是如果出现上述我们的情况——子组件中又引入了父组件,框架在递归注册时就可能陷入死循环。
所以Vue框架底层注册机制为了避免这种情况会在这种地方停止向下递归注册。所以出现了上述的组建为注册错误。
使用了按需引入后就会在RackDialog组件激活时才引入Rack组件,就不会出现这种未注册报错了。
优化 按需引入的方式还可以使用Vue的内置组件,即动态组件更优雅的引入
---------------------
作者:兴趣使然的码仔
来源:CSDN
原文:https://blog.csdn.net/qq_41790461/article/details/121774086
版权声明:本文为作者原创文章,转载请附上博文链接!
C/C++通过shapelib开源库读取shapefile文件 shapelib下载shapelib编译C++使用二次封装 shapelib下载 链接: http://download.osgeo.org/shapelib/
shapelib编译 作者使用的是deepin操作系统(linux),下载的是shapelib-1.5.0.tar.gz压缩包,解压后会有一个源码目录shapelib-1.5.0。进入源码路径即CMakeList.txt所在路径。
命令行分别输入:
./configure mkdir build cd build cmake .. 然后在build路径下就会生成libshp.so,通过源码路径下的shapefil.h就可以调用libshp.so库
如果不想使用库,希望把源码和你的项目编译到一起可以直接将CMakeLists.txt中lib_SRC 所包含的源码文件添加到你的项目中进行编译即可
C++使用二次封装 作者在C++项目中使用到了这个库对其进行了二次封装,该项目读取的是.dbf文件和.shp文件
read_shapefile.h
#ifndef __READ_SHAPEFILE_H__ #define __READ_SHAPEFILE_H__ #include "shapefil.h" #include <unistd.h> #include <memory> #include <iostream> #include <vector> #include <assert.h> #include <bits/stdc++.h> using namespace std; class ReadShapeFile; #define SUCCESS (0) #define FAILURE (-1) using SpReadShapeFile = std::shared_ptr<ReadShapeFile>; typedef struct { double x; double y; double z; } Point3D; using Point3DS = vector<Point3D>; #define SHAPEFILE_DBF_TITLE_SIZE (50) // dbf文件标题长度 class ReadShapeFile { public: static SpReadShapeFile createSpReadShapeFile(const string &file_name) { // file_name中应为路径和文件前缀 if(access((file_name + "
1. 问题描述 scanf() 函数和 gets() 函数都可用于输入字符串,但在功能上有区别。
gets 可以接收空格,结束后自动加 '\0'
scanf 遇到 空格、回车 和 Tab 键都会认为输入结束,所以它不能接收空格,也是结束后自动加 '\0'
但是在 C++ 下,使用 gets 会报错:
2. 解决办法 后面经过查找资料,才知道 VS2015 之后就不支持 gets 了,变成了 gets_s,并且后面的括号中也不能单独写一个数组名,还需加上数组内的个数,用法如下:
gets_s(words, STLEN); 此时,编译就不会报错了:
作者 | 科技猛兽 编辑 | 极市平台
点击下方卡片,关注“自动驾驶之心”公众号
ADAS巨卷干货,即可获取
点击进入→自动驾驶之心【模型部署】技术交流群
后台回复【模型部署工程】获取基于TensorRT的分类、检测任务的部署源码!
导读
本文提出了一种对硬件友好的 DFC 注意力机制,并借助它和 GhostNet 模型提出了一种针对端侧设备的GhostNetV2 架构。
本文目录 1 GhostNetV2:长距离注意力机制增强廉价操作
(来自北京华为诺亚方舟实验室)
1.1 GhostNetV2 论文解读
1.1.1 GhostNet 回顾和本文动机
1.1.2 重新思考 Attention 对模型架构的影响
1.1.3 用于移动端架构的解耦全连接注意力机制 DFC Attention
1.1.4 借助 DFC 注意力机制增强 Ghost 模块
1.1.5 特征下采样
1.1.6 实验结果
1 GhostNetV2:长距离注意力机制增强廉价操作 论文名称:
GhostNetV2: Enhance Cheap Operation with Long-Range Attention (NeurIPS 2022 Spotlight)
论文地址 GhostNetV2:
https://openreview.net/pdf/6db544c65bbd0fa7d7349508454a433c112470e2.pdf
1.1.1 GhostNet 回顾和本文动机 GhostNet 是一种轻量级卷积神经网络,是专门为移动设备上的应用而设计的。其主要构件是 Ghost 模块,一种新颖的即插即用模块。Ghost 模块设计的初衷是使用更少的参数来生成更多特征图 (generate more features by using fewer parameters)。 我们知道,深度神经网络的每个卷积层都有一定数量的输出特征图。给定输入特征 分别是特征图的高度,宽度和通道数),Ghost 模块将输出通道分成了两个部分 (一般是对半分):
break、continue、return的使用与区别 结论先行:
break与continue:
break和continue都是用来控制循环结构的,主要作用是停止循环
它俩的区别:
1》break是跳出整个循环,continue是跳出当前循环,继续进行下一个循环
2》continue语句只用在for、while、do-while等循环体中, 常与if条件语句一起使用, 用来加速循环;break还可以在switch分支语句中使用,遇到break,就会跳出switch语句
return
函数中使用,函数遇到return就会立即停止执行并退出;后面可以跟函数的返回值,如果不跟就返回undefined;
break语句 跳出整个循环;跳出的是它所在的最近一级的循环,如果外面还有循环,外面还是会继续的
eg1:
let num = 0; const arr = [1, 2, 3, 4, 5, 6]; for (let k = 1; k <= 10; k++) { if (k % 3 == 0) { break; } num++; } console.log(num); // 2 当 k=3 时,满足条件break,跳出真个for循环语句,打印2
eg2:
let num = 0; for (let i = 0; i < 2; i++) { for (let k = 1; k <= 10; k++) { if (k % 3 == 0) { break; } num++; } } console.