MATLAB串口通信
使用MATLAB进行串口调试的两种方法

使用MATLAB进行串口调试的两种方法在MATLAB中进行串口调试有多种方法,可以使用MATLAB自带的Instrument Control Toolbox,或使用第三方函数库进行串口通信。
1. 使用MATLAB自带的Instrument Control Toolbox进行串口调试Instrument Control Toolbox是MATLAB中用于连接和控制仪器的工具箱。
它提供了一组函数,可以通过串口与仪器进行通信。
第一步是创建串口对象。
使用MATLAB的serial函数可以创建一个串口对象,并设置串口的参数。
例如,以下代码创建一个串口对象并设置波特率为9600,数据位为8位,停止位为1位,校验位为无:```matlabs = serial('COM1');set(s, 'BaudRate', 9600);set(s, 'DataBits', 8);set(s, 'StopBits', 1);set(s, 'Parity', 'none');```第二步是打开串口。
使用MATLAB的fopen函数可以打开串口并进行通信:```matlabfopen(s);```第三步是发送和接收数据。
可以使用MATLAB的fwrite函数向串口发送数据,使用fread函数从串口接收数据。
以下代码发送一个字节的数据,并接收一个字节的数据:```matlabfwrite(s, uint8('A'));receivedData = fread(s, 1);```最后一步是关闭串口。
使用MATLAB的fclose函数可以关闭已经打开的串口:```matlabfclose(s);```2.使用第三方函数库进行串口通信```matlabimport java.io.*;import ng.*;import gnu.io.*;```创建和配置串口对象的步骤与使用Instrument Control Toolbox类似:```matlabport = 'COM1';baudRate = 9600;dataBits = 8;stopBits = 1;parity = 'none';s = serial(port, baudRate, dataBits, stopBits, parity);```打开串口和发送/接收数据的步骤也与使用Instrument Control Toolbox类似:```matlabfopen(s);fwrite(s, uint8('A'));receivedData = fread(s, 1);```关闭串口的步骤也是一样的:```matlabfclose(s);```这些是使用MATLAB进行串口调试的两种常见方法。
matlab中的串口通信通信系统设计

文章标题:探索Matlab中的串口通信系统设计在当前的现代通信系统中,串口通信系统设计已经成为一项至关重要的任务。
在Matlab中,借助各种工具和函数,我们可以设计出高效、稳定和灵活的串口通信系统。
本文将从简单到复杂、由浅入深地探讨Matlab中的串口通信系统设计,为读者提供全面的了解和深入的思考。
1. 串口通信系统概述在进行Matlab中的串口通信系统设计之前,我们首先需要了解串口通信系统的基本概念和原理。
串口通信是通过串行接口进行数据传输的一种通信方式,它在各种领域中都有着广泛的应用,包括嵌入式系统、通信设备、工业控制等。
Matlab作为强大的工程计算软件,为我们提供了丰富的工具和函数来进行串口通信系统设计,包括串口对象、串口配置、数据读写等功能。
2. Matlab中的串口通信基本操作在Matlab中,我们可以通过串口对象来进行串口通信的基本操作。
我们需要创建一个串口对象,并进行相应的配置,包括波特率、数据位、停止位、校验位等参数。
我们可以使用该串口对象来进行数据的读写操作,可以发送数据到外部设备,也可以接收来自外部设备的数据。
通过Matlab中丰富的串口函数,我们可以轻松实现串口通信系统的基本功能。
3. Matlab中的串口通信系统设计在实际的工程应用中,我们通常需要设计更加复杂和灵活的串口通信系统。
在Matlab中,我们可以借助信号处理工具箱、通信工具箱等功能来进行串口通信系统的设计。
通过信号处理工具箱,我们可以实现对串口数据的解调、调制、滤波等操作,从而提高通信系统的稳定性和性能。
而通信工具箱中的各种算法和工具则可以帮助我们实现更加复杂的通信协议和数据处理。
4. 个人观点和总结在我看来,Matlab是一款非常适合进行串口通信系统设计的软件,它不仅提供了丰富的工具和函数,还具备强大的计算能力和灵活的编程环境。
通过Matlab,我们可以实现从简单到复杂的串口通信系统设计,为各种应用场景提供定制化的解决方案。
MATLAB串口通信

