在计算机视觉领域,相机标定是一项至关重要的任务,它能够帮助我们校正图像畸变,获取相机的内在参数,从而实现精确的三维重建和物体定位。
Tsai的标定方法是一种早期提出的、广泛应用于相机标定的经典算法,由Richard Tsai在1987年提出。
本篇文章将深入探讨Tsai的相机标定方法及其在Matlab环境下的实现。
我们来理解Tsai的相机标定理论基础。
该方法基于多视图几何,通过一组已知坐标点(通常是在平面棋盘格上的特征点)在图像中的投影,来求解相机的内在参数矩阵和外在参数矩阵。
内在参数包括焦距、主点坐标和径向畸变系数,而外在参数则表示相机相对于标定板的位姿。
Tsai的标定流程主要包括以下几个步骤:1. 数据采集:拍摄多张包含标定板的图片,确保标定板在不同角度和位置出现,以获取丰富的视图信息。
2. 特征检测:在每张图片中检测并提取标定板的角点,常用的方法有角点检测算法,如Harris角点检测或Shi-Tomasi角点检测。
3. 建立世界坐标与像素坐标的对应关系:将标定板角点在世界坐标系中的位置与在图像中的像素坐标对应起来。
4. 线性化问题:通过极几何约束,将非线性问题线性化,可以使用高斯-牛顿法或Levenberg-Marquardt法进行迭代优化。
5. 求解参数:求解内在参数矩阵K和外在参数矩阵R、t,其中R表示旋转矩阵,t表示平移向量。
6. 校正与验证:利用求得的参数对图像进行畸变校正,并通过重投影误差来评估标定结果的准确性。
在Matlab环境下实现Tsai的标定方法,可以充分利用其强大的数学计算能力和可视化功能。
需要编写代码来完成上述的数据采集和特征检测。
然后,利用内置的优化工具箱进行参数估计。
可以绘制图像和标定板的重投影误差,以直观地查看标定效果。
在提供的压缩包文件e19bb35c303d499aa5c2568a73f0a35f中,可能包含了实现上述过程的Matlab源代码。
代码可能分为几个部分,包括角点检测、标定板坐标匹配、线性化优化以及参数解算等模块。
用户可以通过阅读和运行这些代码,理解Tsai标定方法的工作原理,并将其应用到自己的项目中。
Tsai的相机标定方法是计算机视觉中的一个经典算法,它通过解决非线性优化问题,实现了相机参数的有效估计。
在Matlab环境下,我们可以方便地实现这一算法,对相机进行标定,为后续的视觉应用提供准确的先验信息。
对于初学者来说,理解和实践这个方法,不仅可以加深对计算机视觉原理的理解,也能提高编程和调试能力。
2025/6/20 1:32:22 5KB
1

在IT行业中,后端开发是构建应用程序不可或缺的一部分,而Python语言因其简洁明了的语法和丰富的库支持,已经成为后端开发领域中的热门选择。
"backend_python"这个项目可能是一个专门探讨使用Python进行后端开发的资源集合。
让我们深入了解一下Python在后端开发中的应用和相关知识点。
Python作为一门解释型、面向对象的高级编程语言,其特点在于可读性强,易于学习,适合快速开发。
在后端开发中,Python主要通过以下几个方面展现其强大功能:1. **Web框架**:Python拥有许多成熟的Web框架,如Django、Flask、Tornado等。
Django是一个功能齐全的MVC(Model-View-Controller)框架,提供了强大的ORM(对象关系映射)和内置的管理界面,适合大型复杂项目。
Flask则轻量级且灵活,适用于快速开发小型应用。
Tornado则以其异步I/O模型在高并发场景下表现出色。
2. **数据库操作**:Python支持多种数据库,如MySQL、PostgreSQL、SQLite等,通过相应的数据库连接库如pymysql、psycopg2、sqlite3等进行数据交互。
ORM库如SQLAlchemy和Peewee可以进一步简化数据库操作。
3. **API开发**:Python可以方便地创建RESTful API,通过框架如Flask-Restful或Django REST framework,可以快速构建符合HTTP标准的接口,便于前后端分离。
4. **数据处理与分析**:Python的Pandas库为数据分析提供了强大的工具,NumPy和SciPy则在科学计算领域有着广泛的应用。
对于大数据处理,Apache Spark可以通过PySpark接口与Python结合,实现高效的数据处理。
5. **并发与异步**:Python 3.5及以后版本引入了asyncio模块,支持协程和异步编程,使得Python也能处理高并发场景。
6. **部署与运维**:Python的Fabric和Ansible可以用于自动化部署和系统管理,而Gunicorn和uWSGI则是常用的Python WSGI服务器,用于承载Web应用。
7. **微服务架构**:Python在构建微服务方面也十分便捷,利用Flask或Django可以快速构建独立的服务单元。
8. **测试**:Python的unittest、pytest和behave等库提供了全面的测试支持,确保代码质量和稳定性。
9. **安全**:Python的requests库用于安全的HTTP请求,而cryptography和pyOpenSSL库则提供了加密和网络安全相关功能。
10. **持续集成/持续部署(CI/CD)**:Jenkins、GitLab CI/CD、Travis CI等工具都可以与Python项目很好地集成,实现自动化的测试和部署流程。
"backend_python-main"这个文件名可能是项目的主要入口或者源代码目录,包含了项目的主程序、配置、路由、模型等核心部分。
通过对这个目录的深入研究,可以更具体地了解项目如何运用以上知识点进行实际的后端开发。
Python在后端开发中的应用广泛且深入,无论是在小型快速原型还是大型企业级应用中,都能发挥其独特的优势。
2025/6/19 23:26:33 12KB
1

