作者dczhang (我不想"擦肩而过")
看板C_and_CPP
标题[问题]已修改 询问C sign extension的方法
时间Thu Aug 27 17:47:17 2009
请问各位大大我有一个32bits资料
存在站存器 uint32 DATA 中
然後我要将DATA中的资料SHIFT右移16bit
所以我程式就打
result=(DATA)>>16;
但是我的result出来要如何让前面补的16bit有"sign extension的效果"
EX: 若DATA=1000 1000 1000 1000 1000 1000 1000 1000 (32bits)
^
sign bit
那我 >>16 SHIFT
我希望结果我要的是
result=1111 1111 1111 1111 1000 1000 1000 1000
___________________ ^
sign extension sign bit(shift後)
thx by dczhang
--
※ 发信站: 批踢踢实业坊(ptt.cc)
◆ From: 140.113.149.173
1F:推 VictorTom:要嘛改用signed, 要嘛判断最高bit为1就|前0xFFFF0000 ?? 08/27 18:01
2F:→ dczhang:抱歉请问要怎抓bit我突然想到,若我要抓DATA的第29个bits 08/27 18:06
3F:推 VictorTom:#define BITN(n) (0x1<<(n)) //随手写的没有测过.... 08/27 18:09
4F:→ akasan:(data >> 29) & 0x01 08/27 18:10
5F:→ VictorTom:话说, int sData = *(int*)&DATA, 然後拿sData>>也行吧. 08/27 18:11
6F:→ dczhang:请问我原来的DATA要>>16,如果又要多一个>>29会资源太大吗 08/27 18:15
7F:推 VictorTom:32 bit data >> 16 又 >> 29 还剩下些什麽?? 08/27 18:17
8F:→ VictorTom:顺便说, 这种原生型态的bit operation速度很快的.... 08/27 18:17
9F:→ dczhang:因为我是做FFT的一堆算术运算,>>16,>>29只是其中一段 08/27 18:29
10F:→ dczhang:而事实上我DATA是要>>12 ,再补弟29为sign bit 08/27 18:31
11F:推 suhorng:只要是 signed 那麽右移之後都会自动补上 sign extension 08/27 18:36
谢谢各物大大指教我改好了,给你们看一下这样是否可以
e = (((data[i+40]>>3)*coeff[20])&0x3ffff000); //e的资料为第29~12 bits共18bits
//以下作判断>>12是否要sign extension
if ((e & 20000000) == 0x20000000){ //CHECK 第29bit是否为1
tmp32R[i+40]= 0xFFFC0000|(e>>12);} //若有就做1的sign extension
else
tmp32R[i+40]= e>>12; //结果放在 tmp32R[i+40]
※ 编辑: dczhang 来自: 140.113.149.173 (08/27 18:53)
12F:推 varg:e & 0x20000000 08/27 20:38
13F:推 wowtiger:bit operation 一直都很快 除了 P4 的 shift XD 08/28 00:26
14F:→ wowtiger:((signed(e) << 2) >> 14) 这样如何 ? 08/28 00:43
15F:→ dczhang:我试试看楼上大大看看唷^^谢谢 08/28 12:56