%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%本程序主要实现串口控制三轴转台进行自动标定,%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%查找串口对象,若串口一开始被占用,需要加上这段程序释放串口,若串口没有被占用,则不需要这段程序scoms = instrfind;%%尝试停止、关闭删除串口对象stopasync(scoms);fclose(scoms); %关闭串口delete(scoms); %释放串口%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%clear all;clc;%%%%%串口配置通道1global s;s = serial('COM13'); %设置串口号s.baudrate = 57600; %设置波特率s.parity = 'none'; %校验位s.stopbits = 1; %停止位s.databits = 7; %数据位s.timeout = 2; %一次读/写的时间最长为0.5ss.InputBufferSize = 1024; %输入缓冲区s.OutputBufferSize = 1024; %输出缓冲区% s.BytesAvailableFcnMode = 'byte'; %中断触发事件为'bytes-available event' % s.BytesAvailableFcnCount = 8; %接收缓冲区每收到n个字节时,触发回调函数% s.BytesAvailableFcn = {'cmd_rec_callback', handles};%得到回调函数句柄fopen(s); %%%%打开串口fclose(s);%%%%%串口配置通道2global s2;s2 = serial('COM15'); %设置串口号s2.baudrate = 460800; %设置波特率s2.parity = 'none'; %校验位s2.stopbits = 1; %停止位s2.databits = 8; %数据位s2.timeout = 2; %一次读/写的时间最长为0.5ss2.InputBufferSize = 1024; %输入缓冲区s2.OutputBufferSize = 1024; %输出缓冲区% s.BytesAvailableFcnMode = 'byte'; %中断触发事件为'bytes-available event' % s.BytesAvailableFcnCount = 8; %接收缓冲区每收到n个字节时,触发回调函数% s.BytesAvailableFcn = {'cmd_rec_callback', handles};%得到回调函数句柄fopen(s2); %%%%打开串口fclose(s2);% InitPos(1)=InitPos(1)+0.3% Pos1=num2str(InitPos(1)');% Pos1=['Q010',Pos1(1,:),'$'];% A=[0 0 0 0 0 0 0 0 0 0 0];% fwrite(s2,A,'uint8')% AA=fread(s2,11,'uint8')%%%%%%%定义变量,存放星点位置PosX=zeros(41,51);PosY=zeros(41,51);AllX=zeros(30,2091);AllY=zeros(30,2091);n=1;InitPos=[0.3 0.0000 93.4253];Flag=0;MouseX=1354;MouseY=376;LeftC=1;global filename4;global filename5;filename4=['D:\1-3\*.bmp' ];filename5=['D:\1-3\'];%%%%%%%三轴转台,自动标定for j=1:41fopen(s);for i=1:51%%%%%%%%%%%控制鼠标左键,采集图像PressMouse(MouseX,MouseY,LeftC);PressMouse(MouseX,MouseY,LeftC);pause(5); %等待整数秒%%%%%%%%%%%%%读取转台位置坐标,进行反馈控制fopen(s2);[Flag]=ReadCoor(s2,InitPos);fclose(s2);while (Flag==1)%%%%%%%%%%%%%删除上次存储的点的图片filename6=dir(filename4); %显示xxx目录下的文件和文件夹[~,index] = sortrows({filename6.date}.'); %index变址向量,重新排序前的地址filename6 = filename6(index);clear indexpath=[filename5]; %查看或者改变路径for k=(length(filename6)-29): length(filename6)A=[path filename6(k).name];delete(A);end%%%%%%%%%%%%%向内轴发定位命令,位置:12.3456?;ASC码:Q01012.3456$ ;16进制数:51H 30H 30H 31H 31H 32H 2EH 33H 34H 35H 36H 24HPos1=num2str(InitPos(1)');Pos1=['Q010',Pos1(1,:),'$'];fwrite(s,Pos1,'char')pause(2);%%%%%%%%%%%%%向中轴发定位命令,位置:12.3456?;ASC码:Q01112.3456$ ;16进制数:51H 30H 31H 31H 31H 32H 2EH 33H 34H 35H 36H 24HPos2=num2str(InitPos(2)');Pos2=['Q011',Pos2(1,:),'$'];fwrite(s,Pos2,'char');pause(2);%%%%%%%%%%%%%向外轴发定位命令,位置:12.3456?;ASC码:Q01212.3456$ ;16进制数:51H 30H 32H 31H 31H 32H 2EH 33H 34H 35H 36H 24HPos3=num2str(InitPos(3)');Pos3=['Q012',Pos3(1,:),'$'];fwrite(s,Pos2,'char');fclose(s);pause(2);%%%%%%%%%%%控制鼠标左键,采集图像PressMouse(MouseX,MouseY,LeftC);PressMouse(MouseX,MouseY,LeftC);pause(5); %等待整数秒% B=[0 12 34 56 0 0 0 0 0 0 0];% fwrite(s2,B,'uint8')fopen(s2);[Flag]=ReadCoor(s2,InitPos);fclose(s2);end%%%%%%%%%%中轴坐标位置一次-0.3°InitPos(2)=InitPos(2)-0.3;%%%%%%%%串口给转台发送命令,设定增量模式,中框增量-0.3°,ASC码:Q02 1 -0.3$ 16进制数:51 30 32 31 2D 30 2E 33 24fwrite(s,'Q021-0.3$','char');pause(3); %等待整数秒end%%%%%%%%%每个点找一张图存到新建文件夹filename=['D:\',num2str(j)]new_folder = filename; % new_folder 保存要创建的文件夹,是绝对路径+文件夹名称mkdir(new_folder); % mkdir()函数创建文件夹filename=dir(filename5);[~,index] = sortrows({filename.date}.'); %index变址向量,重新排序前的地址filename = filename(index);clear indexfor r=1:51k=30*(r-1)+1;path=[filename5];A0=imread([path filename(k).name]);imshow(A0);B=['D:\j\',num2str(r),'.bmp'];imwrite(A0,B,'bmp');endfwrite(s,'Q02115$','char');pause(5);%%%%%%%%%%计算星点坐标[x,y,x0,y0]=SigleStarPointCalibration(j, filename4 ,filename5);PosX(j,:)=x;PosY(j,:)=y;AllX(:,n*51-50)=x0;AllY(:,n*51-50)=y0;n=n+1;%%%%%%%%%%中轴坐标位置回到初始位置InitPos(2)=InitPos(2)+15.3;%%%%%%%%%%内轴坐标位置增量+0.3°InitPos(1)=InitPos(1)+0.3;if (InitPos(1)>360)InitPos(1)=InitPos(1)-360;end%%%%%%%%串口给转台发送命令,增量模式,内框增量-0.3°,ASC码:Q01 0 0.3$ 16进制数:51 30 32 30 30 2E 33 24fwrite(s,'Q0200.3$','char');pause(3); %等待整数秒fclose(s);end%%%%%%%关闭串口fclose(s);%查找串口对象scoms = instrfind;% 尝试停止、关闭删除串口对象stopasync(scoms);fclose(scoms); %关闭串口delete(scoms); %释放串口。
【STM32H7的DSP教程】第9章Matlab的串口通信实现

【STM32H7的DSP教程】第9章Matlab的串⼝通信实现第9章 Matlab的串⼝通信实现本章节主要为⼤家讲解Matlab的串⼝⽅式波形数据传输和后期数据分析功能,⾮常实⽤。
9.1 初学者重要提⽰9.2 程序设计框架9.3 下位机STM32H7程序设计9.4 上位机Matlab程序设计9.5 Matlab上位机程序运⾏9.6 实验例程说明(MDK)9.7 实验例程说明(IAR)9.8 总结9.1 初学者重要提⽰1、测试本章节例程注意事项。
请优先运⾏开发板,然后运⾏matlab。
调试matlab串⼝数据发送前,请务必关闭串⼝助⼿。
2、函数delete(instrfindall);如果不⽤matlab了,请在matlab的命令输⼊窗⼝调⽤此函数,防⽌matlab⼀直占⽤串⼝。
9.2 程序设计框架上位机和下位机的程序设计框架如下:上位机和下位机做了⼀个简单的同步,保证数据通信不出错。
9.3 下位机STM32H7程序设计STM32H7端的程序设计思路。
9.3.1 第1步,发送的数据格式为了⽅便数据发送,专门设计了⼀个数据格式:__packed typedef struct{uint16_t data1;uint16_t data2;uint16_t data3;uint8_t data4;uint8_t data5;uint8_t data6;uint8_t data7;}SENDPARAM_T;SENDPARAM_T g_SendData;9.3.2 第2步,接收同步信号$Matlab发送同步信号$(ASCII编码值是13)给开发板。
int main(void)/* 省略未写,仅留下关键代码 *//* 进⼊主程序循环体 */while (1){/* 判断定时器超时时间 */if (bsp_CheckTimer(0)){/* 每隔100ms 进来⼀次 */bsp_LedToggle(2);}if (comGetChar(COM1, &read)){/* 接收到同步帧'$'*/if(read == 13){bsp_LedToggle(4);bsp_DelayMS(10);Serial_sendDataMATLAB();}}}}通过函数comGetChar获取串⼝接收到的数据,如果数值是13,说明接收到Matlab发送过来的同步信号了。
matlab之串口通信