"plchart图表"是一款专为数据可视化设计的工具,它提供了丰富的图表类型和灵活的定制选项,使得用户能够轻松地创建出美观且具有洞察力的数据展示。
235K的大小表明这是一个轻量级的解决方案,适合各种环境,尤其是那些对资源消耗有严格限制的项目。
在实际应用中,"plchart"通常被用作数据分析和报告的一部分,它能够帮助用户将复杂的数据转化为易于理解的图形。
例如,你可以使用它来创建柱状图、折线图、饼图、散点图以及热力图等多种图表类型,这些图表在商业智能、科研分析或者教育教学等场景下都非常常见。
"使用实例都包括在内"意味着下载的压缩包中可能包含了一些示例代码或预设的图表模板,这对于初学者来说是极其宝贵的资源。
通过查看和修改这些实例,用户可以快速掌握plchart的使用方法,并了解到如何根据自己的数据调整图表参数,以达到最佳的视觉效果。
在"效果集合"部分,很可能包含了plchart的各种预览效果,展示了它在不同应用场景下的表现。
这不仅让用户能直观地看到图表的样式和功能,也便于他们在设计时寻找灵感。
可能涵盖动态效果、交互式操作以及自定义主题等方面,使得最终的图表既实用又具有吸引力。
"plchart"可能支持多种编程语言,如JavaScript、Python或者PHP等,因此无论你熟悉哪种语言,都能找到相应的接口来调用和控制图表。
此外,其可能还提供了详细的API文档和用户手册,帮助开发者更好地理解和利用这个库。
在实际操作中,使用plchart创建图表的步骤通常包括:导入数据、选择合适的图表类型、设置图表属性(如颜色、大小、标签等)、添加交互功能(如点击事件、数据悬停提示等)以及调整布局和样式。
对于高级用户,可能还需要了解如何自定义图表组件,以满足特定的需求。
"plchart图表"是一个全面的数据可视化工具,它集易用性、灵活性和功能性于一体,适用于各种需要数据展示的场合。
通过深入学习和实践,你可以用它来创建出专业且引人入胜的图表,提升数据的解析度和沟通效率。
2025/6/19 23:26:24 235KB
1

