虫虫首页| 资源下载| 资源专辑| 精品软件
登录| 注册

软件<b>实现</b>

  • 本代码为编码开关代码

    本代码为编码开关代码,编码开关也就是数字音响中的 360度旋转的数字音量以及显示器上用的(单键飞梭开 关)等类似鼠标滚轮的手动计数输入设备。 我使用的编码开关为5个引脚的,其中2个引脚为按下 转轮开关(也就相当于鼠标中键)。另外3个引脚用来 检测旋转方向以及旋转步数的检测端。引脚分别为a,b,c b接地a,c分别接到P2.0和P2.1口并分别接两个10K上拉 电阻,并且a,c需要分别对地接一个104的电容,否则 因为编码开关的触点抖动会引起轻微误动作。本程序不 使用定时器,不占用中断,不使用延时代码,并对每个 细分步数进行判断,避免一切误动作,性能超级稳定。 我使用的编码器是APLS的EC11B可以参照附件的时序图 编码器控制流水灯最能说明问题,下面是以一段流水 灯来演示。

    标签: 代码 编码开关

    上传时间: 2017-07-03

    上传用户:gaojiao1999

  • 【问题描述】 在一个N*N的点阵中

    【问题描述】 在一个N*N的点阵中,如N=4,你现在站在(1,1),出口在(4,4)。你可以通过上、下、左、右四种移动方法,在迷宫内行走,但是同一个位置不可以访问两次,亦不可以越界。表格最上面的一行加黑数字A[1..4]分别表示迷宫第I列中需要访问并仅可以访问的格子数。右边一行加下划线数字B[1..4]则表示迷宫第I行需要访问并仅可以访问的格子数。如图中带括号红色数字就是一条符合条件的路线。 给定N,A[1..N] B[1..N]。输出一条符合条件的路线,若无解,输出NO ANSWER。(使用U,D,L,R分别表示上、下、左、右。) 2 2 1 2 (4,4) 1 (2,3) (3,3) (4,3) 3 (1,2) (2,2) 2 (1,1) 1 【输入格式】 第一行是数m (n < 6 )。第二行有n个数,表示a[1]..a[n]。第三行有n个数,表示b[1]..b[n]。 【输出格式】 仅有一行。若有解则输出一条可行路线,否则输出“NO ANSWER”。

    标签: 点阵

    上传时间: 2014-06-21

    上传用户:llandlu

  • 这次课程设计的内容是LED、步进电机和喇叭的控制

    这次课程设计的内容是LED、步进电机和喇叭的控制,通过对步进电机的原理的掌握,学会步进电机与芯片的连接方法,以及如何控制脉冲输出,控制单片机的正转,反转,加速转和慢转等,了解步进电机速度的软件控制方法,此外要和蜂鸣器,数码管,LED结合起来,学会控制蜂鸣器的声音的长短,大小,频率,数码管的多数字稳定显示,通过软件定时实现数秒的结果,通过有规律的脉冲来控制LED灯泡循环显示。合理的选择芯片,以及芯片端口,方便程序的实现,通过程序在步进电机和它们之间切换使用,实现连续的功能状态。

    标签: LED 步进电机 控制

    上传时间: 2017-07-14

    上传用户:gundan

  • 离散实验 一个包的传递 用warshall

     实验源代码 //Warshall.cpp #include<stdio.h> void warshall(int k,int n) { int i , j, t; int temp[20][20]; for(int a=0;a<k;a++) { printf("请输入矩阵第%d 行元素:",a); for(int b=0;b<n;b++) { scanf ("%d",&temp[a][b]); } } for(i=0;i<k;i++){ for( j=0;j<k;j++){ if(temp[ j][i]==1) { for(t=0;t<n;t++) { temp[ j][t]=temp[i][t]||temp[ j][t]; } } } } printf("可传递闭包关系矩阵是:\n"); for(i=0;i<k;i++) { for( j=0;j<n;j++) { printf("%d", temp[i][ j]); } printf("\n"); } } void main() { printf("利用 Warshall 算法求二元关系的可传递闭包\n"); void warshall(int,int); int k , n; printf("请输入矩阵的行数 i: "); scanf("%d",&k); 四川大学实验报告 printf("请输入矩阵的列数 j: "); scanf("%d",&n); warshall(k,n); } 

    标签: warshall 离散 实验

    上传时间: 2016-06-27

    上传用户:梁雪文以

  • 道理特分解法

    #include "iostream" using namespace std; class Matrix { private: double** A; //矩阵A double *b; //向量b public: int size; Matrix(int ); ~Matrix(); friend double* Dooli(Matrix& ); void Input(); void Disp(); }; Matrix::Matrix(int x) { size=x; //为向量b分配空间并初始化为0 b=new double [x]; for(int j=0;j<x;j++) b[j]=0; //为向量A分配空间并初始化为0 A=new double* [x]; for(int i=0;i<x;i++) A[i]=new double [x]; for(int m=0;m<x;m++) for(int n=0;n<x;n++) A[m][n]=0; } Matrix::~Matrix() { cout<<"正在析构中~~~~"<<endl; delete b; for(int i=0;i<size;i++) delete A[i]; delete A; } void Matrix::Disp() { for(int i=0;i<size;i++) { for(int j=0;j<size;j++) cout<<A[i][j]<<" "; cout<<endl; } } void Matrix::Input() { cout<<"请输入A:"<<endl; for(int i=0;i<size;i++) for(int j=0;j<size;j++){ cout<<"第"<<i+1<<"行"<<"第"<<j+1<<"列:"<<endl; cin>>A[i][j]; } cout<<"请输入b:"<<endl; for(int j=0;j<size;j++){ cout<<"第"<<j+1<<"个:"<<endl; cin>>b[j]; } } double* Dooli(Matrix& A) { double *Xn=new double [A.size]; Matrix L(A.size),U(A.size); //分别求得U,L的第一行与第一列 for(int i=0;i<A.size;i++) U.A[0][i]=A.A[0][i]; for(int j=1;j<A.size;j++) L.A[j][0]=A.A[j][0]/U.A[0][0]; //分别求得U,L的第r行,第r列 double temp1=0,temp2=0; for(int r=1;r<A.size;r++){ //U for(int i=r;i<A.size;i++){ for(int k=0;k<r-1;k++) temp1=temp1+L.A[r][k]*U.A[k][i]; U.A[r][i]=A.A[r][i]-temp1; } //L for(int i=r+1;i<A.size;i++){ for(int k=0;k<r-1;k++) temp2=temp2+L.A[i][k]*U.A[k][r]; L.A[i][r]=(A.A[i][r]-temp2)/U.A[r][r]; } } cout<<"计算U得:"<<endl; U.Disp(); cout<<"计算L的:"<<endl; L.Disp(); double *Y=new double [A.size]; Y[0]=A.b[0]; for(int i=1;i<A.size;i++ ){ double temp3=0; for(int k=0;k<i-1;k++) temp3=temp3+L.A[i][k]*Y[k]; Y[i]=A.b[i]-temp3; } Xn[A.size-1]=Y[A.size-1]/U.A[A.size-1][A.size-1]; for(int i=A.size-1;i>=0;i--){ double temp4=0; for(int k=i+1;k<A.size;k++) temp4=temp4+U.A[i][k]*Xn[k]; Xn[i]=(Y[i]-temp4)/U.A[i][i]; } return Xn; } int main() { Matrix B(4); B.Input(); double *X; X=Dooli(B); cout<<"~~~~解得:"<<endl; for(int i=0;i<B.size;i++) cout<<"X["<<i<<"]:"<<X[i]<<" "; cout<<endl<<"呵呵呵呵呵"; return 0; } 

    标签: 道理特分解法

    上传时间: 2018-05-20

    上传用户:Aa123456789

  • 酒店管理系统_自建源码

    拥有数据库的windows应用软件,实现了用户的登录注册、数据库的增删改查、酒店管理等功能,界面整洁

    标签: 管理系统 源码

    上传时间: 2019-01-02

    上传用户:qazxdrgbhujmko123

  • 频谱分析仪

    音频工作者对频谱分析仪一定不陌生,这是一种用来对被测信号进行频率及频谱分析的重要 测量仪器,广泛应用于电声测量、音频制作、信号分析乃至振动测试等领域。随着数字技术的 飞速发展,这种复杂仪器已经可以在一台普通的多媒体计算机上用软件来实现

    标签: 频谱分析仪

    上传时间: 2019-07-17

    上传用户:LH.TAN

  • TwinCAT 3 入门教程 Version 4.13

    TwinCAT 3  入门教程Version 4.13毕孚自动化设备贸易(上海)有限公司2020 年 10 月前言TwinCAT3 是基于 PC 的控制软件并且它开启了一个新的时代,是倍福公司历史上又一个里程碑。特别是在高效的工程领域中 TwinCAT3 将模块化思想以及其灵活的软件架构,融入到整个平台。几乎每一种控制应用程序都能在 TwinCAT3 中实现。从印刷设备、木工设备、塑料机械或门窗设备、风力发电机和实验台,亦或是楼宇,诸如剧院,以及运动场,一切都可以通过 TwinCAT3 实现自动化。用户可以选择不同的编程语言来实现这些应用。除了经典的 PLC 编程语言的IEC 61131-3,用户现在也可以用高级语言 C 或 C++,以及 MATLAB®/ Simulink®。整合了运动功能从而简化了工程项目,以及全新的安全应用编辑更加人性化。这些以及更多的特性都证明了为什么 TwinCAT3 也名为扩展的自动化。本书针对任何想要学习倍福 TwinCAT3 软件如何实现基于 PC 控制编程的读者,阅读本书需要预先具备 IEC61131-3,C/C++或 MATLAB®/ Simulink®中至少一种编程语言的知识。本书内容的架构安排如下:第一章介绍 TwinCAT3 软件架构,如何选择合适的 Visual Studio,以及如何安装帮助系统。第二章介绍了 TwinCAT3 试用版授权以及完整版授权激活方式,同时介绍了两种全新硬件授权设备的介绍和使用。第三章介绍了 TwinCAT3 中如何扫描硬件,以及虚拟层和物理层直接的连接如何实现。第四章围绕 IEC61131-3 的概念展开了说明,讲述了 IEC61131-3 标准的核心概念,语法以及 IEC61131-3 新标准扩充的部分。第五章介绍如何创建一个 TwinCAT3 项目,并且选择 ST(结构文本)语言进行简单编程,调用功能块,在线检测与调试的过程。第六章介绍如何选择 PLC 中自带的 HMI 功能编辑一个完整的界面,并且实现全屏显示,用户管理,网页浏览等功能。第七章全面介绍 TwinCAT3 中 Measurement 功能的使用,包括如何创建一个

    标签: twincat

    上传时间: 2021-12-17

    上传用户:shjgzh

  • 超声波测距在智能机器人中的开发与应用

    超声波测距在智能机器人中的开发与应用摘 要:本文提出了在机器人控制中,使用软件方法实现超声波测距机器人避障功能的工作原理和设计 方法。该系统在使用过程中,测量精度高,机器人避障准确,可靠,真正实现了智能化控制。 关键词:机器人 超声波 测距 软件触发 Abstract: The 0n pnnc eanddesignm d10d ofu]U~ sordc are descx'~edindetail fora intenigencero~ ic . ByI|8i“gthissystem,therobotmakesaccta~elyavoidingdmwhackhi# reliability. 1畸 wo阿s:ro tultro-sor~c聊 曲 喀sot~aretrigger 1 引言 在智能机器人的研制开发中,很重要 的一部 分就是机器人 要能实现避 障功能 ,即通过传感器 的作用 ,探测机器人行进道路 上是否碰到障碍。 若碰到了障碍 ,机器人应该 自动转向 ,躲避障碍 。 本文所介 绍的超声 波测距方法 ,应用 于 ET一18 Hem智能机器人中。通过超声波测距 ,该智能机 器人实现了对步进电动机的智能控制及运动控制 方式的灵活应用。同时,超声波测距作为一种非 接触 的检测方式 ,和红外 、激光及无线电测距相 比,在近距范 围内有不受光线影响、结构简单 、成 本低等优点 2 超声波测距基本原理 超声波是指频率在 2000Hz以上 ,不能引起正 常人听觉反应 的机械振动波 ,是物体 的机械振 动 在弹性介质 中传播所形成 的机械振动波。由于超 声波具有非常短 的波长 ,可 以聚集成狭小 的发

    标签: 超声波测距 智能机器人

    上传时间: 2022-02-16

    上传用户:jiabin

  • 基于SAE+J1939协议的汽车CAN总线控制系统的设计与测试

    随着汽车电子技术的发展,汽车作为一种融合了当代多种高新技术的交通工具,需要采用越来越多的电子控制系统,这些复杂的系统控制需要检测及交换大量数据,传统的点对点控制方式不但布线复杂、昂贵,而且可靠性差、重量大维护成本高,已经无法满足现代汽车的通信要求,为了解决上面这些问题,德国BOSCH公司的CAN总线控制应运而生,且日前得到了广泛应用。为了应对当前某些整车厂对车载CAN总线控制系统应用的需求,以及解决由于没有一个开放的CAN应用层协议,使不同配套厂的设备之间不能互操作的问题论文以基于SAEJ939协议的汽车CAN总线控制系统设计与测试作为研究课题制定了基于SAEJ939协议的CAN应用层协议并设计开发了CAN总线控制模块结合项目组已有的技术基础,论文首先研究了CAN总线协议特点和实现该技术的要求,并研究分析了CAN总线的应用层协议规范SAE939,在此基础上,根据某整车厂需求,分别从网络拓扑结构的总体设计、模块的信号定义、信息发送周期选择、报文优先级分配以及节点地址定义等几个方面设计制定了一套具有良好扩展性的汽车CAN应用层协议。此外,课题还完成了CAN总线控制模块的全部硬件设计,通过软件开发实现了所制定的CAN应用层协议以及各控制模块的功能为了验证CAN总线系统设计方案和所制定的CAN应用层协议的可行性,以及测试网络性能,课题对CAN总线控制模块和CAN网络系统进行CAN模块的致性测试,CAN控制模块通信功能测试,以及应用cAN总线开发工具 CANoe进行的CAN总线仿真实验和整个系统平台测试。通过研究这些实验和测试的结果验证了CAN总线控制系统的实时性、可靠性和稳定性,证明了课题设计方案可行此外,误题的研究也为实现具有自主知识产权的汽车CAN总线控制技术的产品化积累了经验,课题也因此具备继续研究开发的意义和良好的经济的前景

    标签: 汽车CAN总线

    上传时间: 2022-03-23

    上传用户:fliang