matlab之串口通信matlab之串口通信串口通信,一般是指RS232、RS422之间的通信。
matlab中有专门的serial函数来创建串口对象。
设串口ID号为COM1,则创建方法为:复制内容到剪贴板代码:>>scom= serial('com1');创建完串口对象后,一般需要设置串口对象的属性,否则,串口不会相互通信。
复制内容到剪贴板代码:>> get(scom)ByteOrder = littleEndianBytesAvailable = 0BytesAvailableFcn =BytesAvailableFcnCount = 48BytesAvailableFcnMode = terminatorBytesToOutput = 0ErrorFcn =InputBufferSize = 512Name= Serial-COM1ObjectVisibility = onOutputBufferSize = 512OutputEmptyFcn =RecordDetail = compactRecordMode = overwriteRecordName = record.txtRecordStatus = offStatus = closedTag=Timeout = 10TimerFcn =TimerPeriod = 1TransferStatus = idleType= serialUserData = []ValuesReceived = 0ValuesSent = 0SERIAL specific properties:BaudRate= 9600BreakInterruptFcn =DataBits = 8DataTerminalReady = onFlowControl = noneParity = nonePinStatus = [1x1 struct]PinStatusFcn =Port= COM1ReadAsyncMode = continuousRequestToSend = offStopBits = 1Terminator = LF这些属性中,要使串口真正通信,一般要设置这几个属性:BaudRate:波特率;Parity:奇偶校验类型;DataBits:数据位,一般为8,不用设置;StopBits:停止位,一般为1,不用设置;TimerFcn :定时回调函数;TimerPeriod:定时周期;BytesAvailableFcn:字节计数回调函数BytesAvailableFcnCount:字节计数BytesAvailableFcnMode:一般设置为字节模式,即byte串口通信时,数据一般按帧传送,有的数据量比较大,会将帧打包后发送。
matlab 串口协议解析