LSTM(Long Short-Term Memory)是一种特殊的循环神经网络(RNN),专为解决传统RNN在处理长期依赖问题上的不足而设计。
在序列数据的建模和预测任务中,如自然语言处理、语音识别、时间序列分析等领域,LSTM表现出色。
本项目“LSTM-master.zip”提供的代码是基于TensorFlow实现的LSTM模型,涵盖了多种应用场景,包括多步预测和单变量或多变量预测。
我们来深入理解LSTM的基本结构。
LSTM单元由输入门、遗忘门和输出门组成,以及一个称为细胞状态的特殊单元,用于存储长期信息。
通过这些门控机制,LSTM能够有效地选择性地记住或忘记信息,从而在处理长序列时避免梯度消失或梯度爆炸问题。
在多步预测中,LSTM通常用于对未来多个时间步的值进行连续预测。
例如,在天气预报或者股票价格预测中,模型不仅需要根据当前信息预测下一个时间点的结果,还需要进一步预测接下来的多个时间点。
这个项目中的“多步的迭代按照步长预测的LSTM”可能涉及使用递归或堆叠的LSTM层来逐步生成未来多个时间点的预测值。
另一方面,单变量预测是指仅基于单一特征进行预测,而多变量预测则涉及到多个特征。
在“多变量和单变量预测的LSTM”中,可能包含了对不同输入维度的处理方式,例如如何将多维输入数据编码到LSTM的输入向量中,以及如何利用这些信息进行联合预测。
在多变量预测中,LSTM可以捕获不同特征之间的复杂交互关系,提高预测的准确性。
TensorFlow是一个强大的开源库,广泛应用于深度学习模型的构建和训练。
在这个项目中,使用TensorFlow可以方便地定义LSTM模型的计算图,执行反向传播优化,以及实现模型的保存和加载等功能。
此外,TensorFlow还提供了丰富的工具和API,如数据预处理、模型评估等,有助于整个预测系统的开发和调试。
在探索此项目时,你可以学习到以下关键点:1. LSTM单元的工作原理和实现细节。
2. 如何使用TensorFlow构建和训练LSTM模型。
3. 处理序列数据的技巧,如时间序列切片、数据标准化等。
4. 多步预测的策略,如滑动窗口方法。
5. 单变量与多变量预测模型的差异及其应用。
6. 模型评估指标,如均方误差(MSE)、平均绝对误差(MAE)等。
通过深入研究这个项目,你不仅可以掌握LSTM模型的使用,还能提升在实际问题中应用深度学习解决序列预测问题的能力。
同时,对于希望进一步提升技能的开发者,还可以尝试改进模型,比如引入注意力机制、优化超参数、或者结合其他序列模型(如GRU)进行比较研究。
2025/6/19 19:17:59 5.42MB
1

《分店变价作业规范》是一份针对超市和零售行业管理的专业文档,旨在提供一套标准的操作流程,确保各个分店在商品价格变动时能够统一、高效地执行。
这份规范对于优化零售业务流程、提高运营效率、维护品牌形象以及增强客户满意度至关重要。
分店变价作业规范通常包括以下几个核心部分:1. 变价决策:变价不是随意进行的,它涉及到市场调研、竞争分析以及公司策略。
变价决策通常由总部根据库存状况、销售数据和市场趋势制定,并向下传达。
2. 信息同步:一旦价格变动决定下来,所有相关信息必须及时、准确地传达给各分店。
这包括通过内部系统更新价格数据库,发送电子邮件通知,或使用专门的零售管理系统进行自动更新。
3. 实施流程:分店接到变价指令后,需要按照规定的步骤操作,如更换价格标签、调整POS系统中的商品价格、更新电子显示屏等。
同时,员工培训也是关键,确保他们理解并能正确执行新的价格策略。
4. 监控与反馈:在变价实施后,总部需要收集反馈,监控变价效果。
这可能包括销售额变化、客户反应、退货率等数据,以便评估变价策略的成功与否,并适时进行调整。
5. 法规遵从:在变价过程中,必须遵守当地的商业法规,如价格公示要求、消费者权益保护法等。
任何违规行为都可能导致法律纠纷,影响企业声誉。
6. 审核与审计:为了确保变价作业的合规性和准确性,定期的审核和审计是必要的。
这可以防止错误发生,同时也能发现潜在的改进点。
7. 应急处理:在遇到突发情况,如系统故障或临时政策变更时,要有应急响应机制,保证变价工作不受影响。
《分店变价作业规范》这份文档详细阐述了这些流程,不仅提供了操作指南,还可能包含实例分析、最佳实践分享,帮助管理者和员工更好地理解和执行变价作业。
通过学习和应用这些规范,零售企业可以提升整体运营效率,降低出错风险,从而在竞争激烈的市场环境中保持优势。
因此,无论是新手还是经验丰富的零售业从业者,都值得花时间研读和掌握这份宝贵的参考资料。
2025/6/19 18:22:24 6KB
1

