if(save_d<2000) { c4_gas[0]=save_d; c4_gas[0]=c4_gas[0]/1000.0; } else { c4_gas[0]=0.6; M24CxxWriteWord(DEVP_ADDR,600); save_d=600; } save_d=M24CxxReadWord(C4ND_ADDR); if(save_d<=10000) { c4_gas[1]=save_d; c4_gas[1]=c4_gas[1]/100.0; } else { c4_gas[1]=10.0; M24CxxWriteWord(C4ND_ADDR,1000); save_d=1000; } save_d=M24CxxReadWord(O2ND_ADDR); if(save_d<5000) { c4_gas[2]=save_d; c4_gas[2]=c4_gas[2]/100.0; } else { c4_gas[2]=5.0; M24CxxWriteWord(O2ND_ADDR,500); save_d=500; } c4_gas[3]=100.0-c4_gas[1]-c4_gas[2]; if(c4_gas[3]<0.0) c4_gas[3]=0.0; lcd_datas[0]=c4_gas[0]*1000.0; lcd_datas[1]=c4_gas[1]*100.0; lcd_datas[2]=c4_gas[2]*100.0; lcd_datas[3]=c4_gas[3]*100.0; WritedataStr(DEVICE_P_ADDR,lcd_datas,4); }

时间: 2024-04-28 10:25:48 浏览: 9
这段代码主要是用来读取和写入一些参数,以及计算一些参数的值。具体来说,它首先从存储器中读取一些参数的值,如C4F7N的体积百分比、O2的分压力等。然后根据读取的值,计算出混合物中C4F7N、O2和CO2的体积百分比,并存储在c4_gas数组中。如果读取的值超出了一定范围,就会将其设置为一个默认值,并将该默认值写入存储器中。最后,将计算出的参数值转换为LCD显示的格式,并将其写入LCD的指定地址中。
相关问题