matlab 串口协议解析Matlab是一种强大的数学计算软件,可以进行数据处理、算法设计、模拟仿真等多种功能。
在工程领域中,我们经常需要通过串口与外部设备进行数据通信。
本文将介绍如何使用Matlab进行串口协议解析,以实现与外部设备的数据交互。
我们需要了解串口协议的基本概念。
串口是一种用于数据传输的接口,通过串口可以实现设备之间的数据通信。
串口协议定义了数据的传输格式和规则,包括数据的起始位、停止位、数据位、波特率等信息。
在Matlab中,我们可以使用Serial对象来实现串口通信。
首先,我们需要创建一个Serial对象,并指定串口的端口号、波特率等参数。
然后,我们可以使用该对象的read和write方法来进行数据的读写操作。
在解析串口数据时,我们需要了解外部设备发送的数据格式。
通常,外部设备会以一定的规则将数据发送到串口中,我们需要根据这些规则将数据解析出来。
常见的数据格式有ASCII码、二进制等。
以ASCII码为例,外部设备发送的数据通常是以字符串的形式进行传输。
在Matlab中,我们可以使用Serial对象的read方法读取串口数据,并将其保存为字符串。
然后,我们可以使用字符串处理函数对数据进行解析,提取出所需的信息。
例如,假设外部设备发送的数据格式为“温度:25°C,湿度:60%”。
我们可以使用Matlab的字符串处理函数来提取出温度和湿度的数值。
首先,我们可以使用strsplit函数将字符串按照“:”进行分割,得到包含温度和湿度的子字符串。
然后,我们可以使用strtrim函数去除子字符串中的空格,并使用str2double函数将数值转换为double类型。
最后,我们就可以得到温度和湿度的数值,进行后续的数据处理和显示。
除了ASCII码,外部设备还可以以二进制的形式发送数据。
在这种情况下,我们需要按照数据的长度和字节顺序进行解析。
通常,我们可以将接收到的二进制数据保存为一个字节数组,并使用bitget 和bitshift函数提取出所需的位数据。
MATLAB串口通讯