【大功率近红外半导体激光对蝗蝻致死作用的研究】这篇研究主要探讨了大功率近红外半导体激光对蝗蝻(Oedaleus asiaticus B.Bienko Nymphae)的致死效应,旨在寻找一种环保且高效的蝗虫防控方法,以替代传统的化学药剂。
研究中使用的激光器具有2W的功率和808nm的波长,这种类型的激光属于近红外范围,其热效应可能会对生物组织产生显著影响。
研究者针对三龄及以前龄期和三龄期后的亚洲小车蝗蝻进行了分组实验。
实验中,激光束直接照射蝗蝻的头部,以不同的功率密度和照射时间进行测试,并在照射后立即、5小时后以及次日观察蝗蝻的存活状态。
通过对比实验组和对照组,发现激光照射的蝗蝻在照射部位出现热损伤,活动能力显著下降。
随着激光剂量的增加和照射时间的延长,蝗蝻的活动能力进一步降低,死亡率逐渐升高。
研究结果显示,近红外激光对蝗蝻头部的照射具有良好的致死效果,且年龄较小的蝗蝻对激光的敏感度更高,致死效果更佳。
这是因为较年轻的蝗蝻身体结构相对脆弱,对热能的耐受性较低。
这一发现对于早期防治蝗灾具有重要意义,可以在蝗虫发育初期就有效控制其数量,防止其进一步扩散和造成更大的农作物损失。
激光作为一种非接触式杀虫手段,具有精准、快速和环境污染小的优点。
然而,该研究并未深入探讨激光对其他生物的影响,以及在实际操作中的可行性、成本效益和技术难题。
未来的研究可能需要考虑这些问题,同时,还需要进一步优化激光参数,以达到最佳的杀虫效果,同时避免对生态环境的潜在影响。
此外,该研究得到了高校博士点基金的支持,表明了学术界对这一领域的重视。
作者姚明印和周强分别是博士研究生和教授,他们的研究方向包括光机电生物诱导技术,这为理解激光在生物防治中的应用提供了专业背景。
这项研究为利用大功率近红外半导体激光控制蝗虫提供了理论基础,但实际应用仍需结合生物学、环境科学和技术工程等多方面的考量。
通过深入研究和优化,激光技术有望成为一种有效的生物控制策略,为全球的蝗虫防治提供新的解决方案。
2025/6/19 18:22:09 99KB
1

【知识点详解】1. **分数的基本性质**:题目中涉及到了分数的加减乘除以及化简,例如“5个15是1”,这考察了分数乘法;
“18个91是171”考察了分数乘法的运算。
同时,“18个91”是一个整数,说明了分数乘法可以得到整数结果。
2. **分数的比较**:题目要求填写“>”、“<”或“=”,如“32○0.66”,这需要理解分数和小数之间的转换及比较大小的方法。
此外,“251○0.4”也涉及到分数与小数的比较,需要掌握分数和小数的等值关系。
3. **分数的运算**:题目中“512+34+112”等计算题,要求学生掌握分数的加减法运算规则,特别是同分母分数和异分母分数的加减。
4. **分数的最简形式**:如“如果一个分数的分子和分母的最大公因数是1,那么这个分数就是最简分数”,这涉及到了分数的化简和最简形式的概念。
而“1812的最简分数是96”则错误,因为18和12的最大公因数不为1,它们可以进一步化简。
5. **真分数的理解**:题目指出“分母是10的真分数共有10个”,这是对真分数定义的理解,即分子小于分母的分数。
6. **分数应用题**:第三部分的题目涉及实际问题的应用,如冰激凌销售情况的分析,要求根据销售比例来决定进货量,这需要对分数有直观的理解并能将其应用于实际问题。
7. **分数的解方程**:在解方程部分,例如“2352x”和“5.0216x”,需要用到分数乘法的逆运算,即除法,来求解未知数。
8. **分数的混合运算**:脱式计算题要求进行分数的混合运算,包括加减乘除,并可能需要简化运算过程。
9. **分数的比较与选择**:在选择题中,如“小明看一本书,第一天看了全书的61,第二天看了全书的31,两天共看了全书的91”,这需要理解分数的加法运算来解决问题。
10. **分数在实际生活中的应用**:最后一部分的问题涉及到用分数解决实际生活中的问题,如布料的使用、修路长度的计算以及学生在课堂上的活动时间分配,这些都是分数在实际问题中的应用实例。
通过这份模拟测试,学生可以巩固和提升对分数的理解,熟练掌握分数的运算、比较、化简以及在实际问题中的应用。
同时,判断题和选择题也测试了他们对分数基本概念和性质的掌握程度。
2025/6/19 18:22:03 195KB
1

