MATLAB的位运算操作
2015-11-15 22:43
363 查看
在MATLAB中想要直接对类似于c、c++中的位运算操作,即或‘|’、与‘&’、非‘~’操作,如果直接写成
在matlab中会把0xff认为是未定义的变量名而完成不了任务,因而想要在matlab中进行位操作,需要函数来操作。
在matlab中有如下的几个位运算函数:
这里举一个例子。
如函数:bitand 顾名思义bit and 按位与,他的操作如下:
0xABCD ====== 43981
0xFFF ====== 4095
那么: 0xABCD & 0xFFF = 0xBCD ===== 3021
在matlab中的操作就是把他们的十进制数放入bitand函数中即可:
也就是说,在matlab中进行位操作的时候,只需要把你要操作的十六进制对应的十进制数放入函数中即可。
这类函数适用于某些模块返回十六进制的数据时,只有某几位是有效位,那么这个时候就要进行位操作,提取有效的数据。不用担心第一个参数的问题,你把数据读入matlab的时候就已经转化为十进制的数了。所以你只需要考虑的是你要取得是那几位,然后把相应的十进制数带入函数的第二个参数即可。
Result = anynum & 0xff; %错误示范
在matlab中会把0xff认为是未定义的变量名而完成不了任务,因而想要在matlab中进行位操作,需要函数来操作。
在matlab中有如下的几个位运算函数:
这里举一个例子。
如函数:bitand 顾名思义bit and 按位与,他的操作如下:
0xABCD ====== 43981
0xFFF ====== 4095
那么: 0xABCD & 0xFFF = 0xBCD ===== 3021
在matlab中的操作就是把他们的十进制数放入bitand函数中即可:
Result = bitand(43981,4095); %结果是: %Result = 3021;
也就是说,在matlab中进行位操作的时候,只需要把你要操作的十六进制对应的十进制数放入函数中即可。
这类函数适用于某些模块返回十六进制的数据时,只有某几位是有效位,那么这个时候就要进行位操作,提取有效的数据。不用担心第一个参数的问题,你把数据读入matlab的时候就已经转化为十进制的数了。所以你只需要考虑的是你要取得是那几位,然后把相应的十进制数带入函数的第二个参数即可。
相关文章推荐
- php通过JavaBridge调用matlab
- matlab导出jar包
- matlab差分算法
- MATLAB实现cost function计算和gradience descent计算
- 机器学习中熟悉MATLAB——区分^/*与.* /^
- VC和MATLAB混合开发经验总结
- MATLAB 牛顿插值法程序
- 光照亮度调整(图像拼接之前)
- Matlab学习历程
- MATLAB中无法读取图像或无法打开文件等类似问题
- matlab和C如何混编
- matlab安装后不能使用,问题提示如下:runtime error!
- Matlab学习历程
- 来来来,有讲一个吐血的故事(matlab)之脚本运行路径是什么
- Matlab功能妙用——鼠标标记
- matlab获取目录中图像名称及路径的递归实现
- 在Matlab中使用mex函数进行C/C++混合编程
- Matlab C混合编程
- DPM(voc-release5) Matlab模型文件 Mat转XML
- MATLAB学习