if recdta==255 %找帧头
rectr=rectr+1; %接收计数器加1
recbuf(rectr)=recdta; %送入接收缓冲区
elseif recdta==framelen&rcbuf(1)==255 %验证接收长度和帧头
%以下程序用以数据进行滤波
inbuffer2=filter(…., Inbuffer1);
%以下程序用以对滤波后数据进行文件存储
fid = fopen('C:\MATLAB7\work\data.txt','a+'); %创建并data.txt文件
fprintf(fid,'%3d',inbuffer2); %将滤波后数据存储到fid文件设备中
%根据具体通讯协议提取数据
…
%接收滤波后的数据
….
plot(…) %输出显示
end
else rectr=0; %未找到帧头清计数器
end %接收结束
end %主循环结束
g.inputbuffersize=256; %设置输入缓冲区为256b,缺省值为512b
g.Terminator='LF'; %设置输入缓冲区为256b,缺省值
recbuf=zeros(1,40); %清接收缓冲区(40)
framelen=23; %帧长度(每帧23byte)
%修改后的instrcallback.m文件如下:
function instrcallback(obj, event)
%以下是用户自行添加的通信事件处理及通信数据处理的中断服务程序代码
%定义存储串口30个字节通信数据的数组
matlab串口通信基础讲义

matlab串口通信基础讲义①支持基于串行接口(RS-232、RS-422、RS-485)、GPIB总线(IEEE2488、HPIB标准)、VISA总线的通信;②通信数据支持二进制和文本(ASCII)两种方式,文本方式支持SCPI(Standard Commands for Programmable Instruments)语言;③支持异步通信和同步通信;④支持基于事件驱动的通信。
从以上的Matlab设备控制工具箱的特点可以看到,Matlab完全可以满足我们实现串行通信的要求。
3.1Matlab对串行口控制的基础知识Matlab对串行口的编程控制主要分为四个步骤。
①创建串口设备对象并设置其属性。
scom=serial('com1');%创建串口1的设备对象scomscom.Terminator='CR';%设置终止符为CR(回车符),缺省为LF(换行符)scom.InputBufferSize=1024;%输入缓冲区为256B,缺省值为512Bscom.OutputBufferSize=1024;%输出缓冲区为256B,缺省值为512Bscom.Timeout=0.5;%Y设置一次读或写操作的最大完成时间为0.5s,缺省值为10ss.ReadAsyncMode='continuous'(缺省方式);%在异步通信模式方式下,读取串口数据采用连续接收数据(continuous)的缺省方式,那么下位机返回的数据会自动地存入输入缓冲区中.注意:在些属性只有在对象没有被打开时才能改变其值,如InputBufferSize、OutputBufferSize属性等。
对于一个RS-232/RS-422/RS-485串口设备对象,其属性的缺省值为波特率9600b/s,异步方式,通信数据格式为8位数据位,无奇偶校验位,1位停止位。
如果要设置的串口设置对象的属性值与缺省值的属性值相同,用户可以不用另行设置。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%本程序主要实现串口控制三轴转台进行自动标定,%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%查找串口对象,若串口一开始被占用,需要加上这段程序释放串口,若串口没有被占用,则不需要这段程序scoms=instrfind;%%尝试停止、关闭删除串口对象stopasync(scoms);fclose(scoms);%关闭串口delete(scoms);%释放串口%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%clear all;clc;%%%%%串口配置通道1global s;s=serial('COM13');%设置串口号s.baudrate=57600;%设置波特率s.parity='none';%校验位s.stopbits=1;%停止位s.databits=7;%数据位s.timeout=2;%一次读/写的时间最长为0.5ss.InputBufferSize=1024;%输入缓冲区s.OutputBufferSize=1024;%输出缓冲区%s.BytesAvailableFcnMode='byte';%中断触发事件为'bytes-available event' %s.BytesAvailableFcnCount=8;%接收缓冲区每收到n个字节时,触发回调函数%s.BytesAvailableFcn={'cmd_rec_callback',handles};%得到回调函数句柄fopen(s);%%%%打开串口fclose(s);%%%%%串口配置通道2global s2;s2=serial('COM15');%设置串口号s2.baudrate=460800;%设置波特率s2.parity='none';%校验位s2.stopbits=1;%停止位s2.databits=8;%数据位s2.timeout=2;%一次读/写的时间最长为0.5ss2.InputBufferSize=1024;%输入缓冲区s2.OutputBufferSize=1024;%输出缓冲区%s.BytesAvailableFcnMode='byte';%中断触发事件为'bytes-available event' %s.BytesAvailableFcnCount=8;%接收缓冲区每收到n个字节时,触发回调函数%s.BytesAvailableFcn={'cmd_rec_callback',handles};%得到回调函数句柄fopen(s2);%%%%打开串口fclose(s2);%InitPos(1)=InitPos(1)+0.3%Pos1=num2str(InitPos(1)');%Pos1=['Q010',Pos1(1,:),'$'];%A=[00000000000];%fwrite(s2,A,'uint8')%AA=fread(s2,11,'uint8')%%%%%%%定义变量,存放星点位置PosX=zeros(41,51);PosY=zeros(41,51);AllX=zeros(30,2091);AllY=zeros(30,2091);n=1;InitPos=[0.30.000093.4253];Flag=0;MouseX=1354;MouseY=376;LeftC=1;global filename4;global filename5;filename4=['D:\1-3\*.bmp'];filename5=['D:\1-3\'];%%%%%%%三轴转台,自动标定for j=1:41fopen(s);for i=1:51%%%%%%%%%%%控制鼠标左键,采集图像PressMouse(MouseX,MouseY,LeftC);PressMouse(MouseX,MouseY,LeftC);pause(5);%等待整数秒%%%%%%%%%%%%%读取转台位置坐标,进行反馈控制fopen(s2);[Flag]=ReadCoor(s2,InitPos);fclose(s2);while(Flag==1)%%%%%%%%%%%%%删除上次存储的点的图片filename6=dir(filename4);%显示xxx目录下的文件和文件夹[~,index]=sortrows({filename6.date}.');%index变址向量,重新排序前的地址filename6=filename6(index);clear indexpath=[filename5];%查看或者改变路径for k=(length(filename6)-29):length(filename6)A=[path filename6(k).name];delete(A);end%%%%%%%%%%%%%向内轴发定位命令,位置:12.3456?;ASC码:Q01012.3456$;16进制数:51H30H30H31H31H32H2EH33H34H35H36H24HPos1=num2str(InitPos(1)');Pos1=['Q010',Pos1(1,:),'$'];fwrite(s,Pos1,'char')pause(2);%%%%%%%%%%%%%向中轴发定位命令,位置:12.3456?;ASC码:Q01112.3456$;16进制数:51H30H31H31H31H32H2EH33H34H35H36H24HPos2=num2str(InitPos(2)');Pos2=['Q011',Pos2(1,:),'$'];fwrite(s,Pos2,'char');pause(2);%%%%%%%%%%%%%向外轴发定位命令,位置:12.3456?;ASC码:Q01212.3456$;16进制数:51H30H32H31H31H32H2EH33H34H35H36H24HPos3=num2str(InitPos(3)');Pos3=['Q012',Pos3(1,:),'$'];fwrite(s,Pos2,'char');fclose(s);pause(2);%%%%%%%%%%%控制鼠标左键,采集图像PressMouse(MouseX,MouseY,LeftC);PressMouse(MouseX,MouseY,LeftC);pause(5);%等待整数秒%B=[01234560000000];%fwrite(s2,B,'uint8')fopen(s2);[Flag]=ReadCoor(s2,InitPos);fclose(s2);end%%%%%%%%%%中轴坐标位置一次-0.3°InitPos(2)=InitPos(2)-0.3;%%%%%%%%串口给转台发送命令,设定增量模式,中框增量-0.3°,ASC码:Q021-0.3$16进制数:513032312D302E3324fwrite(s,'Q021-0.3$','char');pause(3);%等待整数秒end%%%%%%%%%每个点找一张图存到新建文件夹filename=['D:\',num2str(j)]new_folder=filename;%new_folder保存要创建的文件夹,是绝对路径+文件夹名称mkdir(new_folder);%mkdir()函数创建文件夹filename=dir(filename5);[~,index]=sortrows({filename.date}.');%index变址向量,重新排序前的地址filename=filename(index);clear indexfor r=1:51k=30*(r-1)+1;path=[filename5];A0=imread([path filename(k).name]);imshow(A0);B=['D:\j\',num2str(r),'.bmp'];imwrite(A0,B,'bmp');endfwrite(s,'Q02115$','char');pause(5);%%%%%%%%%%计算星点坐标[x,y,x0,y0]=SigleStarPointCalibration(j,filename4,filename5);PosX(j,:)=x;PosY(j,:)=y;AllX(:,n*51-50)=x0;AllY(:,n*51-50)=y0;n=n+1;%%%%%%%%%%中轴坐标位置回到初始位置InitPos(2)=InitPos(2)+15.3;%%%%%%%%%%内轴坐标位置增量+0.3°InitPos(1)=InitPos(1)+0.3;if(InitPos(1)>360)InitPos(1)=InitPos(1)-360;end%%%%%%%%串口给转台发送命令,增量模式,内框增量-0.3°,ASC码:Q0100.3$16进制数:51303230302E3324fwrite(s,'Q0200.3$','char');pause(3);%等待整数秒fclose(s);end%%%%%%%关闭串口fclose(s);%查找串口对象scoms=instrfind;%尝试停止、关闭删除串口对象stopasync(scoms);fclose(scoms);%关闭串口delete(scoms);%释放串口。