这段代码加注释vec.SetPinVoltage(0); vec.ClosePinRelay(allpin,SIZEOF_ARRAY(allpin)); int i,j; int k,n; int data_num[4096]={0}; for(i=0;i<4096;i++) { data_num[i]=0; } DWORD * pea = new DWORD[49440]; BYTE * buf = new BYTE [98880]; assert(pea != NULL); assert(buf != NULL); int adc_data; int mid_data[24]; FILE fp; fp = fopen(filename,"w"); int con; for(con=0;con<10;con++) { Create_AWG_Data(con); vec.Run(0,18); while(vec.Running()); DWORD ern = vec.GetResult(); if(ern) { if(fp!=NULL) { vec.GetFailData(ern,pea,buf,outpin,SIZEOF_ARRAY(outpin)); n=(int)ern/12; for(i=0;i<n;i++) { j=i24; for(k=0;k<24;k++) { mid_data[k]=(int)buf[j+k]; } adc_data=(mid_data[0]<<11) | (mid_data[2]<<10) | (mid_data[4]<<9) | (mid_data[6]<<8) | (mid_data[8]<<7) | (mid_data[10]<<6) | (mid_data[12]<<5) | (mid_data[14]<<4) | (mid_data[16]<<3) | (mid_data[18]<<2) | (mid_data[20]<<1)|mid_data[22]; data_num[adc_data]++; fprintf(fp,"%d: %d\n",i+con*4120,adc_data); } } } } for(i=0;i<4096;i++) { if (data_num[i]) fprintf(fp,"%d: %d\n",i,data_num[i]); } vec.OpenPinRelay(allpin,SIZEOF_ARRAY(allpin)); SetCurrentDirectory(temp1); unsigned long all_data_num=0; for(i=1; i<4095; i++) { all_data_num+=data_num[i]; }
时间: 2023-07-15 10:13:55 浏览: 133
// 设置第一个引脚电压为0,关闭所有引脚继电器
vec.SetPinVoltage(0);
vec.ClosePinRelay(allpin,SIZEOF_ARRAY(allpin));
// 初始化数组data_num,将其所有元素初始化为0
int i,j;
int k,n;
int data_num[4096]={0};
for(i=0;i<4096;i++) {
data_num[i]=0;
}
// 动态分配内存,pea长度为49440个DWORD,buf长度为98880个BYTE
DWORD * pea = new DWORD[49440];
BYTE * buf = new BYTE [98880];
assert(pea != NULL);
assert(buf != NULL);
int adc_data;
int mid_data[24];
FILE fp;
fp = fopen(filename,"w");
int con;
// 进行10次循环
for(con=0;con<10;con++) {
// 创建AWG数据
Create_AWG_Data(con);
// 运行向量信号发生器
vec.Run(0,18);
// 等待向量信号发生器运行完成
while(vec.Running());
// 获取向量信号发生器的结果
DWORD ern = vec.GetResult();
if(ern) {
// 如果获取结果失败,则将结果写入文件
if(fp!=NULL) {
vec.GetFailData(ern,pea,buf,outpin,SIZEOF_ARRAY(outpin));
n=(int)ern/12;
for(i=0;i<n;i++) {
j=i*24;
for(k=0;k<24;k++) {
mid_data[k]=(int)buf[j+k];
}
adc_data=(mid_data[0]<<11) | (mid_data[2]<<10) | (mid_data[4]<<9) | (mid_data[6]<<8) | (mid_data[8]<<7) | (mid_data[10]<<6) | (mid_data[12]<<5) | (mid_data[14]<<4) | (mid_data[16]<<3) | (mid_data[18]<<2) | (mid_data[20]<<1)|mid_data[22];
data_num[adc_data]++;
fprintf(fp,"%d: %d\n",i+con*4120,adc_data);
}
}
}
}
// 将data_num数组中的内容写入文件
for(i=0;i<4096;i++) {
if (data_num[i])
fprintf(fp,"%d: %d\n",i,data_num[i]);
}
// 打开所有引脚继电器,返回上一级目录
vec.OpenPinRelay(allpin,SIZEOF_ARRAY(allpin));
SetCurrentDirectory(temp1);
// 计算data_num数组中所有元素的和
unsigned long all_data_num=0;
for(i=1; i<4095; i++) {
all_data_num+=data_num[i];
}
阅读全文