单片机上的开方程序

因为工作的需要,要在 单片机上实现开根号的操作。目前开平方的方法大部分是用牛顿迭代法。我在查了一些资料以后找到了一个比牛顿迭代法更加快速的方法。不敢独享,介绍给大家,希望会有些帮助。

1.原理
因为排版的原因,用pow(X,Y)表示X的Y次幂,用B[0],B[1],...,B[m-1]表示一个序列,
其中[x]为下标。

假设:
B[x],b[x]都是二进制序列,取值0或1。
M = B[m-1]*pow(2,m-1) + B[m-2]*pow(2,m-2) + ... + B[1]*pow(2,1) + B[0]*pow
(2,0)
N = b[n-1]*pow(2,n-1) + b[n-2]*pow(2,n-2) + ... + b[1]*pow(2,1) + n[0]*pow
(2,0)
pow(N,2) = M

(1) N的最高位b[n-1]可以根据M的最高位B[m-1]直接求得。
设 m 已知,因为 pow(2, m-1) <= M <= pow(2, m),所以 pow(2, (m-1)/2) <= N <=
pow(2, m/2)
如果 m 是奇数,设m=2*k+1,
那么 pow(2,k) <= N < pow(2, 1/2+k) < pow(2, k+1),
n-1=k, n=k+1=(m+1)/2
如果 m 是偶数,设m=2k,
那么 pow(2,k) > N >
  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: DHT11温湿度传感器可以通过52单片机进行读取和处理。下面是一个简单的程序代码示例: #include <dht11.h> // 引入dth11库 #define dthPin 2 // 将传感器的信号线连接到52单片机的GPIO引脚2 void setup() { Serial.begin(9600); // 开启串口通信 } void loop() { int chk; float humidity, temperature; // 定义变量以存储湿度和温度值 DHT11 dht(dthPin); // 创建dth11对象,并将传感器信号接收引脚传入 chk = dht.read(); // 读取传感器数据 humidity = dht.humidity; // 将湿度值保存到humidity变量中 temperature = dht.temperature; // 将温度值保存到temperature变量中 Serial.print("湿度:"); Serial.println(humidity); // 打印湿度值到串口 Serial.print("温度:"); Serial.println(temperature); // 打印温度值到串口 delay(2000); // 延时2秒 } 以上代码首先引入了dht11库文件,并定义了传感器信号线对应的引脚为GPIO引脚2。在setup函数中,打开了串口通信,并在loop函数中实现循环读取和处理传感器数据的功能。 程序首先创建了一个dth11对象,并将传感器信号接收引脚传入。然后使用dht.read()函数读取传感器数据,将湿度值和温度值保存到对应的变量中。接着使用Serial.print()和Serial.println()函数将湿度值和温度值打印到串口上。最后使用delay(2000)函数延时2秒,以便下次读取数据前让传感器有足够的时间进行采样。 通过这段简单的程序代码,我们可以在52单片机上读取并打印DHT11温湿度传感器的数据。当然,具体的程序代码还可以根据需求进行更加复杂的处理和优化。 ### 回答2: DTH11温湿度传感器可以通过52单片机进行读取和处理温湿度数据。下面是一个示例程序代码,以帮助你理解如何实现这个功能: 首先,你需要定义一些常数和引脚连接: ```c #define DTH11_PIN 2 // DTH11传感器的数据引脚连接到单片机的2号引脚 ``` 然后,你可以定义一些变量来存储读取到的温湿度数据: ```c int temperature = 0; // 存储温度数据 int humidity = 0; // 存储湿度数据 ``` 在`setup()`函数中,你需要初始化串行通信和DTH11传感器: ```c void setup() { Serial.begin(9600); // 初始化串行通信,波特率设置为9600 pinMode(DTH11_PIN, OUTPUT); // 将DTH11_PIN设置为输出模式 digitalWrite(DTH11_PIN, LOW); // 将引脚拉低 delay(1000); // 延时1秒 } ``` 在`loop()`函数中,你需要读取和处理DTH11传感器的数据: ```c void loop() { digitalWrite(DTH11_PIN, HIGH); // 将引脚拉高 delayMicroseconds(40); // 延时40微秒 pinMode(DTH11_PIN, INPUT_PULLUP); // 将DTH11_PIN设置为输入模式,开启上拉电阻 delayMicroseconds(10); // 延时10微秒 if (digitalRead(DTH11_PIN) == LOW) { delayMicroseconds(80); // 延时80微秒 if (digitalRead(DTH11_PIN) == HIGH) { delayMicroseconds(50); // 延时50微秒 humidity = pulseIn(DTH11_PIN, HIGH); // 读取湿度数据脉冲宽度 delayMicroseconds(25); // 延时25微秒 temperature = pulseIn(DTH11_PIN, HIGH); // 读取温度数据脉冲宽度 Serial.print("Temperature: "); Serial.print(temperature); Serial.print(" Humidity: "); Serial.println(humidity); } } delay(2000); // 每2秒读取一次温湿度数据 } ``` 这样,你就可以通过52单片机读取和处理DTH11温湿度传感器的数据了。以上是一个简单的示例程序,你可以根据自己的需求进行修改和优化。 ### 回答3: DTH11温湿度传感器是一种常用的数字式温湿度传感器,可以用于测量环境的温度和湿度。以下是在52单片机上的DTH11温湿度传感器的程序代码。 首先,我们需要在代码中定义引脚和变量: #include <reg52.h> sbit DHT11 = P1^0; // 定义DTH11传感器的引脚 unsigned char humidity_data[5]; // 存储湿度数据 unsigned char temperature_data[5]; // 存储温度数据 然后,我们需要编写初始化函数,用于初始化DTH11传感器: void init_dht11() { DHT11 = 1; // 设置引脚为输出 Delay_18us(); // 延时18微秒 DHT11 = 0; // 发送开始信号 Delay_ms(20); // 延时20毫秒 DHT11 = 1; // 设置引脚为输入 } 接下来,我们需要编写读取温湿度数据的函数: bit read_dht11(unsigned char *humidity, unsigned char *temperature) { unsigned char i, j; bit error = 0; for (j = 0; j < 5; j++) { for (i = 0; i < 8; i++) { while (!DHT11); // 等待低电平结束 Delay_30us(); // 延时30微秒 if (DHT11) // 高电平持续时间较长,表示数据为1 { humidity_data[j] |= 0x80 >> i; // 将数据存入湿度数组 } while (DHT11); // 等待高电平结束 } } for (j = 0; j < 5; j++) { for (i = 0; i < 8; i++) { while (!DHT11); // 等待低电平结束 Delay_30us(); // 延时30微秒 if (DHT11) // 高电平持续时间较长,表示数据为1 { temperature_data[j] |= 0x80 >> i; // 将数据存入温度数组 } while (DHT11); // 等待高电平结束 } } // 验证校验和 unsigned char checksum = humidity_data[0] + humidity_data[1] + humidity_data[2] + humidity_data[3]; if (checksum != humidity_data[4]) { error = 1; // 校验和错误 } *humidity = humidity_data[0]; // 将湿度数据传回 *temperature = temperature_data[2]; // 将温度数据传回 return error; } 最后,在主函数中调用上述函数进行读取和显示温湿度数据: void main() { unsigned char humidity, temperature; init_dht11(); // 初始化DTH11传感器 while (1) { bit error = read_dht11(&humidity, &temperature); if (!error) // 如果没有错误,显示温湿度数据 { // 在此处添加显示温湿度数据的代码 } Delay_ms(1000); // 延时1秒 } } 以上就是在52单片机上使用DTH11温湿度传感器的程序代码。请注意,此代码仅供参考,具体使用时请根据实际情况进行调整和优化。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值