实验源代码 //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); }
上传时间: 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
近年来,随着超声学研究的发展,功率超声技术得到了越来越广泛的应用。超声波清洗技术作为功率超声技术的一个分支,以清洗速度快、效果好、易于实现自动化等优点,为传统工业清洗领域注入了新鲜的血液。作为超声波清洗机的核心组件,超声逆变电源的设计一直是超声波清洗系统设计的关键环节,它性能的好坏很大程度上决定了最终的清洗效果。以往的超声逆变电源的设计通常是基于模拟集成控制芯片的,这种实现方式在频率、功率控制的精度和速度上以及系统的灵活性、稳定性方面存在着一定的局限性,限制了超声逆变电源的发展。数字控制技术的出现,很好地弥补了上述缺陷,因此本课题将数字控制技术引入到超声逆变电源控制电路的设计中是很有意义的。 本文首先对超声逆变电源的基本结构和工作原理做了简单介绍,针对超声逆变电源各部分的结构特点,并结合一些传统设计方案优缺点的分析,确定了二极管不控整流的整流电路设计方案、电压源型串联谐振逆变器的逆变电路实现方案、基于锁相环的频率跟踪实现方案、和基于PWM脉宽调制技术的功率调节实现方案。接着,文章详细介绍了频率自动跟踪和功率控制的具体实现方法,利用数学推理和波形分析的方式阐明了方案的可行性,并通过软件仿真验证了方案的正确性。然后,文章还设计了主电路谐振软开关、人机接口电路、采样电路、IGBT驱动以及过流过温保护电路。方案确定了之后,通过观察自制电路板的实验波形表明新构建的超声逆变电源可以保证系统在复杂工况下处于谐振状态,验证了全数字频率跟踪系统和功率调节系统的可行性和有效性。 本文的重点和创新点在于将超声逆变电源的控制电路通过数字化来实现。本文创新地利用FPGA构建了全数字频率跟踪系统——数字锁相环和全数字功率调节系统——数字PWM调制、数字PID调节,从而取代了传统的模拟锁相环芯片CD4046和模拟PWM控制芯片SG3525,在控制的精确性、快速性和灵活性上都有了很大的提高。此外,利用ATmega16单片机实现了人机接口电路、频率采样和电流A/D转换,并通过SPI接口与FPGA进行数据传输,完善了数字控制体系,从而实现了基于FPGA和单片机的全数字控制超声逆变电源系统。
上传时间: 2022-05-30
上传用户:
CCD(电荷耦合器)摄像头基本知识现在科学级的摄像头比前几年更尖端, 应用领域也更广了。在生物科学领域,从显微镜、分光光度计到胶文件、化学放光探测系统, 都用到了CCD 的摄像头。但是很多研究工作者对CCD 的指标仍云里雾里。下面对CCD 的一些常见指标进行表述。常见的CCD 一般指: CCD 摄像头和插在电脑的采集卡区别数字摄像头与模拟摄像头所有CCD 芯片都属于模拟的设备。当图像进入计算机是数字的。如果信号在摄像头、采集卡两部分完成数字化的,这个CCD 被认为是模拟CCD。数字摄像头事实上是由内置于摄像头的数字化设备完成数字化过程, 这样可以减少图像噪音。与模拟摄像头相比, 数字摄像头提高了摄像头的信噪比、增加摄像头的动态范围、最大化图像灰度范围。科学级的绝大多数的CCD 芯片都是由Kodak、Sony、SIT 制造。评价CCD 的基本指标信噪比SNR 真实体现摄像头的检测能力。所有的CCD 摄像头的厂家为提高摄像头的性能, 都尽力使信号(可达到满井电子的数目) 最大同时尽可能减少噪音。
上传时间: 2022-06-23
上传用户:xsr1983
AR0231AT7C00XUEA0-DRBR(RGB滤光)安森美半导体推出采用突破性减少LED闪烁 (LFM)技术的新的230万像素CMOS图像传感器样品AR0231AT,为汽车先进驾驶辅助系统(ADAS)应用确立了一个新基准。新器件能捕获1080p高动态范围(HDR)视频,还具备支持汽车安全完整性等级B(ASIL B)的特性。LFM技术(专利申请中)消除交通信号灯和汽车LED照明的高频LED闪烁,令交通信号阅读算法能于所有光照条件下工作。AR0231AT具有1/2.7英寸(6.82 mm)光学格式和1928(水平) x 1208(垂直)有源像素阵列。它采用最新的3.0微米背照式(BSI)像素及安森美半导体的DR-Pix™技术,提供双转换增益以在所有光照条件下提升性能。它以线性、HDR或LFM模式捕获图像,并提供模式间的帧到帧情境切换。 AR0231AT提供达4重曝光的HDR,以出色的噪声性能捕获超过120dB的动态范围。AR0231AT能同步支持多个摄相机,以易于在汽车应用中实现多个传感器节点,和通过一个简单的双线串行接口实现用户可编程性。它还有多个数据接口,包括MIPI(移动产业处理器接口)、并行和HiSPi(高速串行像素接口)。其它关键特性还包括可选自动化或用户控制的黑电平控制,支持扩频时钟输入和提供多色滤波阵列选择。封装和现状:AR0231AT采用11 mm x 10 mm iBGA-121封装,现提供工程样品。工作温度范围为-40℃至105℃(环境温度),将完全通过AEC-Q100认证。
标签: 图像传感器
上传时间: 2022-06-27
上传用户:XuVshu
注塑机生产过程的微机控制系统设计本系统设计是通过8255A并行端口A、B传输数据控制12个LED发光二级管的亮灭来模拟控制两台注塑机的生产过程。其中端口A和B分别对应1号和2号注塑机,每一个LED代表一个工序。编程语言采用BORLAND C++语言。
上传时间: 2013-12-25
上传用户:叶山豪
全国交通咨询模拟 一、程序界面 A.关于程序 B. 程序的使用 ...
上传时间: 2014-01-09
上传用户:lili123
98年全国大学生数学建模竞赛B题"水灾巡视问题"模拟退火算法。
上传时间: 2015-06-29
上传用户:a6697238
98年全国大学生数学建模竞赛B题"水灾巡视问题"模拟退火算法。
上传时间: 2015-06-29
上传用户:tuilp1a
s平面中直接形式到级联形式的转换 %适合模拟滤波器的 %C为增益系数 %B为包含各bk的K乘3维实系数矩阵 %A为包含各ak的K乘3维实系数矩阵 %b为直接形式的分子多项式系数 %a为直接形式的分母多项式系数
上传时间: 2015-07-22
上传用户:sdq_123