找回密码
 注册
关于网站域名变更的通知
查看: 358|回复: 1
打印 上一主题 下一主题

导出CCS3.3数据及使用matlab处理的方法

[复制链接]

该用户从未签到

跳转到指定楼层
1#
发表于 2020-3-10 10:27 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

EDA365欢迎您登录!

您需要 登录 才可以下载或查看,没有帐号?注册

x
. c. L7 q9 H. n. j" L
CCS3.3是一款DSP的集成开发环境(IDE)。在做DSP开发时,为验证算法,常常需要使用matlab进行算法验证,验证算法就需要数据。因此,一种交互的方法是:
* F3 L- N1 d7 O& C) ~- z
- h$ e% l# y5 ]- F. ]
  • 使用DSP开发板连接CCS
  • 用CCS3.3菜单中的“File->Data->Save..”功能导出DSP内存中的数据到PC的.dat文件中
  • 使用Matlab读取.dat文件,进行数据处理
    2 ^6 `& x: V! _9 U$ e1 T& D

' u& d- v6 a  h; ~7 \
  c/ |, q/ R  B- J9 Z2 h' f下面给出使用Matlab读取CCS导出的dat文件的方法:
8 a( G! `4 @9 m% O) t( i7 G# J  L7 ?3 i' ?/ a
  • % =========================================================================
  • % Read *dat file of CCS3.3
  • % xiahouzuoxin
  • % 2014.04.21
  • % =========================================================================
  • % clc;clear all;close all;
  • % 对话框选择*.dat文件
  • [fname,pname]=uigetfile(...
  •     {'*.dat';'*.*'},'Input *.dat File');
  • fid = fopen(fullfile(pname,fname));
  • fseek(fid, 21,-1);  % 去文件头, 21字节,如 1651 1 80000006 0 100
  • % 按指定格式读取解析
  • fm = 4;
  • switch (fm)
  •     case 4  % 按4Byte格式读,如 0x 80000000
  •         x = textscan(fid, '%2s %8s');
  •         z(:,1) = hex2dec(x{2});
  •     case 2 % 按2Byte格式读,如 0x 8000 0000
  •         x = textscan(fid, '%2s %4s %4s');
  •         z(:,1) = hex2dec(x{3});
  •         z(:,2) = hex2dec(x{2});
  •     case 1 % 按1Byte格式读,如 0x 80 00 00 00
  •         x = textscan(fid, '%2s %2s %2s %2s %2s');
  •         z(:,1) = hex2dec(x{5});
  •         z(:,2) = hex2dec(x{4});
  •         z(:,3) = hex2dec(x{3});
  •         z(:,4) = hex2dec(x{2});
  •     otherwise
  •         z = [];
  • end
  • if ~isempty(z)
  •     % 将数据处理代码放在这里
  • end
  • fclose(fid);
    , G) H9 h2 h% H. R) ]8 ]
       . `# ?" A3 x) z% _3 u) L8 e( {7 w" e
* r: _$ O. m! Q0 ^5 O
程序中默认DSP内存中数据的存储格式为整数类型,而对于浮点型DSP如TMS320C6713B,常常在内存中是float或double格式存储的,
) o& s" [* @- }7 h; d) d! J8 p: R! `" ]) h  F* a+ i( o$ u+ V
这时,我们还需要一个转化为浮点数的操作,因此我写了一个转化为float类型的函数,4 V) C; [0 L! e/ \+ M
$ C; x$ v6 S4 y% B* V9 T
  • function y = integer2float(x, ishex)
  • % =========================================================================
  • % 有些数据y原本是float类型,在内存中是按float格式存储
  • % 而现在按整数将其从内存中读出变成了x
  • % 这个函数就是用于将按整数格式读出的x转变成y
  • % ishex~=0表示输入为十六进制格式
  • % 注:要完成该函数,你必须了解IEEE浮点数的格式
  • %
  • % xiahouzuoxin
  • % 2014.04.21
  • % =========================================================================
  • if nargin == 2
  •     if (ishex)
  •         x = hex2dec(x);
  •     end
  • end
  • [h w] = size(x);
  • y = zeros(h,w);
  • for i = 1:h
  •     for j = 1:w
  •         sign = bitget(x(i,j),32);
  •         exponent = bitget(x(i,j),24:31) * 2.^(0:7).';
  •         fraction = bitget(x(i,j),1:23) * 2.^(-23:-1).';
  •         y(i,j) = (-1)^sign * (1+fraction) * 2^(exponent-127);
  •     end
  • end4 o! l4 l  R8 P. n# j
  6 f3 }# O% n8 P  L% |. W
) X# {% E+ `! Z; _- y7 A+ R
根据不同的输入情况(可以为十六进制的字符串表示或十进制数,但必须≤8Bytes),使用方法举个例子:
! w) i* h4 M9 e# Q& B4 O; h- e7 T2 m
  • >> x='4565A012'
  • >> y=integer2float(x,1);
  • >> x = 23974881923;
  • >> y = integer2float(x)
    $ F, B* `; N" _. x& Y7 o
9 c& `8 N" q3 }4 ]7 V6 F

$ j# e! k6 V% |9 |' p* C后来发现,Matlab已经早有对应的方法了,  J/ a0 Q! m( J) m$ N  `

% o: @! o& E2 D2 F: S' ~
  • y = typecast(uint32(z),'single');
      I2 |0 a/ l/ w1 t0 A8 i

& t& C. o% I0 Y- Z+ X2 _4 t; Q# z可以直接把z转化为解析为单精度浮点数,具体使用请参见
3 ]4 p4 y2 }3 s, W& ?1 x
- `9 O+ n6 l' p" `- K' a$ ~, V  v3 `/ |% Y
  • >> help typecast
    & j# i, |  f4 K: o2 D. U- R

& F/ J# K3 f4 V. v* T2 B3 _4 Y) Y# i6 |
  • TA的每日心情

    2019-11-29 15:37
  • 签到天数: 1 天

    [LV.1]初来乍到

    2#
    发表于 2020-3-10 16:48 | 只看该作者
    导出CCS3.3数据及使用matlab处理的方法
    您需要登录后才可以回帖 登录 | 注册

    本版积分规则

    关闭

    推荐内容上一条 /1 下一条

    EDA365公众号

    关于我们|手机版|EDA365电子论坛网 ( 粤ICP备18020198号-1 )

    GMT+8, 2025-11-24 00:02 , Processed in 0.171875 second(s), 23 queries , Gzip On.

    深圳市墨知创新科技有限公司

    地址:深圳市南山区科技生态园2栋A座805 电话:19926409050

    快速回复 返回顶部 返回列表