【百度地图Demo详解】在IT行业中,地图API的使用已经成为许多应用不可或缺的一部分,尤其是在移动开发领域。
百度地图作为国内主流的地图服务提供商之一,为开发者提供了丰富的API和SDK,便于他们在项目中集成地图功能。
本篇将详细介绍“百度地图Demo”,以及如何通过它来理解和运用百度地图API。
我们要理解什么是“Demo”。
在编程和软件开发中,Demo通常是指一个简化的示例程序,它展示了特定功能或技术的实际应用。
百度地图Demo就是一个包含了基础和进阶功能的实例,帮助开发者快速上手并理解如何在自己的应用中集成百度地图服务。
1. **注册与获取API密钥** 在使用百度地图API之前,我们需要在百度地图开放平台注册一个账号,并创建应用以获取API密钥。
这个密钥是我们在集成地图服务时必须提供的,用于识别调用来源,确保服务的安全性和可控性。
2. **基本地图展示** 百度地图Demo中的基础功能包括加载地图、设置缩放级别、平移和旋转地图。
这可以通过JavaScript API实现,通过创建地图实例、指定容器元素和设置地图中心点坐标来完成。
3. **标注与覆盖物** 在地图上添加标注可以指示特定地点,例如商店、学校等。
百度地图API提供了多种类型的覆盖物,包括点标记、信息窗口、多边形、圆等。
开发者可以根据需求自定义样式和交互行为。
4. **地理编码与反地理编码** 地理编码是将地址转换为坐标的过程,反地理编码则是将坐标转换为地址。
这两个功能在地图应用中非常实用,例如搜索附近的地点或者根据用户点击的位置显示相关信息。
5. **路线规划** 百度地图提供了丰富的路径规划API,包括驾车、公交、步行等多种方式。
开发者可以定制起点和终点,API会返回详细的路线信息,包括距离、预计时间、步骤等。
6. **实时交通信息** 结合百度地图的交通数据,开发者可以展示实时路况,帮助用户避开拥堵区域,提升出行效率。
7. **地图事件监听** 通过监听地图的点击、拖动等事件,开发者可以实现更丰富的交互功能,比如在用户点击地图时弹出信息窗口,或者在拖动地图时更新定位点。
8. **离线地图** 虽然“student20120923.bak”和“stumanager”两个文件名看起来不像是直接关联百度地图Demo的文件,但它们可能代表了对离线地图数据的备份或管理。
离线地图是针对网络环境不稳定或节省流量场景的一种解决方案,开发者可以通过百度地图SDK实现离线地图的下载、存储和使用。
9. **地图样式自定义** 百度地图允许开发者自定义地图样式,包括更改颜色、隐藏特定图层、设置透明度等,以适应不同应用场景的需求。
10. **集成定位服务** 百度地图API提供了定位服务,可以获取设备的当前位置,同时支持室内定位和高精度定位。
开发者可以结合这些功能实现导航、签到等应用。
“百度地图Demo”是一个全面的教程,涵盖了地图集成的各个方面。
通过学习和实践,开发者不仅可以了解百度地图API的基本用法,还能掌握如何在实际项目中灵活运用,为用户提供更加便捷和丰富的地图体验。
2025/6/19 16:46:25 19.3MB
1

颜色分类leetcode哈里斯角Kps和描述符提取这是纯numpy的Hog特征提取特征描述符特征描述符是图像或图像块的表示,它通过提取有用信息并丢弃无关信息来简化图像。
通常,特征描述符将大小为宽x高x3(通道)的图像转换为长度为n的特征向量/数组。
在HOG特征描述符的情况下,输入图像的大小为64x128x3,输出特征向量的长度为3780。
请记住,可以针对其他大小计算HOG描述符,但在这篇文章中,我坚持使用原始论文中提供的数字,以便您可以通过一个具体示例轻松理解该概念。
这一切听起来不错,但什么是“有用的”,什么是“无关紧要的”?要定义“有用”,我们需要知道它“有用”是为了什么?显然,特征向量对于查看图像是没有用的。
但是,它对于图像识别和对象检测等任务非常有用。
当将这些算法产生的特征向量输入到支持向量机(SVM)等图像分类算法时,会产生良好的结果。
但是,什么样的“特征”对分类任务有用?让我们用一个例子来讨论这一点。
假设我们要构建一个对象检测器来检测衬衫和外套的纽扣。
纽扣是圆形的(在图像中可能看起来是椭圆形的)并
2025/6/19 13:18:46 459KB
1