void main() { u8 key_temp=0; u8 save_value=0; u8 save_buf[3]; while(1) { key_temp=key_scan(1); //??????????? //?????? if(key_temp==KEY1_PRESS) { at24c02_write_one_byte(EEPROM_ADDRESS,save_value); } else if(key_temp==KEY2_PRESS) { save_value=at24c02_read_one_byte(EEPROM_ADDRESS); } else if(key_temp==KEY3_PRESS) { save_value++; if(save_value==255) { save_value=255; } } else if(key_temp==KEY4_PRESS) { save_value=0; } //?????? if(IND_KEY1==0) //??????????1 { save_value+=10; //?save_value??10 if(save_value>255) { save_value=255; } IND_KEY1=1; //??????1????? } else if(IND_KEY2==0) //??????????2 { save_value-=10; //?save_value??10 if(save_value<0) { save_value=0; } IND_KEY2=1; //??????2????? } else if(IND_KEY3==0) //??????????3 { save_value+=1; //?save_value??1 if(save_value==255) { save_value=255; } IND_KEY3=1; //??????3????? } else if(IND_KEY4==0) //??????????4 { save_value-=1; //?save_value??1 if(save_value<0) { save_value=0; } IND_KEY4=1; //??????4????? } //?????????? if(IND_KEY1==1 && IND_KEY2==1 && IND_KEY3==1 && IND_KEY4==1) { IND_KEY1=0; IND_KEY2=0; IND_KEY3=0; IND_KEY4=0; } //?save_value??????????? save_buf[0]=save_value/100; save_buf[1]=save_value%100/10; save_buf[2]=save_value%100%10; //???????save_value smg_display(save_buf,6); } }用独立按键K1,K2,K3分别控制三位数码管如何修改

可以将原来的IND_KEY1、IND_KEY2、IND_KEY3等变量改为k1_pressed、k2_pressed、k3_pressed等更具有意义的变量名。同时,可以在每次按键操作结束后,将对应的按键状态清零,避免影响下一次按键操作。 修改后的代码如下: ```c void main() { u8 key_temp=0; u8 save_value=0; u8 save_buf[3]; u8 k1_pressed=0, k2_pressed=0, k3_pressed=0; while(1) { key_temp=key_scan(1); //获取按键值 //按下K1,将当前值写入EEPROM中 if(key_temp==KEY1_PRESS) { at24c02_write_one_byte(EEPROM_ADDRESS,save_value); } //按下K2,从EEPROM中读取上次保存的值并显示 else if(key_temp==KEY2_PRESS) { save_value=at24c02_read_one_byte(EEPROM_ADDRESS); save_buf[0]=save_value/100; save_buf[1]=save_value%100/10; save_buf[2]=save_value%100%10; smg_display(save_buf,6); } //按下K3,将当前值加1并显示 else if(key_temp==KEY3_PRESS) { save_value++; if(save_value==255) { save_value=255; } save_buf[0]=save_value/100; save_buf[1]=save_value%100/10; save_buf[2]=save_value%100%10; smg_display(save_buf,6); } //按下K4,将当前值清零并显示 else if(key_temp==KEY4_PRESS) { save_value=0; save_buf[0]=0; save_buf[1]=0; save_buf[2]=0; smg_display(save_buf,6); } //K1按下,将当前值加10并显示 if(k1_pressed == 1) { save_value+=10; if(save_value>255) { save_value=255; } save_buf[0]=save_value/100; save_buf[1]=save_value%100/10; save_buf[2]=save_value%100%10; smg_display(save_buf,6); k1_pressed = 0; } //K2按下,将当前值减10并显示 else if(k2_pressed == 1) { save_value-=10; if(save_value<0) { save_value=0; } save_buf[0]=save_value/100; save_buf[1]=save_value%100/10; save_buf[2]=save_value%100%10; smg_display(save_buf,6); k2_pressed = 0; } //K3按下,将当前值加1并显示 else if(k3_pressed == 1) { save_value+=1; if(save_value==255) { save_value=255; } save_buf[0]=save_value/100; save_buf[1]=save_value%100/10; save_buf[2]=save_value%100%10; smg_display(save_buf,6); k3_pressed = 0; } //判断按键是否释放,释放后才能继续检测按键 if(k1_pressed==0 && IND_KEY1==0) { k1_pressed = 1; } else if(k2_pressed==0 && IND_KEY2==0) { k2_pressed = 1; } else if(k3_pressed==0 && IND_KEY3==0) { k3_pressed = 1; } //释放所有按键 if(IND_KEY1==1 && IND_KEY2==1 && IND_KEY3==1 && IND_KEY4==1) { IND_KEY1=0; IND_KEY2=0; IND_KEY3=0; IND_KEY4=0; } } } ```

write.csv(data, file = save_path)

这是一个R语言中的函数,用于将数据写入CSV文件中。其中,data是要写入的数据集,file是要保存的文件路径,save_path是你自己定义的文件保存路径。具体使用方法如下: 1. 首先,需要将数据读入到R环境中,可以使用read.csv()函数。 2. 然后,使用write.csv()函数将数据写入CSV文件中,其中第一个参数为要写入的数据集,第二个参数为文件路径。 例如: ``` data <- read.csv("data.csv") # 读入数据 save_path <- "result.csv" # 定义文件保存路径 write.csv(data, file = save_path) # 写入CSV文件 ``` 执行完上述代码后,数据将被写入到result.csv文件中。

相关推荐

def refresh_labels(self): data4 = self.la # 连接到 SQLite 数据库文件,并创建游标对象 cursor() conn = sqlite3.connect(filepath) cursor = conn.cursor() data41 = str(self.la) if not data4.endswith('.xlsx'): data4 += '.xlsx' wo = pinjie filepath = os.path.join(wo, data4) if not os.path.exists(filepath): wb = openpyxl.Workbook() wb.save(filepath) else: wb = openpyxl.load_workbook(filepath) for i, sheet_name in enumerate(self.sheet_names): label = tk.Label(self.unique_listbox, text=sheet_name) label.grid(row=i // 3, column=i % 3, sticky="ew", padx=1, pady=1) current_time = datetime.datetime.now().time() start_time_1 = datetime.time(8, 0, 0) # 早上8点 end_time_1 = datetime.time(20, 0, 0) # 下午7点 start_time_2 = datetime.time(20, 0, 0) # 晚上8点 end_time_2 = datetime.time(7, 0, 0) # 早上7点 for i, sheet_name in enumerate(self.sheet_names): filtered_rows = [] # 优化第二段代码:检查文件是否存在 filepath = os.path.join(pinjie, self.la + '.xlsx') if os.path.exists(filepath): workbook = xl.load_workbook(filepath) sheet = workbook.active today = datetime.datetime.now().strftime('%Y/%m/%d') cell_value = sheet.cell(row=1, column=1).value if cell_value is not None and cell_value != '': for row in sheet.iter_rows(min_row=1): if row[2].value == today and row[8].value == sheet_name: datetime_obj = datetime.datetime.strptime(row[3].value, '%H:%M:%S') row_time = datetime_obj.time() if start_time_1 <= row_time <= end_time_1 and start_time_1 <= current_time <= end_time_1: filtered_rows.append(row) elif start_time_2 <= row_time or current_time <= end_time_2: filtered_rows.append(row) label = self.unique_listbox.grid_slaves(row=i // 3, column=i % 3)[0] if filtered_rows: label.config(text=f"{sheet_name} - 已點檢", fg="green") else: label.config(text=f"{sheet_name} - 未點檢", fg="red")將這段代碼重拼接的excel修改為sqlite3,然後將在這個excel所作的操作,修改為到sqlite3中,其他判斷條件不變,和顯示需求不變

最新推荐

recommend-type

浅谈keras保存模型中的save()和save_weights()区别

本文将深入探讨Keras中`save()`和`save_weights()`两个函数之间的差异,并通过一个使用MNIST数据集的简单示例来说明它们的不同效果。 首先,`save()`函数用于保存整个模型,包括模型的结构、优化器的状态、损失函数...
recommend-type

keras的load_model实现加载含有参数的自定义模型

model.save('my_model.h5') # 加载模型,提供custom_objects参数 loaded_model = load_model('my_model.h5', custom_objects={'SelfAttention': SelfAttention}) ``` 然而,这里有一个关键点需要注意。如果在加载...
recommend-type

pytorch 状态字典:state_dict使用详解

除了保存和加载模型的参数,你还可以直接保存整个模型对象,使用`torch.save(model, PATH)`,然后通过`torch.load(PATH)`恢复。但是,这种方法会包含模型的整个计算图,可能占用更多空间。加载时同样需要调用`model....
recommend-type

Keras load_model 导入错误的解决方式

if os.path.exists(string): # 加载模型 model = load_model(string) else: print(f'Sorry, I cannot find the "{string}" file.') ``` 确保在加载模型前使用`os.path.exists()`检查文件是否存在,这样可以...
recommend-type

OpenCV stitching_detailed.cpp解读

- `--save_graph`:保存匹配图的文件名。 - `--warp`:选择融合的几何模型,默认为球形。 - `--seam_megapix`:拼接缝的像素大小。 - `--seam`:选择拼接缝隙的估计方法。 - `--compose_megapix`:设定拼接图像的...
recommend-type

基于嵌入式ARMLinux的播放器的设计与实现 word格式.doc

本文主要探讨了基于嵌入式ARM-Linux的播放器的设计与实现。在当前PC时代,随着嵌入式技术的快速发展,对高效、便携的多媒体设备的需求日益增长。作者首先深入剖析了ARM体系结构,特别是针对ARM9微处理器的特性,探讨了如何构建适用于嵌入式系统的嵌入式Linux操作系统。这个过程包括设置交叉编译环境,优化引导装载程序,成功移植了嵌入式Linux内核,并创建了适合S3C2410开发板的根文件系统。 在考虑到嵌入式系统硬件资源有限的特点,通常的PC机图形用户界面(GUI)无法直接应用。因此,作者选择了轻量级的Minigui作为研究对象,对其实体架构进行了研究,并将其移植到S3C2410开发板上,实现了嵌入式图形用户界面,使得系统具有简洁而易用的操作界面,提升了用户体验。 文章的核心部分是将通用媒体播放器Mplayer移植到S3C2410开发板上。针对嵌入式环境中的音频输出问题,作者针对性地解决了Mplayer播放音频时可能出现的不稳定性,实现了音乐和视频的无缝播放,打造了一个完整的嵌入式多媒体播放解决方案。 论文最后部分对整个项目进行了总结,强调了在嵌入式ARM-Linux平台上设计播放器所取得的成果,同时也指出了一些待改进和完善的方面,如系统性能优化、兼容性提升以及可能的扩展功能等。关键词包括嵌入式ARM-Linux、S3C2410芯片、Mplayer多媒体播放器、图形用户界面(GUI)以及Minigui等,这些都反映出本文研究的重点和领域。 通过这篇论文,读者不仅能了解到嵌入式系统与Linux平台结合的具体实践,还能学到如何在资源受限的环境中设计和优化多媒体播放器,为嵌入式技术在多媒体应用领域的进一步发展提供了有价值的经验和参考。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

Python字符串为空判断的动手实践:通过示例掌握技巧

![Python字符串为空判断的动手实践:通过示例掌握技巧](https://img-blog.csdnimg.cn/72f88d4fc1164d6c8b9c29d8ab5ed75c.png?x-oss-process=image/watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBASGFyYm9yIExhdQ==,size_20,color_FFFFFF,t_70,g_se,x_16) # 1. Python字符串为空判断的基础理论 字符串为空判断是Python编程中一项基本且重要的任务。它涉及检查字符串是否为空(不包含任何字符),这在
recommend-type

box-sizing: border-box;作用是?

`box-sizing: border-box;` 是 CSS 中的一个样式属性,它改变了元素的盒模型行为。默认情况下,浏览器会计算元素内容区域(content)、内边距(padding)和边框(border)的总尺寸,也就是所谓的"标准盒模型"。而当设置为 `box-sizing: border-box;` 后,元素的总宽度和高度会包括内容、内边距和边框的总空间,这样就使得开发者更容易控制元素的实际布局大小。 具体来说,这意味着: 1. 内容区域的宽度和高度不会因为添加内边距或边框而自动扩展。 2. 边框和内边距会从元素的总尺寸中减去,而不是从内容区域开始计算。
recommend-type

经典:大学答辩通过_基于ARM微处理器的嵌入式指纹识别系统设计.pdf

本文主要探讨的是"经典:大学答辩通过_基于ARM微处理器的嵌入式指纹识别系统设计.pdf",该研究专注于嵌入式指纹识别技术在实际应用中的设计和实现。嵌入式指纹识别系统因其独特的优势——无需外部设备支持,便能独立完成指纹识别任务,正逐渐成为现代安全领域的重要组成部分。 在技术背景部分,文章指出指纹的独特性(图案、断点和交叉点的独一无二性)使其在生物特征认证中具有很高的可靠性。指纹识别技术发展迅速,不仅应用于小型设备如手机或门禁系统,也扩展到大型数据库系统,如连接个人电脑的桌面应用。然而,桌面应用受限于必须连接到计算机的条件,嵌入式系统的出现则提供了更为灵活和便捷的解决方案。 为了实现嵌入式指纹识别,研究者首先构建了一个专门的开发平台。硬件方面,详细讨论了电源电路、复位电路以及JTAG调试接口电路的设计和实现,这些都是确保系统稳定运行的基础。在软件层面,重点研究了如何在ARM芯片上移植嵌入式操作系统uC/OS-II,这是一种实时操作系统,能够有效地处理指纹识别系统的实时任务。此外,还涉及到了嵌入式TCP/IP协议栈的开发,这是实现系统间通信的关键,使得系统能够将采集的指纹数据传输到远程服务器进行比对。 关键词包括:指纹识别、嵌入式系统、实时操作系统uC/OS-II、TCP/IP协议栈。这些关键词表明了论文的核心内容和研究焦点,即围绕着如何在嵌入式环境中高效、准确地实现指纹识别功能,以及与外部网络的无缝连接。 这篇论文不仅深入解析了嵌入式指纹识别系统的硬件架构和软件策略,而且还展示了如何通过结合嵌入式技术和先进操作系统来提升系统的性能和安全性,为未来嵌入式指纹识别技术的实际应用提供了有价值的研究成果。