C/C++取数据中高8位,低8位,合成新数据

有时,需将某一串数字中感兴趣的某些位的数据进行提取,并将提取的数据合并成新数据,可用位运算来实现。
1.取低几位的数:可用&运算符,通过取低几位的二进制置为1来实现。(低8位:0xff)

2.取高几位的数:先通过右移将高几位数据移到低位,再通过&运算来实现。

3.将取得的位数进行合并:先通过左移恢复取得的高几位数据的权值,再和取得低几位数据进行|运算来合成新数据。

注:左移和右移是针对补码来说。

直接上程序,位运算的理论知识见:https://blog.csdn.net/hanxiaoyong_/article/details/88775094

#include <stdio.h>
#include <stdlib.h>
unsigned char n_right,n_left,temp; //right表示低8位,left表示高8位
int size_right,size_left,size_temp;
short int num,size_num;
short int num_two,num_three; //int 4字节,short int 2字节
 int main()
 {  
    /*  本文 2 字节 
    *   存放取值的数必须是无符号数类型,否则,取得16为的低8位:1111 1111,
    *   会把取得的8位中的高位1作为符号为1(负数),取真值的会按
    *   为取反,加1,为-1;
    */
    num = 32767;  //16进制 0111 1111 1111 1111
    size_num = sizeof(num);
    size_right = sizeof(n_right);
    size_left = sizeof(n_left);
    size_temp = sizeof(temp);
//    printf("size_num = %d 个字节\n",size_num);
//  printf("size_right = %d 个字节\n",size_right);
    printf("原数num= %d\n",num);
    n_right = num &0xFF; //取低8位 n_right =  2 ^8 -1 = 255  
    printf("n_right = %d \n",n_right);
    n_left = (num  >> 8) & 0xff; //取高8位 n_right =  2 ^7 -1 = 127  
    printf("n_left = %d \n",n_left);

    unsigned char n_r4;
    n_r4 = num & 0x0f; // 0111 1111 1111 1111  取低4位 n_r4  1111 = 2^4 -1 = 15          
    printf("n_r4 = %d \n",n_r4);

    unsigned char n_l4; //取高4位
    n_l4 =   (( num >>= 8) >> 4 ) & 0x0F; //0111 1111 1111 1111 取高4位 n_l4  0111 = 2 ^3 -1 = 7           
    printf("n_l4 = %d \n",n_l4); 
    


    //把高8位与低8位结合
    num_three = n_left;
    num_three <<= 8; //恢复高位
    num_three |= n_right; //或上低位
    printf("num_three = %d ",num_three);  //结果32767
    return 0;
}

 

  • 15
    点赞
  • 76
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
数据平滑插值是将不连续的数据合成连续的曲线,一般使用三次样条插值方法实现。具体步骤如下: 1. 将原始数据按照从小到大的顺序排序。 2. 计算每个数据点的一阶导数和二阶导数。 3. 构造三次样条函数,将每个数据点和其一阶导数、二阶导数作为插值条件。 4. 根据插值函数,计算插值点的程值。 以下是一个示例代码: ```c #include <stdio.h> #include <stdlib.h> #include <math.h> #define N 10 // 数据点个数 double x[N] = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10}; // 数据点横坐标 double y[N] = {2.5, 3.7, 4.2, 4.8, 5.1, 5.3, 5.6, 6.1, 6.5, 7.0}; // 数据点纵坐标 double h[N-1]; // 每个数据点之间的间距 double d[N]; // 一阶导数 double b[N], c[N], f[N]; // 三次样条插值函数参数 void spline() { int i; for (i = 0; i < N-1; i++) { h[i] = x[i+1] - x[i]; d[i+1] = (y[i+1] - y[i]) / h[i]; } c[0] = 0, c[N-1] = 0; int j; double l[N], u[N], z[N]; l[0] = 1, u[0] = 0, z[0] = 0; for (j = 1; j < N-1; j++) { l[j] = 2 * (x[j+1] - x[j-1]) - h[j-1] * u[j-1]; u[j] = h[j] / l[j]; z[j] = (d[j+1] - d[j-1] - h[j-1] * z[j-1]) / l[j]; } l[N-1] = 1, z[N-1] = 0; for (j = N-2; j >= 0; j--) { c[j] = z[j] - u[j] * c[j+1]; b[j] = (y[j+1] - y[j]) / h[j] - h[j] * (c[j+1] + 2 * c[j]) / 3; f[j] = (c[j+1] - c[j]) / (3 * h[j]); } } double interpolate(double xi) { int i; for (i = 0; i < N-1; i++) { if (xi >= x[i] && xi <= x[i+1]) { double dx = xi - x[i]; return y[i] + dx * b[i] + dx * dx * c[i] + dx * dx * dx * f[i]; } } return NAN; } int main() { spline(); int i; for (i = 0; i < 20; i++) { double xi = x[0] + i * (x[N-1] - x[0]) / 19; printf("x=%.2f, y=%.2f\n", xi, interpolate(xi)); } return 0; } ``` 在这个示例代码中,我们假设有10个数据点,使用三次样条插值方法实现数据平滑插值。其中,spline函数计算三次样条插值函数的参数,interpolate函数根据插值函数计算插值点的程值。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值