第二次实验报告
Ev2实验报告
含水率对 Ev2 值的影响试验研究①目的:通过测量不同含水率的Ev2 值,分析沙土在不同含水率时对Ev2 值的影响。
②原理:变形模量 Ev2 试验是通过圆形承载板和加载装置对地面进行第一次加载和卸载后,再进行第二次加载,用测得的承载板下应力σ和与之相对应的承载板中心沉降量 S ,来计算变形模量 Ev2、 Ev1 及Ev2/Ev1 值的试验方法。
变形模量 Ev2 是反映荷载作用下土体反抗变形能力的刚度参数。
变形模量 Ev2 测试仪器应包括承载板、范蠡装置、加载装置、荷载量测装置及沉降量测装置。
JBM-2 型变形模量 Ev2 测试仪测试仪箱承载板为圆形钢板,承载板直径为300mm±0.2mm,厚度为 25mm ±0.2mm ,材质为 Q345 钢。
承载板上应带有水准泡。
承载板加工表面粗糙度应不大于 6.3um。
反力装置的承载能力应大于最大试验荷载 10kN 以上。
加载装置的液压千斤顶应通过高压油软管与手动液压泵连接。
千斤顶顶端应设置球铰,并配有可调节丝杆和加长杆件,以便与各种不同高度的反力装置相适应。
高压油软管长度应不小于 2m ,两端应装有自动开闭阀门的快速接头,以防止液压油漏出。
手动液压泵上应装有可调节减压阀,可准确地对荷载板进行分级加、卸载。
为使力准确传递,千斤顶两边应固定,并确保不倾斜。
千斤顶活塞的行程应不小于 150mm。
在试验过程中,应保证千斤顶高度不超过 600mm。
荷载量测表量程应达到最大试验荷载的1.25 倍,最大误差不大于 1 %。
荷载量测表显示值应能保证承载板荷载有效位至少达到 0.001MPa。
① 沉降量测装置应由测桥和测表组成。
②测桥的测量臂可采用杠杆式(见图 2-1 )或者垂直抽拉式(见图 2-2 )。
测量臂应有足够的刚度。
图 2-1 杠杆式测量臂1—触点 2—承载板 3—千斤顶 4—加长杆件 5—反力装置6—沉降量测表 7—支撑架 8—杠杆支点 9—测量臂 10—支撑座图 2-2 垂直抽拉式测量臂1—触点 2—承载板 3—千斤顶 4—加长杆件 5—反力装置6—沉降量测表 7—支撑架 8--垂直支架 9—支撑座③ 承载板中心至测桥支撑座的距离应大于 1.25m。
第二次实验报告
《VLSI》第二次实验报告
系别:班级:
学号:姓名:
日期:指导教师:
一、实验内容:
1.对反相器电路进行DRC验证
2.对反相器电路进行LVS验证。
3.对反相器电路进行寄生参数提取
4.对反相器电路进行后仿真
二、实验完成步骤及结果:
1、对反相器电路进行DRC验证
1)初次仿真结果截图:
2)错误分类及改正方法:
3)正确通过后的结果截图:
2、对反相器电路进行LVS验证
1)初次仿真结果截图:
2)错误分类及改正方法:
3)正确通过后的结果截图:
注意:如果一次通过(无错误),只需完成3)即可。
3、后仿真
1)修改后的网表文件
三、调试和运行程序过程中产生的问题及采取的措施:
四、心得:。
南京邮电大学-操作系统实验报告
课内实验报告课程名:操作系统任课教师:沈超专业:信息管理与信息系统学号:姓名:二○一六至二○一七年度第一学期南京邮电大学经济与管理学院Process[numberschedul].order=tempcounter;}程序结果截图:二、银行家算法(网上借鉴)银行家算法,当进程提出资源申请时,系统首先检查该进程对资源的申请量是否超过其最大需求量及系统现有的资源能否满足进程需要。
若超过,则报错,若不能满足,则让该进程等待;否则进一步检查把资源分给该进程后系统能否出于安全状态,若安全,则分配,否则置该进程为等待资源状态。
算法实现过程:设进程i 提出请求REQUEST [j] ,则银行家算法按如下规则进行判断。
(1) 如果REQUEST [i] [j]<= NEED[i][j] ,则转(2) ;否则,出错。
(2) 如果REQUEST [i] [j]<= A V AILABLE[i][j] ,则转(3) ;否则,出错。
(3) 系统试探分配资源,修改相关数据:A V AILABLE[j]-=REQUEST[i][j];ALLOCATION[i][j]+=REQUEST[i][j];NEED[i][j]-=REQUEST[i][j];(4) 系统执行安全性检查,如安全,则分配成立;否则试探险性分配作废,系统恢复原状,进程等待。
Check()关键代码:{int k, f, no=0;int work[M],a[M];char finish[M];anquan=1;for(i=0;i<n; i++) finish[i]='F';for(j=0;j<m; j++) work[j]=available[j]; k=n;do{ for (i=0;i<n; i++){if (finish[i]=='F'){ f=1;for (j=0;j<m; j++)if (need[i][j]>work[j]) printf("处于安全状态.");printf("安全序列号:");for (i=0;i<n;i++) printf ("%d ",a[i]); printf("\n");printf("进程");printf(" ");printf(" Max ");rintf(" ");rintf("allocation");printf(" ");printf("need");printf(" ");f=0;if (f==1)//找到还没完成的且需求数小于可提供进程继续运行的{ finish[i]='T';a[no++]=i;//记录安全序列号for (j=0;j<m; j++)work[j]=work[j]+allocation[i][j];//释放该进程已分配的资源available[j] =work[j];}}}k--; }while(k>0);f=1;for (i=0;i<n; i++)//判断有没有进程没完成{ if (finish[i]=='F'){f=0;break; }} if (f==0) {printf("不安全状态!\n");anquan=0;} else {printf("available");printf("\n");for (i=0;i<n; i++){ printf("%2d",i);printf(" ");for(j=0;j<m; j++)printf("%2d",max[i][j]);printf(" ");for(j=0;j<m; j++)printf("%2d",allocation[i][j]);printf(" ");for(j=0;j<m; j++)printf("%2d",need[i][j]);printf(" ");for(j=0;j<m; j++){if(i>0)break;printf("%2d",available[j]);}printf("\n");}}}程序结果截图:三、实验总结:这次上机模拟了进程调度过程和解决了死锁问题,让我对短作业优先调度算法和银行家算法有了比在课堂上更深刻的认识。
DNA的酶切、连接、转化和重组子的筛选与鉴定
第二次分子生物学实验报告DNA的酶切、连接、转化和重组子的筛选与鉴定一、实验目的1、学习和掌握限制性内切酶的分类、特性与作用原理,掌握载体和外源目的DNA酶切的操作技术。
2、学习利用T4 DNA 连接酶把酶切后的载体片段和外源目的DNA 片段连接起来,构建体外重组DNA 分子的技术,了解并掌握几种常用的连接方法。
3、掌握利用CaCl2 制备感受态细胞的方法;学习和掌握热击法转化E. coli 的原理与方法。
4、学习并掌握使用红白菌落法筛选获得重组子以及α互补筛选法的原理及方法。
5、学习和掌握使用试剂盒抽提质粒的方法;6、复习琼脂糖凝胶电泳的原理和方法;7、通过对重组子进行重组质粒DNA 的抽提与酶切鉴定,进一步确定重组质粒中含有外源目的DNA 片段,并验证重组子是期望的重组子。
二、实验原理1、限制性内切酶限制性核酸内切酶是一类能够识别双链DNA 分子中的某种特定核苷酸序列,并由此切割DNA 双链结构的酶,主要是从原核生物中分离纯化出来的。
在限制性核酸内切限制酶的作用下,侵入细菌的“外源”DNA 分子便会被切割成不同大小的片段,而细菌自己固有的DNA 由于修饰酶(通常是一种甲基化酶)的保护作用,则可免受限制酶的降解。
目前已经鉴定出3 种不同类型的限制性核酸内切酶,即Ⅰ型酶、II 型酶和III 型酶。
Ⅰ型酶切割位点是随机的,至少距识别位点1000bp。
Ⅲ型限制酶的切割位点距识别序列3'端为24—26bp。
Ⅱ型限制酶的切割位点一般在识别序列上或与之靠近,而且具有序列特异性,故在基因克隆中有特别广泛的用途。
Ⅱ型核酸内切限制酶具有3个基本的特性:①在DNA 分子双链的特异性识别序列部位切割DNA 分子,产生链的断裂;②2个单链断裂部位在DNA 分子上的分布通常不是彼此直接相对的;③断裂结果形成的DNA 片段往往具有互补的单链延伸末端。
限制性核酸内切酶对DNA 底物的酶切作用是否完全,直接关系到连接反应、重组体分子的筛选和鉴定等实验结果。
东南大学电力电子技术第二次实验报告
东南大学《电力电子技术基础》实验报告第二次实验实验名称:单相全控桥式整流电路院(系):自动化专业:自动化姓名:学号:实验室:动力楼119 实验时间:2016 年11月19日评定成绩:审阅教师:目录1电压互感器(PT)与电流互感器(CT) (3)1.1电压互感器 (3)1.2电流互感器 (5)1.3 电压互感器和电流互感器在作用原理上的区别 (7)2认识相关模块 (7)2.1 互感器 (7)2.2 电度表 (8)3 单相全控桥式整流电路 (9)3.1 实验目的 (9)3.2 实验原理 (9)3.3 MATLAB仿真 (11)3.4 实验步骤 (12)3.5 实验数据与波形记录 (12)3.6 实验分析 (15)4 TCA785功能验证 (16)4.1 实验目的 (16)4.2 实验原理 (16)4.3 实验内容 (18)4.4 波形记录 (18)4.5 集成触发器应用 (20)5 思考分析 (21)附录:1、ULN2003数据手册2、MC1413数据手册3、数字触发器1电压互感器(PT)与电流互感器(CT)1.1 电压互感器1.1.1基本概念电压互感器又称仪用变压器,是一种电压变换装置。
常用于变配电仪表测量和继电保护等回路,按原理可分为电磁感应式和电容分压式两类。
电磁感应式一般用于110KV以上的电力系统,330~765KV超高压电力系统应用较多。
电压互感器按用途又分为测量用和保护用两类,对前者的主要技术要求是保证必要的准确度,对后者可能有某些特殊要求。
1.1.2工作原理电压互感器的工作原理与普通电力变压器相同,结构原理和接线也相似。
特点是容量很小且比较稳定,正常运行时接近于空载状态,图1.1是电压互感器使用时的接线图。
工作时,一次绕组匝数很多,并联接到主线路,一次侧电压决定于一次电力网的电压U1,不受二次侧负荷影响。
二次侧绕组匝数很小,并联接入电压表或其他测量仪表的电压线圈。
电压互感器的一次电压U1与其二次电压U2之间有下列关系式中 N1、N2——电压互感器一次和二次绕组的匝数;——电压互感器的变压比。
两次仪器高法水准测量实验报告
两次仪器高法水准测量实验报告对于仪器高法水准测量实验,我进行了两次实验,并撰写了以下报告。
一、实验目的本次实验的目的是掌握水准仪的使用方法,了解仪器高法水准测量的原理,并通过实验计算出不同目标点之间的高差。
二、实验原理1. 仪器高法水准测量原理仪器高法水准测量是利用水准仪来确定不同目标点之间的高度差,根据高度的测量需要,可将测站分为平距越小的几组,每组称为测段。
测量从起始测站开始,沿着测段逐步确定各目标点的高程。
2. 水准仪的使用方法在进行仪器高法水准测量前,需要先通过水准仪来确定起始测站的基准高度,然后再进行不同目标点之间的高度测量。
使用水准仪时,需要进行水平、垂直调节,以保证数据的准确性。
三、实验仪器1. 水准仪2. 四抬杆3. 测量带4. 针式水平仪四、实验步骤1. 调整水准仪的水平和垂直,使其处于工作状态。
2. 根据实际需要,确定不同目标点的位置和编号。
3. 把四抬杆固定在目标点上,并使用水准仪对杆进行观测,记录读数。
4. 计算不同目标点之间的高差。
五、实验结果第一次实验:起始测站高度:100.50米目标点1高度:99.42米目标点2高度:98.75米目标点3高度:98.21米目标点4高度:97.96米计算结果:目标点1高程:100.50-0.08=100.42米目标点2高程:100.50-1.75=98.75米目标点3高程:100.50-2.29=98.21米目标点4高程:100.50-2.54=97.96米第二次实验:起始测站高度:99.75米目标点1高度:98.83米目标点2高度:98.02米目标点3高度:97.60米目标点4高度:97.32米计算结果:目标点1高程:99.75-0.92=98.83米目标点2高程:99.75-1.73=98.02米目标点3高程:99.75-2.15=97.60米目标点4高程:99.75-2.43=97.32米六、实验结论通过本次仪器高法水准测量实验的两次实验结果可看出,不同目标点的高度差是根据起始测站的高度与目标点的高度之差来计算的。
JAVA实验报告Y.Daniel Liang第二次实验
2014-2015学年第一学期实验报告课程名称:Java SE 平台技术实验名称:JA VA编程(基础练习)姓名:学号:成绩:指导教师:日期:目录一、实验目的 (3)二、实验内容 (3)2.1 构建一个继承类。
(3)2.2 抽象类和接口的使用 (3)2.3 图像类编程和事件驱动程序。
(3)三、实验环境 (3)四、实验结果 (3)4.1构建继承类 (3)4.2抽象类和接口的使用 (3)4.3 事件驱动程序 (3)五、附录 (4)5.2 设计方案 (4)5.1构建继承类 (4)5.2抽象类和接口的使用 (4)5.3 事件驱动程序 (4)5.2 设计方案 (4)5.1构建继承类 (4)5.2抽象类和接口的使用 (4)5.3 事件驱动程序 (4)5.3 算法 (4)5.3.1 三角形继承类 (4)5.3.2 抽象类与接口 (5)5.3.3 画出小车 (5)5.4. 设计图 (6)5.4.1 三角形类UML设计图 (6)5.4.2.1 Colorable接口UML设计图 (7)5.4.2.2 CompareTo与Clone接口UML设计图 (8)5.4.3 小车UML设计图 (9)5.5 仿真结果 (9)5.5.1构建继承类 (9)5.5.2抽象类和接口的使用 (9)5.5.3 事件驱动程序 (10)5.6 调试心得 (10)5.6.1 错误分析 (10)5.6.2 心得与收获 (10)一、实验目的通过使用JA V A语言进行基本程序的开发,掌握JA V A通用IDE,练习类的封装使用、JA V A基本类库的使用、利用UML进行简单建模。
二、实验内容2.1 构建一个继承类。
2.2 抽象类和接口的使用2.3 图像类编程和事件驱动程序。
三、实验环境Eclipse、Win 8.1四、实验结果4.1构建继承类输出了三角形的三边长,面积,周长。
4.2抽象类和接口的使用4.2.1执行Colorable接口,输出了一条how to color的信息4.2.2执行Comparable 和Cloneable接口,输出了创建的五边形和克隆五边形的周长和面机的信息。
江苏大学计算机图形学第二次实验报告曲线拟合
江苏大学-计算机图形学第二次实验报告-曲线拟合————————————————————————————————作者: ————————————————————————————————日期:ﻩ计算机科学与通信工程学院实验报告课程计算机图形学实验题目实验二:曲线拟合学生姓名学号专业班级指导教师日期ﻬ成绩评定表评价内容具体内容权重得分论证分析方案论证与综合分析的正确、合理性20%算法设计算法描述的正确性与可读性20%编码实现源代码正确性与可读性30%程序书写规范标识符定义规范,程序书写风格规范20%报告质量报告清晰,提交准时10%总分指导教师签名1. 实验内容1. 绘制三次Bezier曲线(1)给定四个已知点P1—P4,以此作为控制顶点绘制一段三次Bezier曲线。
(2)给定四个已知点P1—P4,以此作为曲线上的点绘制一段三次Bezier曲线。
2.绘制三次B样条曲线给定六个已知点P1—P6,以此作为控制顶点绘制一条三次B样条曲线。
2.实验环境Windows xpVs 20083. 问题分析Bezier曲线通过一组多边折线的各顶点唯一的定义出来。
在多边折线的各顶点中,只有第一点和最后一点在曲线上,其余的顶点则用来定义曲线的导数,阶次和形状。
三次Bezieer曲线经过首、末两个控制点,且与特征多边形的首、末两条边相切。
因此在给定四个控制点的情况下,可以根据线性贝塞尔曲线描述的中介点 Q0、Q1、Q2,和由二次曲线描述的点 R0、R1 所建构。
也可以在给定四个线上点的情况下根据公式计算出曲线。
总之,只要获得了四个控制点的坐标,便可以通过编程来绘制出曲线。
对于给出了四个曲线上点的曲线,由于控制点的坐标位于曲线上,而且在相交处两曲线的切平面重合,曲率相等。
可以据此来绘制图形。
B 样条曲线是Bezier 曲线的拓广,它是用B 样条基函数代替了Bezier 曲线表达式中的Bernst ain 基函数。
在空间给定n+1个点的位置向量Pi (i=0,1,2,……n, n>=k),则称参数曲线,0()()ni i k i Q t t N P ==∑ (0≤t≤1)为k 阶(或k-1次)的B 样条曲线。
第二次实验报告心得
第二次实验报告心得前言本次实验是第二次实验,我们小组研究的主题是XXX。
通过这次实验,我们掌握了XXX的基本原理和实验操作方法。
在实验过程中,我们遇到了挑战和问题,但也取得了进步和收获。
实验过程与成果我们小组在实验前制定了详细的实验计划并分工合作。
首先,我们对XXX进行了深入的了解和学习,并通过查阅大量的文献和资料来提高对该主题的理解和认识。
在熟悉了实验内容和操作流程后,我们进行了实验的准备工作,包括搭建实验装置、调试仪器设备等。
在实验过程中,我们认真操作,严格遵守实验操作规范,确保了实验的安全性和准确性。
我们按照实验计划逐步进行实验并记录下实验数据和现象。
同时,我们也积极讨论和交流,共同解决实验中遇到的问题和困难。
通过实验,我们获得了大量的实验数据和结果。
我们对实验数据进行了仔细的整理和分析,并进行了合理的处理和计算。
最终,我们得到了一系列有关XXX的重要结论和发现。
实验收获与成长本次实验让我们获得了许多宝贵的经验和知识,也让我们在实践中得到了成长。
首先,通过实验过程,我们掌握了XXX的基本原理和实验方法。
我们深入研究了相关的理论知识,并将其运用到实际操作中。
我们通过实验实践,进一步加深了对XXX的理解,加强了对实验方法的掌握。
其次,通过团队合作,我们学会了有效地协作和沟通。
在实验过程中,我们互相帮助、共同解决问题,并且共同分工合作,提高了实验效率和质量。
我们在团队中形成良好的合作氛围,培养了团队意识和合作能力。
最后,通过实验报告的撰写,我们学会了对实验数据进行整理和分析,并将实验结果清晰准确地表达出来。
这锻炼了我们的科学思维和表达能力,提高了我们的写作水平。
反思与改进在实验中,我们也面临了一些挑战和问题。
通过实验的反思和总结,我们认识到了不足之处,并提出了一些改进的建议。
首先,我们在实验前准备方面需要更加细致和仔细。
在本次实验中,我们发现有些仪器设备的调试工作并没有充分准备,导致实验过程中出现了一些意外情况。
东南大学虚拟仪器实验报告-(计算n!,计算器)
东南大学生物科学与医学工程学院虚拟仪器实验报告第二次实验实验名称:程序结构专业:生物医学工程姓名:学号:同组人员:学号:实验室: 综合楼716实验时间:10月14日评定成绩:审阅教师:一、计算n的阶乘 (3)1实验题目 (3)2实验目的 (3)3实验内容 (3)4设计方案选择、方案的优缺点。
(3)5软件设计: (3)6调试: (6)7测试结果和分析。
(6)8使用说明: (7)9结束语、总结、心得体会。
(7)二、实现加减乘除的计算器 (7)1实验题目 (7)2实验目的 (7)3实验内容 (7)4设计方案选择、方案的优缺点。
(7)5软件设计: (8)6调试: (9)7测试结果和分析 (10)8使用说明: (10)9结束语、总结、心得体会。
(10)一、计算n的阶乘1实验题目完成计算n的阶乘2实验目的①前面板数字控制器可随意输入n的值,并能显示结果(注:0!=1)。
②For循环中重复时间不少于100ms(即程序每100ms循环一次)。
3实验内容⑴学习while、For循环的使用方法。
⑵学习移位寄存器的概念,学习移位寄存器的使用。
⑶学习使用Case结构,学习添加和删除分支。
4设计方案选择、方案的优缺点。
计算n的阶乘的计算器方案选择:利用循环语句,进行数字n的阶乘运算,利用移位寄存器实现数据的传送完成数字连乘。
利用时间计时器的差值得出程序运行所用时间。
能够简洁明了的实现计算n的阶乘的功能,数据正确。
5软件设计:虚拟仪器设计步骤详细介绍。
(1)程序前面板设计:数值输入控件:名称:输入n 属性:双精度(DBL)用途:面向用户,手动输入n值数值显示控件:名称:n!的值属性:双精度(DBL)用途:显示n!运算结果名称:运行时间(ms)属性:双精度(DBL)用途:显示程序运行时间面板的布局:。
(2)框图程序设计:程序流程图:源程序:6调试:调试步骤:使用高亮执行该段程序,观察数据流的动向。
调试中问题:一开始使用整型,对于较小数值,结算结果正确,但对于较大的数值计算结果错误。
2022年北工大数据结构第二次上机中缀转后缀实验报告
北京工业大学- 第学期信息学部计算机学院3月31日报告题目:输入中缀体现式,输出后缀体现式,并对体现式求值A.分析中缀体现式旳运算顺序受运算符优先级和括号旳影响。
因此,将中缀体现式转换成等价旳后缀体现式旳核心在于如何恰当旳去掉中缀体现式中旳括号,然后在必要时按照先乘除后加减旳优先规则调换运算符旳先后顺序。
在去括号旳过程中用栈来储存有关旳元素。
基本思路:从左至右顺序扫描中缀体现式,用栈来寄存体现式中旳操作数,开括号,以及在这个开括号背面旳其她临时不能拟定计算顺序旳内容。
(1)当输入旳是操作数时,直接输出到后缀体现式(2)当遇到开括号时,将其入栈(3)当输入遇到闭括号时,先判断栈与否为空,若为空,则表达括号不匹配,应作为错误异常解决,清栈退出。
若非空,则把栈中元素依次弹出,直到遇到第一种开括号为止,将弹出旳元素输出到后缀体现式序列中。
由于后缀体现式不需要括号,因此弹出旳括号不放到输出序列中,若没有遇到开括号,阐明括号不匹配,做异常解决,清栈退出。
(4)当输入为运算符时(四则运算+ - * / 之一)时:a.循环,当(栈非空&&栈顶不是开括号&&栈顶运算符旳优先级不低于输入旳运算符旳优先级)时,反复操作将栈顶元素弹出,放到后缀体现式中。
b.将输入旳运算符压入栈中。
(5)最后,当中缀体现式旳符号所有扫描完毕时,若栈内仍有元素,则将其所有依次弹出,放在后缀体现式序列旳尾部。
若在弹出旳元素中遇到开括号,则阐明括号不匹配,做异常解决,清栈退出。
B.实现#include<stdio.h>#include<string.h>#include<stdlib.h>#include<stack>using namespace std;#define N 1000char infix[N]; //中缀体现式(未分离,都在一种字符串里)char expression[N][10]; //保存预解决过旳体现式,也就是每个元素都分离过旳体现式char suffix[N][10]; //保存后缀体现式旳操作数int count;//体现式中元素旳个数(一种完整到数字(也许不止一位数)或者符号)int suffixLength;//后缀体现式旳长度int level(char a){switch(a){case '#':return 0;case '+':case '-':return 1;case '*':case '/':return 2;case '^':return 3;default:break;}return -1;}int isDigital(char x){if( (x>='0'&&x<='9') || (x>='A'&&x<='Z') || (x>='a'&&x<='z') || (x=='.') )return 1;return 0;}int isNumber(char *str){int i;for(i=0;str[i];i++){if(isDigital(str[i])==0)return 0;}return 1;}/*************************************预解决中缀体现式,把持续旳字符分离成不同旳元素,用字符串数组(expression[][])保存,以便背面旳计算,由于这里考虑了运算数也许不全是个位数例如:(12+3)在解决成后缀体现式时,是123+,容易产生歧义(1+23 ? 12+3)*************************************/void pretreatment(char *str){int i,j,numberFlag;char temp[3];char number[10];count=0;numberFlag=0;for(j=0,i=0;str[i];i++){if(isDigital(str[i])==0){if(numberFlag==1){number[j]=0;strcpy(expression[count++],number); j=0;numberFlag=0;}if(str[i]!=' '){temp[0]=str[i];temp[1]=0;strcpy(expression[count++],temp); }}else {numberFlag=1;number[j++]=str[i];}}puts("分离后旳体现式为");for(i=0;i<count;i++){printf("%s ",expression[i]);}puts("");puts("");}/*****************************************中缀体现式转后缀体现式遍历字符串,对于str[i]str[i]是运算数(或者是字母替代旳运算变量)输出;str[i]是符号,有两种状况(1),是右括号,栈顶元素输出,直到与str[i]匹配旳左括号出栈(左括号不用输出打印)(2),是运算符,判断str[i]与栈顶元素旳优先级,str[i]优先级不高于栈顶符号,则栈顶元素输出,直到栈空或者栈顶符号优先级低于str[i]*****************************************/void infix_to_suffix(char str[N][10]){memset(suffix,0,sizeof(suffix));suffixLength=0;stack <char*> st;int i=0;char Mark[2]="#";st.push(Mark);do{if(isNumber(str[i])==1)//运算数直接保存到后缀体现式中strcpy(suffix[suffixLength++],str[i]);else if(str[i][0]=='(') //是左括号,直接入栈st.push(str[i]);else if(str[i][0]==')'){ //是右括号,栈顶出栈,直到与其匹配旳左括号出栈while( strcmp(st.top(),"(")!=0 ){char temp[10];strcpy(temp,st.top());strcpy(suffix[suffixLength++],temp);st.pop();}st.pop();}else if( strcmp(st.top(),"(")==0 )//是运算符,且栈顶是左括号,则该运算符直接入栈st.push(str[i]);else { //是运算符,且栈顶元素优先级不不不小于运算符,则栈顶元素始终//出栈,直到栈空或者遇到一种优先级低于该运算符旳元素while( !st.empty() ){char temp[10];strcpy(temp,st.top());if( level(str[i][0]) > level(temp[0]) )break;strcpy(suffix[suffixLength++],temp);st.pop();}st.push(str[i]);}i++;}while(str[i][0]!=0);while( strcmp(st.top(),"#")!=0 ){ //将栈取空结束char temp[10];strcpy(temp,st.top());strcpy(suffix[suffixLength++],temp);st.pop();}puts("后缀体现式为:");for(i=0;i<suffixLength;i++){printf("%s",suffix[i]);}puts("");puts("");}/**************************************计算后缀体现式旳值**************************************/char kt[N][10];int stackTop;void getResult(char str[N][10]){stackTop=0;/*这里要注意,内存旳分派方案导致 i 旳位置就在temp[9]旁边,然后strcpy()函数直接拷贝内存旳话,在temp越界状况下会覆盖 i 旳值*/int i;char temp[10];for(i=0;i<suffixLength;i++){if(isNumber(str[i])==1){strcpy(kt[stackTop++],str[i]);}else {char a[10],b[10];double na,nb,nc;strcpy(a,kt[stackTop-1]);na = atof(a);stackTop--;strcpy(b,kt[stackTop-1]);nb = atof(b);stackTop--;if(str[i][0]=='+')nc=nb+na;else if(str[i][0]=='-')nc=nb-na;else if(str[i][0]=='*')nc=nb*na;else if(str[i][0]=='/')nc=nb/na;sprintf(temp,"%lf",nc);strcpy(kt[stackTop++],temp);}}puts("\nThe result is : %f\n");printf("%s\n",kt[stackTop-1]);}int main(){printf("Please input calculate Expression :\n"); char temp[N];while(gets(infix)){strcpy(temp,infix);pretreatment( strcat(temp," ") );infix_to_suffix(expression);getResult(suffix);}return 0;}C.总结实验需要细心细心再细心。
MCU第二次实验报告
实验名称:I/O接口实验与LED显示实验目录一.实验目的和要求 (3)二.实验原理 (3)三.实验方案与实验步骤 (5)四.实验设备与器材 (7)五.实验记录 (7)六.实验总结 (7)七.源代码 (7)一.实验目的与要求(一)实验目的1、I/O接口实验了解单片机各个口的输出,以及延时程序的计算;2、L ED显示实验,了解数码管显示机理,学会片外编码。
(二)实验要求1、I/O接口实验利用实验板I/O口(例如P0口)控制8个LED循环显示,循环点亮时间间隔约为1秒(采用软件延时实现)。
2、LED显示实验要求在8个LED数码管显示8个指定的数(例如学号后8位)。
本实验不需要接线。
二.实验原理1、I/O接口实验图2-1 上排LED指示灯(与FPGA相连)原理图图2-2 下排LED指示灯(通过CPLD译码与CPU相连)原理图主板左下方有16个LED指示灯,其中上面8个LED指示灯FLED0~FLED7输入直接与FPGA 插座引脚相连,可由FPGA模块输出引脚直接驱动,电路如图2-1所示,输入高电平时相应指示灯被点亮(这里实验箱开机复位后默认是点亮的)。
下面一排的8个LED指示灯LED0~LED7输入与CPU总线相连,作为系统扩展接口,其地址选通(0F600H)由CPLD地址译码控制,电路如图2-2所示,输入低电平时相应指示灯被点亮。
本实验采用的是上面一排与FPGA 相连的LED,需要8根导线将I/O口与相应的LED连接。
2、LED显示实验如图所示:实验装置上设有8只共阳极七段数码管及驱动电路,8只数码管共数据线,通过片选可以分别显示。
段码表为:表2-1 数码管段码表编程提示:数码管模块具有两个地址:片选地址(位控地址)0F400H和数据(段码)地址0F300H,要在某个数码管上显示1个数,需要先向片选地址上送一个数选中其中一个数码管,再向数据地址送要显示的数据的段码值,这就是位控和段控。
数码管的I/O地址都为片外地址。
西北工业大学_计算机系统基础_实验报告_第2次
计算机系统基础实验课第二次实验报告对二进制炸弹求解过程的详细描述首先使用objdump命令对bomb程序进行反汇编,并将汇编代码输出到asm.txt中。
阶段一、字符串比较打开asm.txt文件,搜索到phase_1函数,可以看到以下代码。
08048b33 <phase_1>:8048b33: 83 ec 14 sub $0x14,%esp8048b36: 68 7c a0 04 08 push $0x804a07c8048b3b: ff 74 24 1c pushl 0x1c(%esp)8048b3f: e8 3e 05 00 00 call 8049082 <strings_not_equal>8048b44: 83 c4 10 add $0x10,%esp8048b47: 85 c0 test %eax,%eax8048b49: 74 05 je 8048b50 <phase_1+0x1d>8048b4b: e8 29 06 00 00 call 8049179 <explode_bomb>8048b50: 83 c4 0c add $0xc,%esp8048b53: c3 ret可以看出,用户输入字串指针保存在0x1c(%esp),然后调用<strings_not_equal>,待<strings_not_equal>返回后,测试返回值,若equal则进入下一phase,否则<explode_bomb>,从<strings_not_equal>可知该函数用于比较两函数的值,因此需要两个字串作为输入,上面代码中, pushl 0x1c(%esp)用于传递用户字串指针,则push $0x804a07c自然是传递比较字串的指针了。
打开gdb,x/s 0x80497c0, 可以直接查看到该指针指向的子符串:所以第一个炸弹的拆弹指令为:I turned the moon into something I call a Death Star.阶段二、循环在asm.txt文件中可以找到phase_2函数代码如下:08048b54 <phase_2>:8048b54: 56 push %esi8048b55: 53 push %ebx8048b56: 83 ec 2c sub $0x2c,%esp8048b59: 65 a1 14 00 00 00 mov %gs:0x14,%eax8048b5f: 89 44 24 24 mov %eax,0x24(%esp)8048b63: 31 c0 xor %eax,%eax8048b65: 8d 44 24 0c lea 0xc(%esp),%eax8048b69: 50 push %eax8048b6a: ff 74 24 3c pushl 0x3c(%esp)8048b6e: e8 2b 06 00 00 call 804919e <read_six_numbers>8048b73: 83 c4 10 add $0x10,%esp8048b76: 83 7c 24 04 01 cmpl $0x1,0x4(%esp)8048b7b: 74 05 je 8048b82 <phase_2+0x2e>8048b7d: e8 f7 05 00 00 call 8049179 <explode_bomb>8048b82: 8d 5c 24 04 lea 0x4(%esp),%ebx8048b86: 8d 74 24 18 lea 0x18(%esp),%esi8048b8a: 8b 03 mov (%ebx),%eax8048b8c: 01 c0 add %eax,%eax8048b8e: 39 43 04 cmp %eax,0x4(%ebx)8048b91: 74 05 je 8048b98 <phase_2+0x44>8048b93: e8 e1 05 00 00 call 8049179 <explode_bomb>8048b98: 83 c3 04 add $0x4,%ebx8048b9b: 39 f3 cmp %esi,%ebx8048b9d: 75 eb jne 8048b8a <phase_2+0x36>8048b9f: 8b 44 24 1c mov 0x1c(%esp),%eax8048ba3: 65 33 05 14 00 00 00 xor %gs:0x14,%eax8048baa: 74 05 je 8048bb1 <phase_2+0x5d>8048bac: e8 df fb ff ff call 8048790 <__stack_chk_fail@plt>8048bb1: 83 c4 24 add $0x24,%esp8048bb4: 5b pop %ebx8048bb5: 5e pop %esi8048bb6: c3 ret根据call 804919e <read_six_numbers>可以推测题目要求是输入六个数字。
matlab数学实验报告
MATLAB数学实验报告指导老师:班级:小组成员:时间:201_/_/_Matlab第二次实验报告小组成员:1题目:实验四;MATLAB选择结构与应用实验目的:掌握if选择结构与程序流程控制;重点掌握break;return;pause语句的应用..问题:问题1:验证“哥德巴赫猜想”;即:任何一个正偶数n>=6均可表示为两个质数的和..要求编制一个函数程序;输入一个正偶数;返回两个质数的和..问题分析:由用户输入一个大于6的偶数;由input语句实现..由if判断语句判断是否输入的数据符合条件..再引用质数判断函数来找出两个质数;再向屏幕输出两个质数即可..编程:function z1;z2=geden;n=input'please input n'if n<6disp'data error';returnendif modn;2==0for i=2:n/2k=0;for j=2:sqrtiif modi;j==0k=k+1;endendfor j=2:sqrtn-iif modn-i;j==0k=k+1;endendif k==0fprintf'two numbers are'fprintf'%.0f;%.0f';i;n-ibreakendendend结果分析:如上图;用户输入了大于6的偶数返回两个质数5和31;通过不断试验;即可验证哥德巴赫猜想..纪录:if判断语句与for循环语句联合嵌套使用可使程序结构更加明晰;更快的解决问题..2题目:实验四;MATLAB选择结构与应用实验目的:用matlab联系生活实际;解决一些生活中常见的实际问题..问题:问题四:在一边长为1的四个顶点上各站有一个人;他们同时开始以等速顺时针沿跑道追逐下一人;在追击过程中;每个人时刻对准目标;试模拟追击路线;并讨论.. (1)四个人能否追到一起(2)若能追到一起;每个人跑过多少路程(3)追到一起所需要的时间设速率为1问题分析:由正方形的几何对称性和四个人运动的对称性可知;只需研究2个人的运动即可解决此问题..编程:hold onaxis0 1 0 1;a=0;0;b=0;1;k=0;dt=0.001;v=1;while k<10000d=norma-b;k=k+1;plota1;a2;'r.';'markersize';15;plotb1;b2;'b.';'markersize';15;fprintf'k=%.0f b%.3f;%.3f a%.3f;%.3f d=%.3f\n';k;b1;b2;a1;a2;da=a+b1-a1/d*dt;b2-a2/d*dt;b=b+b2-a2/d*dt;-b1-a1/d*dt;if d<=0.001breakendendfprintf'每个人所走的路程为:%.3f';k*v*dtfprintf'追到一起所需要的时间为%.3f';k*dt结果分析:上图为2人的模拟运动路线;有对称性可解决所提问题..-上图为运算过程和运算结果..四个人可以追到一起;走过的路程为1.003;时间也为1.003.纪录:此题利用正方形和运动的对称性可以简便运算..3题目:实验八;河流流量估计与数据插值目的:由一些测量数据经过计算处理;解决一些生活实际问题..问题:实验八上机练习题第三题:瑞士地图如图所示;为了算出他的国土面积;做以下测量;由西向东为x轴;由南向北为y轴;从西边界点到东边界点划分为若干区域;测出每个分点的南北边界点y1和y2;得到以下数据mm..已知比例尺1:2222;计算瑞士国土面积;精确值为41288平方公里..测量数据如下:x=7.0 10.5 13.0 17.5 34 40.5 44.5 48 56 61 68.5 76.5 80.5 91 96 101 104 106 111.5 118 123.5 136.5 142 146 150 157 158 ;y1=44 45 47 50 50 38 30 30 34 36 34 41 45 46 43 37 33 28 32 65 55 54 52 50 66 66 68;y2=44 59 70 72 93 100 110 110 110 117 118 116 118 118 121 124 121 121 121 122 116 83 81 82 86 85 68;问题分析:先由题目给定的数据作出瑞士地图的草图;再根据梯形法;使用trapz语句;来估算瑞士国土的面积..编程:x=7.0 10.5 13.0 17.5 34 40.5 44.5 48 56 61 68.5 76.5 80.5 91 96 101 104 106 111.5 118 123.5 136.5 142 146 150 157 158;y1=44 45 47 50 50 38 30 30 34 36 34 41 45 46 43 37 33 28 32 65 55 54 52 50 66 66 68;y2=44 59 70 72 93 100 110 110 110 117 118 116 118 118 121 124 121 121 121 122 116 83 81 82 86 85 68;plotx;y1;'r.';'markersize';15;plotx;y2;'r.';'markersize';15;axis0 160 0 135grid;hold ont=7:158;u1=splinex;y1;t;u2=splinex;y2;t;plott;u1plott;u2s1=trapzt;u1;s2=trapzt;u2;s=s2-s1*2222*22222/10000000;fprintf'S=%.0f';s结果分析:上图为由所给数据绘制出的瑞士地图..上图为运算结果;计算出瑞士的国土面积为42472平方公里;与准确值41288较为接近..纪录:使用梯形分割的方法;trapz语句可以方便计算不规则图形面积;但存在一定误差..4题目:实验七:圆周率的计算与数值积分目的:将数值积分最基本的原理应用于matlab之中;解决一些与积分有关的问题..问题:实验七上机练习题第一题:排洪量某河床的横断面如图7.3所示;为了计算最大排洪量;需要计算其断面积;试根据所给数据m用梯形法计算其断面积..问题分析:河床断面可近似分割成若干曲边梯形;近似处理把它们当做梯形来计算面积可使问题得到简化..编程:clc;clear;x=0 4 10 12 15 22 28 34 40;y=0 1 3 6 8 9 5 3 0;y1=10-y;plotx;y1;'k.';'markersize';15;axis0 40 0 10;grid;hold ont=0:40;u=splinex;y1;t;plott;u;s=40*10-trapzt;u;fprintf's=%.2f\n';s结果分析:上图为河床的断面图..上图为计算结果面积约为180.70平方米..纪录:使用梯形法计算不规则图形面积十分简便易行..5题目:实验七:圆周率的计算与数值积分目的:使用matlab计算解决一些有关积分的问题..问题:实验七上机练习题第三题:从地面发射一枚火箭;在最初100秒内记录其加速度如下;试求火箭在100秒时的速度..Ts=0 10 20 30 40 50 60 70 80 90 100;Am/s*s=30.00 31.63 33.44 35.47 37.75 40.33 43.29 46.69 50.67 54.01 57.23;问题分析:加速度为速度的微分;已知微分求积分;类似于面积问题;可使用梯形法来计算..编程:clc;clear;x=0 10 20 30 40 50 60 70 80 90 100;y=30.00 31.63 33.44 35.47 37.75 40.33 43.29 46.69 50.6754.01 57.23;plotx;y;'k.';'markersize';15;axis0 100 20 60;grid;hold ons=0:10:100;z=splinex;y;s;plots;y;v=trapzx;y;fprintf'v=%.2f\n';v结果分析:上图为加速度变化图..上图为计算结果;求得火箭在100秒时速度约为4168.95m/s..纪录:梯形法可以推广解决许多已知微分求积分的其他问题..6题目:实验七:圆周率的计算与数值积分目的:计算曲线弧长闭曲线周长可使用微元法;ds=sqrtdx^2+dy^2;在转化微积分问题;累加即可得到结果..问题:实验七上机练习题第三题:计算椭圆想x^2/4+y^2=1的周长;使结果具有五位有效数字..问题分析:编程:s=0;dx=0.001;for x=0:0.001:1.999dy=1.-x+0.001.^2/4-1.-x.^2/4;ds=sqrtdx.^2+dy.^2;s=s+ds;ends=4*s;fprintf'the length is'fprintf'%.4f';s结果分析:上图为计算结果;给定椭圆的周长约为9.1823五位有效数字纪录:计算不规则曲线弧长;可使用微元法;划分为若干小的看做直角三角形;利用勾股定理解决..7题目:实验九人口预测与数据拟合目的:掌握一些曲线拟合的方法;了解曲线拟合常用函数..问题:用电压U=10v的电池给电容器充电;t时刻的电压Vt=U-U-V0exp-t/τ;其中V0是电容器的初始电压;τ是充电常数;由所给数据确定V0和τ..t=0.5 1 2 3 4 5 7 9;V=3.64 3.52 2.74 1.78 1.34 1.01 0.57 0.37;问题分析:题中已给出函数关系式;为指数函数曲线拟合;将所给函数式整理可得标准的exp形函数曲线;从而便于解决..编程:t=0.5 1 2 3 4 5 7 9;V=3.64 3.52 2.74 1.78 1.34 1.01 0.57 0.37;plott;V;'k.';'markersize';20;axis0 10 0 4;grid;hold onpause0.5n=8;a=sumt1:n;b=sumt1:n.*t1:n;c=sumlogV1:n;d=sumt1:n.*logV1:n;A=n a;a b;B=c;d;p=invA*Bx=0:10;y=expp1+p2*x;plotx;y;'r-';'linewidth';2结果分析:上图为电压与时间关系图..上图为计算结果;即U-V0=1.4766;所以V0=8.5234;-1/τ=-0.2835;所以τ=3.5273纪录:曲线拟合的一个重难点是选择合适的曲线函数;才能提高拟合度..8题目:实验七圆周率的计算与数值积分目的:拓展圆周率的各种计算方法;掌握其他数值的近似计算方法..问题:实验七练习2:计算ln2的近似值精确到10的-5次方(1)利用级数展开的方法来计算(2)利用梯形法计算(3)利用抛物线法问题分析:级数展开;梯形法;抛物线法是常见的近似运算方法..编程:1级数展开的方法clc;clear;n=0;r=1;p=0;k=-1;while r>=0.1e-5n=n+1;k=k*-1;p1=p+k/n;r=absp1-p;fprintf'n=%.0f;p=%.10f\n';n;p1;p=p1;end2梯形法clc;clear;f=inline'1./x';x=1:0.1:2;y=fx;p=trapzx;y;fprintf'p=%.6f\n';p3抛物线法clc;clear;f=inline'1./x';a=1;b=2;n=1;z=quadf;a;b;fprintf'z=%.10f\n';z结果分析:(1)级数展开的方法(2)梯形法3抛物线法纪录:级数展开法;梯形法;抛物线法;计算近似值时应合理利用..梯形法和抛物线法不易提高精确度;级数展开法可以提高精确度..9题目:实验八河流流量估计与数据插值目的:掌握求插值多项式的方法;并利用此计算近似值..问题:已知y=fx的函数表如下x=0.40 0.55 0.65 0.80 0.90 1.05;y=0.41075 0.57815 0.69675 0.88811 1.02652 1.25382;求四次拉格朗日插值多项式;并由此求f0.596问题分析:利用所给函数表可计算拉格朗日插值多项式..编程:function p=lagrangex;yL=lengthx;a=onesL;for j=2:La:;j=a:;j-1.*x';endx=inva*y';for i=1:Lpi=xL-i+1;endx=0.40 0.55 0.65 0.80 0.90 1.05;y=0.41075 0.57815 0.69675 0.88811 1.02652 1.25382; plotx;y;'k.';'markersize';15axis0 2 0 2grid;hold on;p=lagrangex;y;t=0:0.1:1.5;u=polyvalp;t;plott;u;'r-'a=polyvalp;0.596结果分析:上图为所求结果;估算值和插值多项式..纪录:插值多项式是一项十分实用的方法..10题目:求正整数n的阶乘:p=1*2*3*…*n=n;并求出n=20时的结果目的:练习使用循环变量解决数学问题问题:对程序:Clear;clc;n=20;p=1;for i=1:np=p*i;fprintf’i=%.0f;p=%.0f\n’;i;pend进行修改使它:利用input命令对n惊醒赋值问题分析:题中给出程序中“n=20”修改;使用input命令;讲题中的输出命令放出循环之外..编程:clear;clc;n=input'n=';p=1;for i=1:np=p*i;endfprintf'i=%.0f;p=%.0f\n';i;p结果:n=20i=20;p=2432902008176640000>>结果分析:使用input命令可以实现人机对话;使用户自由赋值;输出语句在程序中的位置对输出的结果有很大的影响;在循环内部可以在计算过城中不断输出结果;在循环之外则可以控制只输出最后结果..11题目:对于数列{√2};n=1;2;…;求当其前n项和不超过1000时的n的值及合的大小..目的:运用条件循环解决文帝个项数的循环程序求解;问题:对程序:clear;clc;n=0;s=0;while s<=1000n=n+1;s=s+sqrtn;fprintf’n=%.0f;s=%.4f\n’;n;send问题分析:题中所给程序中的限制变量为上次循环之后的s;导致s超过上限后仍有一次的循环;若把循环变量改为这次的s;则可以避免这种情况的发生..编程:clear;clc;n=0;s=0;while s+sqrtn<=1000n=n+1;s=s+sqrtnfprintf'n=%.0f;s=%.4f\n';n;send结果:……s =970.8891n=128;s=970.8891s =982.2469n=129;s=982.2469s =993.6487n=130;s=993.6487>>结果分析:从结果中可以看出;最后一步为我们需要的答案;从这道题我们可以得出循环变量对一道编程的重要性..。
实验报告2-1
实验(实训)报告项目名称第二次实验时间序列SPSS分析(一)所属课程名称统计学项目类型统计学上机实验实验(实训)日期2014年5月18日班级12计算机1班学号120104200122姓名刘倩颖指导教师陈雄强浙江财经大学教务处制【项目内容】1)动态数列逐期、累计增长量计算;2)动态数列定基、环比发展速度计算;3)动态数列定基、环比增长速度计算;4)移动平均法和最小平方法计算动态数列的长期趋势。
【方案设计】1)搜集数据2)计算浙江省GDP的逐期增长量和累计增长量;3)计算浙江省GDP的环比发展速度和定基发展速度;4)计算浙江省GDP的环比增长速度、定基增长速度以及平均增长速度5)采用移动平均法分别计算浙江省GDP跨距3年和跨距4年的移动平均值;6)采用最小平方法拟合浙江省GDP序列的趋势方程。
【实验(实训)过程】(步骤、记录、数据、程序等)1)搜集数据,在国家统计局的网络上找到1978年-2012年的人均GDP和人均GDP指数,输入到SPSS软件中。
年份人均GDP(亿元)人均GDP指数1978381.23100 1979419.25106.1 1980463.25113 1981492.16117.5 1982527.78126.2 1983582.68137.9 1984695.2156.8 1985857.82175.5 1986963.19188.2 19871,112.38206.6 19881,365.51226.3 19891,519.00231.9 19901,644.00237.3 19911,892.76255.6 19922,311.09288.4 19932,998.36324.9 19944,044.00363.3 19955,045.73398.6 19965,845.89433.9 19976,420.18469.4 19986,796.03501.4 19997,158.50534.9 20007,857.68575.5 20018,621.71618.720029,398.05670.4200310,541.97733.1200412,335.58802.2200514,185.36887.7200616,499.70994.7200720,169.461,129.60200823,707.711,232.10200925,607.531,339.00201030,015.051,471.70201135,197.791,600.90201238,459.471,715.102)计算浙江省GDP的逐期增长量和累计增长量;首先,创建上年度时间序列【转换】-【创建时间序列】-将“人均GDP”添加到“变量->新名称”的文本框中-将“名称”改为“滞后一期”-在“函数”里面选择“滞后”-【确定】。
西北工业大学-数字电子技术基础-实验报告-实验2
西北⼯业⼤学-数字电⼦技术基础-实验报告-实验2数字电⼦技术基础第⼆次实验报告⼀、题⽬代码以及波形分析1. 设计⼀款可综合的2选1多路选择器①编写模块源码module multiplexer(x1,x2,s,f);input x1,x2,s;output f;assign f=(~s&x1)|(s&x2);endmodule②测试模块`timescale 1ns/1psmodule tb_multiplexer;reg x1_test;reg x2_test;reg s_test;wire f_test;initials_test=0;always #80 s_test=~s_test;initialbeginx1_test=0;x2_test=0;#20x1_test=1;x2_test=0;#20x1_test=0;x2_test=1;#20x1_test=1;x2_test=1;#20x1_test=0;x2_test=0;#20x1_test=1;x2_test=0;#20x1_test=0;x2_test=1;#20x1_test=1;x2_test=1;endmultiplexer UUT_multiplexer(.x1(x1_test),.x2(x2_test),.s(s_test),.f(f_test));endmodule③仿真后的波形截图④对波形的分析本例⽬的是令s为控制信号,实现⼆选⼀多路选择器。
分析波形图可以知道,s为0时,f 输出x1信号;s为1时,f输出x2信号。
所以实现了⽬标功能。
2. 设计⼀款可综合的2-4译码器①编写模块源码module dec2to4(W,En,Y);input [1:0]W;input En;output reg [0:3]Y;always@(W,En)case({En,W})3'b100:Y=4'b1000;3'b101:Y=4'b0100;3'b110:Y=4'b0010;3'b111:Y=4'b0001;default:Y=4'b0000;endcaseendmodule②测试模块`timescale 1ns/1psmodule tb_dec2to4;reg [1:0]W_test;reg En_test;wire [0:3]Y_test;initialEn_test=0;always #80 En_test=~En_test;initialbeginW_test=2'b00;#20W_test=2'b01;#20W_test=2'b11;#20W_test=2'b10;#20W_test=2'b00;#20W_test=2'b01;#20W_test=2'b11;#20W_test=2'b10;#20W_test=2'b00;enddec2to4 UUT_dec2to4(.W(W_test),.En(En_test),.Y(Y_test));endmodule③仿真后的波形截图④对波形的分析本例⽬的是实现可综合的2-4译码器,其中数组W是输⼊信号,共有两个值,输⼊⼀个两位⼆进制数据,⽬的是通过译码器将它转换成独热码,数组Y是输出信号,输出四个⼆进制数据,构成独热码。
人工智能实验报告-产生式系统推理-动物识别
人工智能第二次实验报告产生式系统推理班级:姓名:学号:一、实验目的1. 理解并掌握产生式系统的基本原理;2. 掌握产生式系统的组成部分,以及正向推理和逆向推理过程。
二、实验要求1. 结合课本内容, 以动物识别系统为例,实现小型产生式系统;2. 要求: 正向推理中能根据输入的初始事实,正确地识别所能识别的动物;逆向推理中能根据所给的动物给出动物的特征。
三、实验算法1. 如何表示事实和特征的知识;在本程序中,我将动物的特征写入data.txt,将规则记入rules.txt,将动物种类记为goal.txt。
通过函数void readFiles(){readGoal();readCod();readRule();}读入所有数据分别存放于goal[],rule[],cod[]自定义数组中。
2. 指出综合数据库和规则库分别使用哪些函数实现的?综合数据库(包括特征和目标)typedef struct{int xuh;//存放编号char valu[50];//存放具体内容}Node;Node goal[20];Node cod[50];规则库typedef struct{int rslt;int codNum;//记载前提的个数int cod[10];//记载前提的序号int used;//记载是否已匹配成功}Nrule;Nrule rule[50];void readRule(){FILE *fp;int i;int tempxuh,tempcodn;char ch;if((fp=fopen("rules.txt","r"))==NULL){printf("cannot open data\n");exit(0);}i=0;rule[i].codNum=0;while((ch=fgetc(fp))!=EOF){if(i==14)i=i;tempcodn=0;while(ch!='\n'&&ch!=EOF) //每一条规则{tempxuh=0;while(ch<='9'&&ch>='0'){tempxuh=tempxuh*10+ch-'0';ch=fgetc(fp);}rule[i].cod[tempcodn++]=tempxuh;tempxuh=0;if(ch=='-')//下一个是结论{ch=fgetc(fp);ch=fgetc(fp);while(ch<='9'&&ch>='0'){tempxuh=tempxuh*10+ch-'0';ch=fgetc(fp);}rule[i].rslt=tempxuh;}//ifelse if(ch=='*'){ch=fgetc(fp);}rule[i].codNum++;}i++;}rulenum=i;fclose(fp);}3. 规则库的匹配算法是什么?如何选用可用规则集中的规则?分别使用哪些函数实现的?程序中的正向与逆向搜索分别是在void main()中调用forwardFinger()和backFinger()来实现的。
Windows实验报告第二次实验
Windows实验报告计算机科学与技术学院计112 1113022032 康照玲一、实验一1、题目:在一个窗口中央加载一个任意位图,位图尺寸为窗口面积的四分之一,当单击鼠标左键或键盘上的向上箭头时,位图向上移动,当移动到窗口的上边界时,在模式对话框中显示“不能再向上移动了”字样;当单击鼠标右键或键盘上的向下箭头时,位图向下移动,当到达窗口的下边界时,在模式对话框中显示“不能再向下移动了”字样;当单击键盘上的向左箭头时,位图向左移动,当移动到窗口的左边界时,在模式对话框中显示“不能再向左移动了”字样;当单击键盘上的向右箭头时,位图向右移动,当移动到窗口的右边界时,在模式对话框中显示“不能再向右移动了”字样。
并要求图片在移动到窗口的任意边界时不消失。
2、关键代码分析首先设置窗口大小,加载位图,获得位图左上角的坐标,在按下上下左右键的时候对相关坐标进行加减,同时建立相关的模式对话框,在对位图进行移动到相关边界时出现相关对话框。
相关代码:PAINTSTRUCT ps; //定义包含绘图信息的结构变量switch(iMessage){case WM_KEYDOWN:switch(wParam){case VK_UP: //按上箭头时,位置-10iY=iY-10;break;case VK_DOWN: //按下箭头时,位置+10iY=iY+10;break;case VK_LEFT: //按左箭头时,位置-10iX=iX-10;break;case VK_RIGHT: //按右箭头时,位置+10iX=iX+10;break;}InvalidateRect(hWnd,NULL,1);//刷新用户区break;case WM_CREATE: //初始化窗口消息hDC=GetDC(hWnd); //得到设备环境指针hdcmem=CreateCompatibleDC(hDC); //得到内存指针ReleaseDC(hWnd,hDC); //删除设备环境指针case WM_PAINT: //处理绘图消息hDC=BeginPaint(hWnd,&ps); //得到设备环境指针if(iX>0&&iX<iWindowWidth/2) //当位图完整的在窗口中时{SelectObject(hdcmem,hBm); //选入内存句柄BitBlt(hDC,iX,iY,bm.bmWidth,bm.bmHeight,hdcmem,0,0,SRCCOPY);//输出位图}else if(iX<=0) //当位图的左边界超出了窗口时{DialogBox(hInst,MAKEINTRESOURCE(IDD_DIALOG3),hWnd,(DLGPROC)ModalDlgProc);}else //当位图的右边界超出了窗口时{DialogBox(hInst,MAKEINTRESOURCE(IDD_DIALOG4),hWnd,(DLGPROC)ModalDlgPr oc);}if(iY>0&&iY<iWindowHeight/2) //当位图完整的在窗口中时{SelectObject(hdcmem,hBm); //选入内存句柄BitBlt(hDC,iX,iY,bm.bmWidth,bm.bmHeight,hdcmem,0,0,SRCCOPY);break; //输出位图}else if(iY<=0) //当位图的上边界超出了窗口时{DialogBox(hInst,MAKEINTRESOURCE(IDD_DIALOG1),hWnd,(DLGPROC)ModalDlgPr oc);}else //当位图的下边界超出了窗口时{DialogBox(hInst,MAKEINTRESOURCE(IDD_DIALOG2),hWnd,(DLGPROC)ModalDlgProc);}EndPaint(hWnd,&ps); //输出环境指针break;case WM_DESTROY: //关闭窗口消息DeleteObject(hBm); //删除内存句柄PostQuitMessage(0);return 0;default:return(DefWindowProc(hWnd,iMessage,wParam,lParam));}return 0;3、模式对话框的设置,相关代码如下:IDD_DIALOG1 DIALOG DISCARDABLE 0, 0, 187, 96STYLE DS_MODALFRAME | WS_POPUP | WS_CAPTION | WS_SYSMENUCAPTION "对话"FONT 10, "System"BEGINPUSHBUTTON "确定",IDCANCEL,130,82,50,14LTEXT "不能再向上移动了"IDC_STA TIC,50,35,170,10ENDIDD_DIALOG2 DIALOG DISCARDABLE 0, 0, 187, 96STYLE DS_MODALFRAME | WS_POPUP | WS_CAPTION | WS_SYSMENUCAPTION "对话"FONT 10, "System"BEGINPUSHBUTTON "确定",IDCANCEL,130,82,50,14LTEXT "不能再向下移动了"IDC_STA TIC,50,35,170,10ENDIDD_DIALOG3 DIALOG DISCARDABLE 0, 0, 187, 96STYLE DS_MODALFRAME | WS_POPUP | WS_CAPTION | WS_SYSMENUCAPTION "对话"FONT 10, "System"BEGINPUSHBUTTON "确定",IDCANCEL,130,82,50,14LTEXT "不能再向左移动了"IDC_STA TIC,50,35,170,10ENDIDD_DIALOG4 DIALOG DISCARDABLE 0, 0, 187, 96STYLE DS_MODALFRAME | WS_POPUP | WS_CAPTION | WS_SYSMENUCAPTION "对话"FONT 10, "System"BEGINPUSHBUTTON "确定",IDCANCEL,130,82,50,14LTEXT "不能再向右移动了"IDC_STA TIC,50,35,170,10END二、实验二1、题目:建立两套菜单,第一套菜单:单击menu2,窗口加载第二套菜单:给每套菜单的每个菜单项放置热键和加速键,单击menu1后,加载第一套菜单。
时间序列二
应用时间序列分析实验报告二学生姓名张亚平学号***********院系数学与统计学院专业统计学指导教师尚林二O一二年三月三十日应用时间序列分析第二次实验报告实验题目118 某地区连续74年的谷物产量(单位:千吨)如表3-21所示(具体数据见课本102页表-21)(1)判断该序列的平稳性与纯随机性。
(2)选择适当模型拟合该序列的发展。
(3)利用拟合模型,预测该地区未来5年的谷物产量。
实验步骤1(1)根据题目所给数据得到了样本的自相关序列图,和纯随机性检验结果如下所示。
样本自相关图显示延迟3阶以后,自相关系数都落在2倍标准差范围内,而且样本自相关系数向零衰减的速度非常快,延迟6阶以后自相关系数即在零值附近波动,这是一个典型的短期相关的样本自相关图。
由时序图和样本自相关图的性质可知该序列平稳。
由纯随机性检验结果可知,在各阶延迟下LB检验统计量的P值都非常小,所以我们可以认定该序列属于非白噪声序列。
(2)为了找到合适的模型来拟合模型的发展,首先进行相对最优定阶得到结果如下。
最后一条信息显示,在自相关延迟阶数小于等于8时,移动平均阶数也小于8的所有(,)ARMA p q 模型中,BIC 信息量相对最小的是(1,0)ARMA 模型,即(1)AR 模型。
然后对参数进行估计,得到如下结果:因此可得该序列拟合的模型为:10.92722t t x x -= (1) (3) 利用模型(1)对该地区未来五年的谷产量进行预测得到结果如下:并画出拟合、预测图如图1所示:图1 该地区谷产量拟合、预测图相关程序:data grain_1;input grain@@;time=_n_;cards;0.97 0.45 1.61 1.26 1.37 1.43 1.32 1.23 0.84 0.89 1.181.33 1.21 0.98 0.91 0.61 1.23 0.97 1.10 0.74 0.80 0.810.80 0.60 0.59 0.63 0.87 0.36 0.81 0.91 0.77 0.96 0.930.95 0.65 0.98 0.70 0.86 1.32 0.88 0.68 0.78 1.25 0.791.19 0.69 0.93 0.86 0.86 0.85 0.90 0.54 0.32 1.40 1.140.69 0.91 0.68 0.57 0.94 0.35 0.39 0.45 0.99 0.84 0.620.85 0.73 0.66 0.76 0.63 0.32 0.17 0.46;proc arima data=grain_1;identify var=grain minic p=(0:8) q=(0:8);estimate p=1 noint;forecast lead=5id=time out=results;run;proc gplot data=results;plot grain*time=1 forecast*time=2 l95*time=3 u95*time=3/overlay; symbol1c=black i=none v=star;symbol2c=red i=join v=none;symbol3c=green i=join v=none l=32;run;实验题目23-19 现有201个连续的生产纪录,如表3-22所示(具体数据见课本102-103页表3-22)(1)判断该序列的平稳性与纯随机性。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
重庆大学计算机基础系列课程实验报告本
课程名称嵌入式系统
实验学期2012年至2013年第 1学期学生所在学院计算机学院
年级2009 专业班级计算机科学与技术学生姓名学号
指导教师汪成亮
实验最终成绩
计算机学院基础系制
3)修改PANID,为了让我们的实验箱能够支持同时使用,我们必须要更改我们的PANID来区分不同的网络架构。
修改PANID的方法如下。
a. 首先打开我们的sink.eww工程,这个是我们的主节点的工程。
2)打开border.h 文件,将#define BUTTONS_MB851A 1 修改为#define BUTTONS_MB851A 2
就可以进行烧写了。
按动就可以进行烧写了。
烧写成功后就可以使用了。