Difference between revisions of "IPSO Alliance"

From ESS-WIKI
Jump to: navigation, search
(Created page with " = IPSO Application Framework [http://www.ipso-alliance.org/ IPSO Offical WebSite] = The IPSO Application Framework makes use of IETF standards as building blocks for a...")
 
Line 1: Line 1:
 +
= [https://www.ipso-alliance.org/ IPSO Application Framework ]=<br/>&lt;div style="margin-left:0cm;margin-right:0cm;"&gt;The IPSO Application Framework makes use of IETF standards as building blocks for a simple and efficient RESTful design model for IP smart objects. The framework may be used over either HTTP or CoAP web transfer protocols.&lt;/div&gt;<br/>HTTP, REST, XML, JSON, COAP and other key components of web technology are powerful mechanisms in an Internet of Things application.
  
 
+
&lt;span style="background-color:#ffffff;color:#333333;"&gt;'''''Note: The objective of the Alliance is not to define technologies, but to document the use of IP-based technologies defined at the standard organizations such as IETF with focus on support by the Alliance of various use cases.'''''&lt;/span&gt;
= IPSO Application Framework&nbsp;[http://www.ipso-alliance.org/ IPSO Offical WebSite] =
 
 
 
The IPSO Application Framework makes use of IETF standards as building blocks for a simple and efficient RESTful design model for IP smart objects. The framework may be used over either HTTP or CoAP web transfer protocols.
 
 
 
HTTP, REST, XML, JSON, COAP and other key components of web technology are powerful mechanisms in an Internet of Things application.
 
 
 
'''''Note: The objective of the Alliance is not to define technologies, but to document the use of IP-based technologies defined at the standard organizations such as IETF with focus on support by the Alliance of various use cases.'''''
 
  
 
'''Function Sets''': The framework is organized into groups of resource types called Function Sets. A Function Set has a recommended root path, under which its sub-resources are organized. Each Function Set is assigned a Resource Type parameter, therefore making it possible to discover it.
 
'''Function Sets''': The framework is organized into groups of resource types called Function Sets. A Function Set has a recommended root path, under which its sub-resources are organized. Each Function Set is assigned a Resource Type parameter, therefore making it possible to discover it.
  
 +
{| style="border-spacing:0;width:14.75cm;"<br/>|- style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;"<br/>| Function Set<br/>| Root Path<br/>| Resource Type<br/>|-<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | &lt;span style="color:#000000;"&gt;General Purpose IO&lt;/span&gt;<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | &lt;span style="color:#000000;"&gt;/gpio&lt;/span&gt;<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | &lt;span style="color:#000000;"&gt;gpio&lt;/span&gt;<br/>|-<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | &lt;span style="color:#000000;"&gt;Power&lt;/span&gt;<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | &lt;span style="color:#000000;"&gt;/pwr&lt;/span&gt;<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | &lt;span style="color:#000000;"&gt;pwr&lt;/span&gt;<br/>|-<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | &lt;span style="color:#000000;"&gt;Load Control&lt;/span&gt;<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | &lt;span style="color:#000000;"&gt;/load&lt;/span&gt;<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | &lt;span style="color:#000000;"&gt;load&lt;/span&gt;<br/>|-<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | &lt;span style="color:#000000;"&gt;Sensors&lt;/span&gt;<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | &lt;span style="color:#000000;"&gt;/sen&lt;/span&gt;<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | &lt;span style="color:#000000;"&gt;sen&lt;/span&gt;<br/>|-<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | &lt;span style="color:#000000;"&gt;Light Control&lt;/span&gt;<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | &lt;span style="color:#000000;"&gt;/lt&lt;/span&gt;<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | &lt;span style="color:#000000;"&gt;lt&lt;/span&gt;<br/>|-<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | &lt;span style="color:#000000;"&gt;Message&lt;/span&gt;<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | &lt;span style="color:#000000;"&gt;/msg&lt;/span&gt;<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | &lt;span style="color:#000000;"&gt;msg&lt;/span&gt;<br/>|-<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | &lt;span style="color:#000000;"&gt;Location&lt;/span&gt;<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | &lt;span style="color:#000000;"&gt;/loc&lt;/span&gt;<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | &lt;span style="color:#000000;"&gt;loc&lt;/span&gt;<br/>|-<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | Configuration<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | /cfg<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | cfg<br/>|}
  
 +
== IPSO Smart Object ==<br/>&lt;div style="margin-left:0cm;margin-right:0cm;"&gt;IPSO Smart Object[2] Guidelines provide a common design pattern, an object model, that can effectively use the IETF CoAP protocol to provide high level interoperability between Smart Object devices and connected software applications on other devices and services&lt;/div&gt;&lt;div style="margin-left:0cm;margin-right:0cm;"&gt;The common object model is based on the Lightweight M2M (LWM2M 1.0) specification from the Open Mobile Alliance. OMA LWM2M is a device management and service architecture specification based on IETF CoAP, and provides a simple and flexible object template (object model) for constrained device management.&lt;/div&gt;<br/>The object model from OMA LWM2M is reused to define application level IPSO Smart Objects. This enables the OMA Name Authority (OMNA) to be used to register new objects, and enables existing LWM2M compliant device libraries and server software to be used as an infrastructure for IPSO Smart Objects<br/>&lt;div style="margin-left:0cm;margin-right:0cm;"&gt;This first IPSO Smart Object Guideline describes 18 Smart Object types '''[Appendix A]''', including a temperature sensor, a light controller, an accelerometer, a presence sensor, and other common sensor and actuator types representing a variety of use case domains. It is intended as a&nbsp;?tarter pack??and example of how IPSO Smart Objects can be built to address some application specific use cases&lt;/div&gt;
  
{|
+
<br/>== Media Types for Sensor Markup Language (SENML) ==
|-
 
| Function Set
 
| Root Path
 
| Resource Type
 
|-
 
| General Purpose IO
 
| /gpio
 
| gpio
 
|-
 
| Power
 
| /pwr
 
| pwr
 
|-
 
| Load Control
 
| /load
 
| load
 
|-
 
| Sensors
 
| /sen
 
| sen
 
|-
 
| Light Control
 
| /lt
 
| lt
 
|-
 
| Message
 
| /msg
 
| msg
 
|-
 
| Location
 
| /loc
 
| loc
 
|-
 
| Configuration
 
| /cfg
 
| cfg
 
|}
 
 
 
 
 
 
 
== IPSO Smart Object ==
 
 
 
IPSO Smart Object[2] Guidelines provide a common design pattern, an object model, that can effectively use the IETF CoAP protocol to provide high level interoperability between Smart Object devices and connected software applications on other devices and services
 
 
 
The common object model is based on the Lightweight M2M (LWM2M 1.0) specification from the Open Mobile Alliance. OMA LWM2M is a device management and service architecture specification based on IETF CoAP, and provides a simple and flexible object template (object model) for constrained device management.
 
 
 
The object model from OMA LWM2M is reused to define application level IPSO Smart Objects. This enables the OMA Name Authority (OMNA) to be used to register new objects, and enables existing LWM2M compliant device libraries and server software to be used as an infrastructure for IPSO Smart Objects
 
 
 
This first IPSO Smart Object Guideline describes 18 Smart Object types '''[Appendix A]''', including a temperature sensor, a light controller, an accelerometer, a presence sensor, and other common sensor and actuator types representing a variety of use case domains. It is intended as a&nbsp;?tarter pack??and example of how IPSO Smart Objects can be built to address some application specific use cases
 
 
 
 
 
 
 
== Media Types for Sensor Markup Language (SENML) ==
 
  
 
'''Semantics'''
 
'''Semantics'''
  
{|
+
{| style="border-spacing:0;width:17.009cm;"<br/>|- style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;"<br/>| SenML<br/>| JSON<br/>| Type<br/>| Description<br/>|-<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | &lt;span style="color:#000000;"&gt;Base Name&lt;/span&gt;<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | &lt;span style="color:#000000;"&gt;bn&lt;/span&gt;<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | &lt;span style="color:#000000;"&gt;String&lt;/span&gt;<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | &lt;span style="color:#000000;"&gt;This is a string that is prepended to the names found in the entries&lt;/span&gt;<br/>|-<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | &lt;span style="color:#000000;"&gt;Base Time&lt;/span&gt;<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | &lt;span style="color:#000000;"&gt;bt&lt;/span&gt;<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | &lt;span style="color:#000000;"&gt;Integer&lt;/span&gt;<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | &lt;span style="color:#000000;"&gt;A base time that is added to the time found in an entry&lt;/span&gt;<br/>|-<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | &lt;span style="color:#000000;"&gt;Base Units&lt;/span&gt;<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | &lt;span style="color:#000000;"&gt;bu&lt;/span&gt;<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | String<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | &lt;span style="color:#000000;"&gt;A base unit that is assumed for all entries, unless otherwise indicated&lt;/span&gt;<br/>|-<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | &lt;span style="color:#000000;"&gt;Version&lt;/span&gt;<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | &lt;span style="color:#000000;"&gt;ver&lt;/span&gt;<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | &lt;span style="color:#000000;"&gt;Number&lt;/span&gt;<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | &lt;span style="color:#000000;"&gt;Version number of media type format&lt;/span&gt;<br/>|-<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | &lt;span style="color:#000000;"&gt;Measurement or Parameters&lt;/span&gt;<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | &lt;span style="color:#000000;"&gt;e&lt;/span&gt;<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | &lt;span style="color:#000000;"&gt;Array&lt;/span&gt;<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | &lt;span style="color:#000000;"&gt;Array of values for sensor measurements or other generic parameters&lt;/span&gt;<br/>|-<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | &lt;span style="color:#000000;"&gt;Name&lt;/span&gt;<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | &lt;span style="color:#000000;"&gt;n&lt;/span&gt;<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | &lt;span style="color:#000000;"&gt;String&lt;/span&gt;<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | &lt;span style="color:#000000;"&gt;Name of the sensor or parameter&lt;/span&gt;<br/>|-<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | Units<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | u<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | String<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | Units for a measurement value<br/>|-<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | Value<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | v<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | Float<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | &lt;span style="color:#000000;"&gt;Value of the entry&lt;/span&gt;<br/>|-<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | String Value<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | sv<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | String<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;color:#000000;" |&nbsp;<br/>|-<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | Boolean Value<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | bv<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | Boolean<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;color:#000000;" |&nbsp;<br/>|-<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | Value Sum<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | s<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | Float<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | &lt;span style="color:#000000;"&gt;Integrated sum of the values over time&lt;/span&gt;<br/>|-<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | Time<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | t<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | &lt;span style="color:#000000;"&gt;Integer&lt;/span&gt;<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | &lt;span style="color:#000000;"&gt;Time when value was recorded&lt;/span&gt;<br/>|-<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | Update Time<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | ut<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | &lt;span style="color:#000000;"&gt;Integer&lt;/span&gt;<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | &lt;span style="color:#000000;"&gt;Update time. A time in seconds that represents the maximum time before this sensor will provide an updated reading for a measurement.&lt;/span&gt;<br/>|}
|-
 
| SenML
 
| JSON
 
| Type
 
| Description
 
|-
 
| Base Name
 
| bn
 
| String
 
| This is a string that is prepended to the names found in the entries
 
|-
 
| Base Time
 
| bt
 
| Integer
 
| A base time that is added to the time found in an entry
 
|-
 
| Base Units
 
| bu
 
| String
 
| A base unit that is assumed for all entries, unless otherwise indicated
 
|-
 
| Version
 
| ver
 
| Number
 
| Version number of media type format
 
|-
 
| Measurement or Parameters
 
| e
 
| Array
 
| Array of values for sensor measurements or other generic parameters
 
|-
 
| Name
 
| n
 
| String
 
| Name of the sensor or parameter
 
|-
 
| Units
 
| u
 
| String
 
| Units for a measurement value
 
|-
 
| Value
 
| v
 
| Float
 
| Value of the entry
 
|-
 
| String Value
 
| sv
 
| String
 
|  
 
|-
 
| Boolean Value
 
| bv
 
| Boolean
 
|  
 
|-
 
| Value Sum
 
| s
 
| Float
 
| Integrated sum of the values over time
 
|-
 
| Time
 
| t
 
| Integer
 
| Time when value was recorded
 
|-
 
| Update Time
 
| ut
 
| Integer
 
| Update time. A time in seconds that represents the maximum time before this sensor will provide an updated reading for a measurement.
 
|}
 
 
 
 
 
  
 
== The Data Type of Sensor Data Type ==
 
== The Data Type of Sensor Data Type ==
  
{|
+
{| style="border-spacing:0;width:9.834cm;"<br/>|- style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;"<br/>| Data Type (type)<br/>| SenML Field<br/>|-<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | b (boolean)<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | bv<br/>|-<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | s (string)<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | s<br/>|-<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | e (enum)<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | e<br/>|-<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | i (integer)<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | v<br/>|-<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | d (decimal)<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | v<br/>|-<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | h(hexadecimal)<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | s<br/>|-<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | o(octet-stream)<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | s<br/>|}
|-
 
| Data Type (type)
 
| SenML Field
 
|-
 
| b (boolean)
 
| bv
 
|-
 
| s (string)
 
| s
 
|-
 
| e (enum)
 
| e
 
|-
 
| i (integer)
 
| v
 
|-
 
| d (decimal)
 
| v
 
|-
 
| h(hexadecimal)
 
| s
 
|-
 
| o(octet-stream)
 
| s
 
|}
 
 
 
 
 
  
 
== Advantech Sensor Semantics ==
 
== Advantech Sensor Semantics ==
  
{|
+
{| style="border-spacing:0;width:17.009cm;"<br/>|- style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;"<br/>| SenML<br/>| JSON<br/>| Type<br/>| Description<br/>|-<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | Min Range Value<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | min<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | Float<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | &lt;span style="color:#000000;"&gt;The minimum value that can be measured by the sensor&lt;/span&gt;<br/>|-<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | Max Range Value<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | max<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | Float<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | &lt;span style="color:#000000;"&gt;The maximum value that can be measured by the sensor&lt;/span&gt;<br/>|-<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | Access Mode<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | asm<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | String<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | &lt;span style="color:#000000;"&gt;The access mode of the resource. Ex: read (r), write (w), read/write (rw)&lt;/span&gt;<br/>|-<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | Standard Format<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | st<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | String<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | &lt;span style="color:#000000;"&gt;The sensor format is which standard format&lt;/span&gt;<br/>|-<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | Health Status<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | Health<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | Integer<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | &lt;span style="color:#000000;"&gt;The health status of network or device. Range: -1 ~ 100&lt;/span&gt;<br/>&lt;span style="color:#000000;"&gt;Good: > 80, Average: 60 ~ 80, Below Average: 40~60, Bad:0~40, -1: Off line or Fault&lt;/span&gt;
|-
 
| SenML
 
| JSON
 
| Type
 
| Description
 
|-
 
| Min Range Value
 
| min
 
| Float
 
| The minimum value that can be measured by the sensor
 
|-
 
| Max Range Value
 
| max
 
| Float
 
| The maximum value that can be measured by the sensor
 
|-
 
| Access Mode
 
| asm
 
| String
 
| The access mode of the resource. Ex: read (r), write (w), read/write (rw)
 
|-
 
| Standard Format
 
| st
 
| String
 
| The sensor format is which standard format
 
|-
 
| Health Status
 
| Health
 
| Integer
 
| The health status of network or device. Range: -1 ~ 100
 
Good: > 80, Average: 60 ~ 80, Below Average: 40~60, Bad:0~40, -1: Off line or Fault
 
  
|-
+
|-<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | Message<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | msg<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | String<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;color:#000000;" | Message for resource<br/>|-<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | Extension<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | exten<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;" | String<br/>| style="border:0.5pt solid #00000a;padding-top:0cm;padding-bottom:0cm;padding-left:0.199cm;padding-right:0.191cm;color:#000000;" | Field for exten<br/>|}
| Message
 
| msg
 
| String
 
| Message for resource
 
|-
 
| Extension
 
| exten
 
| String
 
| Field for exten
 
|}
 
  
 
'''Example'''
 
'''Example'''
  
<big>{"n":"Room Temp","u":"Cel","v":0,"min":0,"max":100,"asm":"r","type":"d","rt":"ucum.Cel","st":"ipso","exten":"sid=3303"}</big>
+
&lt;big&gt;{"n":"Room Temp","u":"Cel","v":0,"min":0,"max":100,"asm":"r","type":"d","rt":"ucum.Cel","st":"ipso","exten":"sid=3303"}&lt;/big&gt;
 +
<big></big>

Revision as of 10:17, 15 September 2017

= IPSO Application Framework =
<div style="margin-left:0cm;margin-right:0cm;">The IPSO Application Framework makes use of IETF standards as building blocks for a simple and efficient RESTful design model for IP smart objects. The framework may be used over either HTTP or CoAP web transfer protocols.</div>
HTTP, REST, XML, JSON, COAP and other key components of web technology are powerful mechanisms in an Internet of Things application.

<span style="background-color:#ffffff;color:#333333;">Note: The objective of the Alliance is not to define technologies, but to document the use of IP-based technologies defined at the standard organizations such as IETF with focus on support by the Alliance of various use cases.</span>

Function Sets: The framework is organized into groups of resource types called Function Sets. A Function Set has a recommended root path, under which its sub-resources are organized. Each Function Set is assigned a Resource Type parameter, therefore making it possible to discover it.

== IPSO Smart Object ==
<div style="margin-left:0cm;margin-right:0cm;">IPSO Smart Object[2] Guidelines provide a common design pattern, an object model, that can effectively use the IETF CoAP protocol to provide high level interoperability between Smart Object devices and connected software applications on other devices and services</div><div style="margin-left:0cm;margin-right:0cm;">The common object model is based on the Lightweight M2M (LWM2M 1.0) specification from the Open Mobile Alliance. OMA LWM2M is a device management and service architecture specification based on IETF CoAP, and provides a simple and flexible object template (object model) for constrained device management.</div>
The object model from OMA LWM2M is reused to define application level IPSO Smart Objects. This enables the OMA Name Authority (OMNA) to be used to register new objects, and enables existing LWM2M compliant device libraries and server software to be used as an infrastructure for IPSO Smart Objects
<div style="margin-left:0cm;margin-right:0cm;">This first IPSO Smart Object Guideline describes 18 Smart Object types [Appendix A], including a temperature sensor, a light controller, an accelerometer, a presence sensor, and other common sensor and actuator types representing a variety of use case domains. It is intended as a ?tarter pack??and example of how IPSO Smart Objects can be built to address some application specific use cases</div>
== Media Types for Sensor Markup Language (SENML) == Semantics

The Data Type of Sensor Data Type

Advantech Sensor Semantics

Example <big>{"n":"Room Temp","u":"Cel","v":0,"min":0,"max":100,"asm":"r","type":"d","rt":"ucum.Cel","st":"ipso","exten":"sid=3303"}</big>