基于温湿度传感器物联网应用实时 数据处理系统开发个人版 4.docx
《基于温湿度传感器物联网应用实时 数据处理系统开发个人版 4.docx》由会员分享,可在线阅读,更多相关《基于温湿度传感器物联网应用实时 数据处理系统开发个人版 4.docx(15页珍藏版)》请在冰豆网上搜索。
基于温湿度传感器物联网应用实时数据处理系统开发个人版4
《无线传感器网络实用教程》课程设计
基于温湿度传感器物联网应用实时
数据处理系统开发_
系别计算机科学系
专业通信工程
班级一
学号XXXXXXXXX
组次X
姓名XXXXXX
指导教师XXXX
评定成绩
起止日期2012年10月8日至2012年10月29日
目录
摘要3
第1章课程设计的目的和要求3
第2章温湿度传感器的简介4
第3章课程设计实现方案6
1、开发环境6
2、开发内容6
3、技术路线7
1)数据服务中心TCP服务器接收实时数据7
2)实时数据显示11
第4章课程设计结果14
第5章结论与体会15
摘要
物联网是新一代信息技术的重要组成部分。
其英文名称是“TheInternetofthings”。
由此,顾名思义,“物联网就是物物相连的互联网”。
这有两层意思:
第一,物联网的核心和基础仍然是互联网,是在互联网基础上的延伸和扩展的网络;第二,其用户端延伸和扩展到了任何物品与物品之间,进行信息交换和通信。
因此,物联网的定义是通过射频识别(RFID)、红外感应器、全球定位系统、激光扫描器等信息传感设备,按约定的协议,把任何物品与互联网相连接,进行信息交换和通信,以实现对物品的智能化识别、定位、跟踪、监控和管理的一种网络。
而温湿度传感器是由于温度与湿度不管是从物理量本身还是在实际人们的生活中都有着密切的关系,所以温湿度一体的传感器就会相应产生。
温湿度传感器是指能将温度量和湿度量转换成容易被测量处理的电信号的设备或装置。
市场上的温湿度传感器一般是测量温度量和相对湿度量。
第1章课程设计的目的与要求
课程设计目的
物联网是一种新概念和新技术,它使新一代IT技术更加充分地应用于各行各业之中。
它的问世打破了过去将基础设施与IT设施分开的传统观念,将建筑物、公路、铁路和网站、网络、数据中心合为一体,是信息化和工业化融合的重要切入点。
温湿度与人们的生活关系密切,所以物联网在温湿度实时数据处理系统的开发将有很大的前景。
在我们的日常生活中无处不在,控制好温湿度可以使我们生活、生产的更好。
温湿度传感器物联网应用实时数据处理系统开发可以帮我们实现对温湿度以实时数据让我们明了的知道。
从而更好的控制温湿度、达到我们所需的标准。
要达到的目的:
1.可以在ubuntu上实现自动接收由传感器取得、传来的实时数据。
2.并ubuntu上能边接收边连续往linux发送从传感器取得的实时数据。
3.还要确保发送过的数据不会再次发送。
4.Linux能接收到ubuntu发过来的实时数据并通过动态网页曲线图实时显示接收过来的数据。
课程设计要求
1.通过ubuntu连接传感器实验箱收集由传感器测得的实时数据存入sqlite3数据库。
2.然后通过ubuntu发送到linux、接收并用动态网页显示代表数据变化的曲线。
第2章温湿度传感器的简介
由于温度与湿度不管是从物理量本身还是在实际人们的生活中都有着密切的关系,所以温湿度一体的传感器就会相应产生。
温湿度传感器是指能将温度量和湿度量转换成容易被测量处理的电信号的设备或装置。
市场上的温湿度传感器一般是测量温度量和相对湿度量。
温度:
度量物体冷热的物理量,是国际单位制中7个基本物理量之一。
在生产和科学研究中,许多物理现象和化学过程都是在一定的温度下进行的,人们的生活也和他密切相关。
湿度:
湿度很久以前就与生活存在着密切的关系,但用数量来进行表示较为困难。
对湿度的表示方法有绝对湿度、相对湿度、露点、湿气与干气的比值(重量或体积)等等。
日常生活中最常用的表示湿度的物理量是空气的相对湿度。
用%RH表示。
在物理量的导出上相对湿度与温度有着密切的关系。
一定体积的密闭气体,其温度越高相对湿度越低,温度越低,其相对湿度越高。
其中涉及到复杂的热力工程学知识。
有关湿度的一些定义:
相对湿度:
在计量法中规定,湿度定义为“物象状态的量”。
日常生活中所指的适度为相对湿度,用RH%表示。
总之,即气体中(通常为空气中)所含水蒸气量(水蒸气压)与其空气相同情况下饱和水蒸气量(饱和水蒸汽压)的百分比。
绝对湿度:
指单位容积的空气里实际所含的水汽量,一般以克为单位。
温度对绝对湿度有着直接影响,一般情况下,温度越高,水蒸气发得越多,绝对湿度就越大;相反,绝对湿度就小。
饱和湿度:
在一定温度下,单位容积,空气中所能容纳的水汽量的最大限度。
如果超过这个限度,多余的水蒸气就会凝结,变成水滴,此时的空气湿度变称为饱和湿度。
空气的饱和湿度不是固定不变的,它随着温度的变化而变化。
温度越高,单位容积空气中能容纳的水蒸气就越多,饱和湿度就越大。
露点:
指含有一定量水蒸气(绝对湿度)的空气,当温度下降到一定程度时所含的水蒸气就会达到饱和状态(饱和湿度)并开始液化成水,这种现象叫做凝露。
水蒸气开始液化成水时的温度叫做“露点温度”简称“露点”。
如果温度继续下降到露点以下,空气中超饱和的水蒸气就会在物体表面上凝结成水滴。
此外,风与空气中的温湿度有密切关系,也是影响空气温湿度变化的重要因素之一。
选择的注意事项:
①、选择测量范围
和测量重量、温度一样,选择湿度传感器首先要确定测量范围。
除了气象、科研部门外,搞温、湿度测控的一般不需要全湿程(0-100%RH)测量。
②、选择测量精度
测量精度是湿度传感器最重要的指标,每提高—个百分点,对湿度传感器来说就是上一个台阶,甚至是上一个档次。
因为要达到不同的精度,其制造成本相差很大,售价也相差甚远。
所以使用者一定要量体裁衣,不宜盲目追求“高、精、尖”。
如在不同温度下使用湿度传感器,其示值还要考虑温度漂移的影响。
众所周知,相对湿度是温度的函数,温度严重地影响着指定空间内的相对湿度。
温度每变化0.1℃。
将产生0.5%RH的湿度变化(误差)。
使用场合如果难以做到恒温,则提出过高的测湿精度是不合适的。
多数情况下,如果没有精确的控温手段,或者被测空间是非密封的,±5%RH的精度就足够了。
对于要求精确控制恒温、恒湿的局部空间,或者需要随时跟踪记录湿度变化的场合,再选用±3%RH以上精度的湿度传感器。
而精度高于±2%RH的要求恐怕连校准传感器的标准湿度发生器也难以做到,更何况传感器自身了。
相对湿度测量仪表,即使在20—25℃下,要达到2%RH的准确度仍是很困难的。
通常产品资料中给出的特性是在常温(20℃±10℃)和洁净的气体中测量的。
③、考虑时漂和温漂
在实际使用中,由于尘土、油污及有害气体的影响,使用时间一长,电子式湿度传器会产生老化,精度下降,电子式湿度传感器年漂移量一般都在±2%左右,甚至更高。
一般情况下,生产厂商会标明1次标定的有效使用时间为1年或2年,到期需重新标定。
④、其它注意事项
湿度传感器是非密封性的,为保护测量的准确度和稳定性,应尽量避免在酸性、碱性及含有机溶剂的气氛中使用。
也避免在粉尘较大的环境中使用。
为正确反映欲测空间的湿度,还应避免将传感器安放在离墙壁太近或空气不流通的死角处。
如果被测的房间太大,就应放置多个传感器。
有的湿度传感器对供电电源要求比较高,否则将影响测量精度。
或者传感器之间相互干扰,甚至无法工作。
使用时应按照技术要求提供合适的、符合精度要求的供电电源。
传感器需要进行远距离信号传输时,要注意信号的衰减问题。
当传输距离超过200m以上时,建议选用频率输出信号的湿度传感器。
第3章课程设计实现方案
一、开发环境
1.硬件(详细介绍所涉及硬件的详细内容)
Pc机、温湿度传感器、传感器实验箱、连接所需的各种线。
2.软件(详细介绍所涉及软件的详细内容)
MDK414(arm平台编译烧录代码软件)、KeilC51v750a_Full(C51平台编译软件)、STC手动下载(C51烧录代码软件)、R340(串口线连接USB驱动)、ubuntu操作系统、linux操作系统。
3.其它
二、开发内容
1.项目开发详细内容(包括传感器的配置、传感器烧录、数据的实时收集、实时数据的存储、实时数据的传输、实时数据在服务器端的接受及存储-TCPServer及MySql、数据库及Web服务器安装、利用JSP曲线动态显示实时数据)
首先烧录整合好的温湿度传感器的代码。
接着连接传感器取得数据。
然后在ubuntu中编译并运行Com_Sensor程序获取传感器实验箱的数据。
在Ubuntu11编译并运行senddata.c把数据发送到linux.Linux通过TCPServer服务器接收数据并存入MySQL数据库。
最后将接收到的数据通过Linuxweb服务器以jsp曲线动态显示实时数据。
2.网络拓扑图(包括传感器、网关、传输网络、TCPServer服务器、数据库服务器、静态及动态Web服务器、Web服务器客户端;并详细标注设备名称及IP地址等详细信息;并详细叙述网络拓扑图流程)
三、技术路线
1.数据服务中心TCP服务器接收实时数据(给出存储实时数据的MySql数据表格的详细的数据列及数据类型、给出接收及存储实时数据的TCPServer.java源代码;是否遇到问题及如何解决)
MySql数据表格的详细的数据列及数据类型:
+---------------+----------+------+-----+---------+-------+
|Field|Type|Null|Key|Default|Extra|
+---------------+----------+------+-----+---------+-------+
|StId|int(11)|NO||||
|Stdatetime|char(50)|NO||||
|Sttemperature|char(50)|NO||||
|Sthumidity|char(50)|NO||||
+---------------+----------+------+-----+---------+-------+
TCPServer.java代码源:
importjava.io.*;
import.*;
importjava.sql.*;
importjava.util.StringTokenizer;
classTCPServer
{
publicstaticvoidmain(Stringargv[])throwsException
{
intqq=-1,pp;
StringclientSentence;
StringcapitalizedSentence;
ServerSocketwelcomeSocket=newServerSocket
(6789);
Stringdriver="com.mysql.jdbc.Driver";
Stringurl="jdbc:
mysql:
//127.0.0.1:
3306/test_db";
Stringuser="root";
Stringpassword="123456";
while(true)
{
SocketconnectionSocket=welcomeSocket.
accept();
BufferedReaderinFromClient=
newBufferedReader(newInputStreamReader(
connectionSocket.getInputStream()));
DataOutputStreamoutToClient=
newDataOutputStream(
connectionSocket.getOutputStream());
clientSentence=inFromClient.readLine();
StringTokenizerst=newStringTokenizer(clientSentence,"#");
try{
Class.forName(driver);
Connectionconn=DriverManager.getConnection(url,user,password);
if(!
conn.isClosed())
System.out.println("SucceededconnectingtotheDatabase!
");
Statementstatement=conn.createStatement();
while(st.hasMoreTokens()){
//System.out.println(st.nextToken());
StringTokenizerst1=newStringTokenizer(st.nextToken(),"$");
while(st1.hasMoreTokens()){
//System.out.println(st1.nextToken());
StringStId=st1.nextToken();
StringStdatetime=st1.nextToken();
StringSttemperature=st1.nextToken();
StringSthumidity=st1.nextToken();
//StringStSize=st1.nextToken();
//StringStUsed=st1.nextToken();
System.out.println("StId="+StId);
System.out.println("Stdatetime="+Stdatetime);
System.out.println("Sttemperature="+Sttemperature);
System.out.println("Sthumidity="+Sthumidity);
//System.out.println("StSize="+StSize);
//System.out.println("StUsed="+StUsed);
pp=Integer.parseInt(StId);
if(qqStringsql="INSERTINTOSdataVALUES('"+StId+"','"+Stdatetime+"','"+Sttemperature+"','"+Sthumidity+"')";
qq=pp;
statement.executeUpdate(sql);
}
}
}
conn.close();
}catch(ClassNotFoundExceptione){
System.out.println("Sorry,can`tfindtheDriver!
");
e.printStackTrace();
}catch(SQLExceptione){
e.printStackTrace();
}catch(Exceptione){
e.printStackTrace();
}
System.out.println(clientSentence);
capitalizedSentence=
clientSentence.toUpperCase()+'\n';
outToClient.writeBytes(capitalizedSentence);
}
}
}
2.实时数据显示(给出实时以曲线形式显示MySql数据库中实时数据的JSP源代码及显示曲线截图)
JSP源代码:
<%@pagecontentType="text/html"pageEncoding="UTF-8"%>
<%@pageimport="java.sql.*"%>
<%@pageimport="java.util.Properties"%>
<%@pageimport="java.text.SimpleDateFormat"%>
<%@pageimport="java.util.Date"%>
<%@pageimport="java.awt.*"%>
<%@pageimport="java.io.*"%>
<%@pageimport="org.jfree.chart.*"%>
<%@pageimport="org.jfree.chart.axis.*"%>
<%@pageimport="org.jfree.chart.entity.*"%>
<%@pageimport="org.jfree.chart.labels.*"%>
<%@pageimport="org.jfree.chart.plot.*"%>
<%@pageimport="org.jfree.chart.renderer.category.*"%>
<%@pageimport="org.jfree.chart.urls.*"%>
<%@pageimport="org.jfree.data.category.*"%>
<%@pageimport="org.jfree.data.general.*"%>
<%@pageimport="org.jfree.data.category.DefaultCategoryDataset"%>
<%@pageimport="org.jfree.data.general.DefaultPieDataset"%>
<%@pageimport="org.jfree.data.xy.*"%>
<%@pageimport="org.jfree.data.*"%>
DOCTYPEHTMLPUBLIC"-//W3C//DTDHTML4.01Transitional//EN"
"http:
//www.w3.org/TR/html4/loose.dtd">
<%
SimpleDateFormatsdf1=newSimpleDateFormat("yyyy-MM-ddHH:
mm:
ss");
SimpleDateFormatsdf2=newSimpleDateFormat("yyyyMMddHHmmss");
XYSeriesseries=newXYSeries("TimeTemperature");
try{
StringdatabaseURL="jdbc:
mysql:
//localhost:
3306/test_db";
Class.forName("com.mysql.jdbc.Driver");
Propertiesproperties=newProperties();
properties.put("user","root");
properties.put("password","123456");
Connectionconn=DriverManager.getConnection(databaseURL,properties);
StatementStmt=conn.createStatement();
ResultSetRS=Stmt.executeQuery("SELECT*fromSdata");
while(RS.next()){
//Datedate=newDate(RS.getString
(2););
StringnowTime1=RS.getString
(2);
StringnowTime2=RS.getString(3);
try{
nowTime2=sdf2.format(sdf1.parse(nowTime1));
}catch(Exceptione){
e.printStackTrace();
}
//System.out.println(nowTime1);
Stringres;
res=nowTime2.substring(8,nowTime2.length());
series.add(Double.parseDouble(res),Double.parseDouble(RS.getString(3)));
}
RS.close();
}catch(ClassNotFoundExceptione){
out.println("Couldn'tloaddatabasedriver:
"+e.getMessage());
}catch(SQLExceptione){}
XYDatasetxyDataset=newXYSeriesCollection(series);
JFreeChartchart=ChartFactory.createXYLineChart
("XYLineChartusingJFreeChart","Time/s","Temperature/C",
xyDataset,PlotOrientation.VERTICAL,true,true,false);
try{
finalChartRenderingInfoinfo=newChartRenderingInfo
(newStandardEntityCollection());
finalFilefile1=newFile("/usr/local/apache2/htdocs/barchart.png");
ChartUtilities.saveChartAsPNG(file1,chart,600,400,info);
}catch(Exceptione){
out.println(e);
}
%>
content="text/html;charset=UTF-8">
JSPPage
HEIGHT="400"BORDER="0"USEMAP="#chart">
第4章课程设计结果
第5章结论与体会
通过几周的努力