【系统测试报告实例】是详述软件测试过程和结果的文档,主要目的是评估软件质量、分析测试过程,并为未来的测试活动提供参考。
本报告聚焦于XX后台管理系统,涵盖了测试总结、测试概要、测试环境等多个方面。
在【引言】部分,报告明确了编写目的:1. 分析测试结果以评估软件质量。
2. 通过分析测试过程、产品和资源,为后续测试计划提供指导。
3. 检视测试执行与测试计划的符合程度。
4. 针对发现的系统缺陷提出修复和预防建议。
【背景】和【用户群】未给出具体信息,但通常会包含项目的业务背景、目标用户和预期读者。
【定义】中列出了严重bug的标准,主要包括系统无响应、页面无法显示、操作异常错误以及必填字段验证失败等情况。
【测试对象】在这份报告中被省略,一般会详细列出测试的系统或模块。
【测试阶段】表明这是系统测试阶段,主要关注整个系统的综合功能和性能。
【测试工具】提到使用了Bugzilla作为缺陷管理系统,用于跟踪和管理测试中发现的问题。
【参考资料】列出了涉及的需求文档、设计说明、测试计划和用例等,这些是测试活动的基础。
【测试概要】提供了关键数据:- 测试从2007年7月2日开始,持续39天。
- 测试了174个功能点,执行了2385个测试用例。
- 发现了427个bug,其中严重级别68个,无效44个。
- 有11个测试版本,B1至B5是计划内的迭代开发,B6至B11为回归测试版本。
- 版本发布和测试进度与计划基本吻合,部分版本因延迟增加了额外工作日。
【进度回顾】详细记录了各版本的开始、完成时间及是否需要加班和增加资源。
【测试执行】强调了严格按照计划执行,覆盖了所有测试对象,遵循了测试策略和用例。
【测试用例】分为功能性测试和易用性测试:- 功能性测试涵盖了查询、添加、修改、删除等主要功能,以及分配酒店、权限、渠道绑定等次要功能,确保需求规定的输入输出和限制条件得到验证。
- 易用性测试关注操作提示信息的正确性、一致性和可理解性,以及必填项标识和输入方式,还有中文界面的本地化一致性。
【测试环境】部分介绍了软硬件配置,包括应用服务器、数据库服务器和客户端的CPU、内存、硬盘和操作系统等信息。
这份报告全面展示了XX后台管理系统测试的全貌,为项目管理和后续测试提供了重要参考。
通过这样的报告,可以清晰地了解测试的深度和广度,以及软件的质量状况。
对于项目团队来说,它不仅是评估和改进产品质量的依据,也是提升项目管理效率的重要工具。
2025/6/19 9:27:49 625KB
1
共 1000 条记录 首页 上一页 下一页 尾页
在日常工作中,钉钉打卡成了我生活中不可或缺的一部分。然而,有时候这个看似简单的任务却给我带来了不少烦恼。 每天早晚,我总是得牢记打开钉钉应用,点击"工作台",再找到"考勤打卡"进行签到。有时候因为工作忙碌,会忘记打卡,导致考勤异常,影响当月的工作评价。而且,由于我使用的是苹果手机,有时候系统更新后,钉钉的某些功能会出现异常,使得打卡变得更加麻烦。 另外,我的家人使用的是安卓手机,他们也经常抱怨钉钉打卡的繁琐。尤其是对于那些不太熟悉手机操作的长辈来说,每次打卡都是一次挑战。他们总是担心自己会操作失误,导致打卡失败。 为了解决这些烦恼,我开始思考是否可以通过编写一个全自动化脚本来实现钉钉打卡。经过一段时间的摸索和学习,我终于成功编写出了一个适用于苹果和安卓系统的钉钉打卡脚本。
2024-04-09 15:03 15KB 钉钉 钉钉打卡