Sélection de la langue

Search

Sommaire du brevet 2705094 

Énoncé de désistement de responsabilité concernant l'information provenant de tiers

Une partie des informations de ce site Web a été fournie par des sources externes. Le gouvernement du Canada n'assume aucune responsabilité concernant la précision, l'actualité ou la fiabilité des informations fournies par les sources externes. Les utilisateurs qui désirent employer cette information devraient consulter directement la source des informations. Le contenu fourni par les sources externes n'est pas assujetti aux exigences sur les langues officielles, la protection des renseignements personnels et l'accessibilité.

Disponibilité de l'Abrégé et des Revendications

L'apparition de différences dans le texte et l'image des Revendications et de l'Abrégé dépend du moment auquel le document est publié. Les textes des Revendications et de l'Abrégé sont affichés :

  • lorsque la demande peut être examinée par le public;
  • lorsque le brevet est émis (délivrance).
(12) Demande de brevet: (11) CA 2705094
(54) Titre français: SYSTEME ET PROCEDE DE FILTRAGE DE FAUSSE ALERTE DE MESSAGES D'EVENEMENTS DANS UN RESEAU
(54) Titre anglais: SYSTEM AND METHOD FOR FALSE ALERT FILTERING OF EVENT MESSAGES WITHIN A NETWORK
Statut: Réputée abandonnée et au-delà du délai pour le rétablissement - en attente de la réponse à l’avis de communication rejetée
Données bibliographiques
(51) Classification internationale des brevets (CIB):
  • H02J 13/00 (2006.01)
  • H04L 12/28 (2006.01)
(72) Inventeurs :
  • VEILLETTE, MICHEL (Canada)
  • HOUSE, KEVIN (Canada)
(73) Titulaires :
  • TRILLIANT NETWORKS, INC.
(71) Demandeurs :
  • TRILLIANT NETWORKS, INC. (Etats-Unis d'Amérique)
(74) Agent: DEETH WILLIAMS WALL LLP
(74) Co-agent:
(45) Délivré:
(86) Date de dépôt PCT: 2008-11-21
(87) Mise à la disponibilité du public: 2009-05-28
Licence disponible: S.O.
Cédé au domaine public: S.O.
(25) Langue des documents déposés: Anglais

Traité de coopération en matière de brevets (PCT): Oui
(86) Numéro de la demande PCT: PCT/US2008/013018
(87) Numéro de publication internationale PCT: US2008013018
(85) Entrée nationale: 2010-05-06

(30) Données de priorité de la demande:
Numéro de la demande Pays / territoire Date
60/989,950 (Etats-Unis d'Amérique) 2007-11-25
60/989,951 (Etats-Unis d'Amérique) 2007-11-25
60/989,952 (Etats-Unis d'Amérique) 2007-11-25
60/989,953 (Etats-Unis d'Amérique) 2007-11-25
60/989,954 (Etats-Unis d'Amérique) 2007-11-25
60/989,955 (Etats-Unis d'Amérique) 2007-11-25
60/989,956 (Etats-Unis d'Amérique) 2007-11-25
60/989,957 (Etats-Unis d'Amérique) 2007-11-25
60/989,958 (Etats-Unis d'Amérique) 2007-11-25
60/989,959 (Etats-Unis d'Amérique) 2007-11-25
60/989,961 (Etats-Unis d'Amérique) 2007-11-25
60/989,962 (Etats-Unis d'Amérique) 2007-11-25
60/989,964 (Etats-Unis d'Amérique) 2007-11-25
60/989,967 (Etats-Unis d'Amérique) 2007-11-25
60/989,975 (Etats-Unis d'Amérique) 2007-11-25
60/992,312 (Etats-Unis d'Amérique) 2007-12-04
60/992,313 (Etats-Unis d'Amérique) 2007-12-04
60/992,315 (Etats-Unis d'Amérique) 2007-12-04
61/025,270 (Etats-Unis d'Amérique) 2008-01-31
61/025,271 (Etats-Unis d'Amérique) 2008-01-31
61/025,273 (Etats-Unis d'Amérique) 2008-01-31
61/025,276 (Etats-Unis d'Amérique) 2008-01-31
61/025,277 (Etats-Unis d'Amérique) 2008-01-31
61/025,278 (Etats-Unis d'Amérique) 2008-01-31
61/025,279 (Etats-Unis d'Amérique) 2008-01-31
61/025,282 (Etats-Unis d'Amérique) 2008-01-31
61/025,287 (Etats-Unis d'Amérique) 2008-01-31
61/094,116 (Etats-Unis d'Amérique) 2008-09-04

Abrégés

Abrégé français

Lorsque le comptage couplé à un réseau perd sa source d'alimentation primaire et possède une source d'alimentation secondaire, tel qu'un supercondensateur, il reconnaît et reporte une coupure de courant. Dans ce cas, le serveur de tête de réseau peut vérifier le rapport de coupure de courant par interrogation des noeuds en aval couplés au réseau au sujet de la coupure de courant. Lorsqu'un noeud perd sa source d'alimentation primaire et ne possède pas de source d'alimentation secondaire, il ne parvient pas à effectuer un rapport programmé de manière régulière au moment approprié. Par conséquent, le serveur de tête de réseau vérifie la coupure de courant par interrogation des noeuds en aval couplés au réseau domestique (HAN) au sujet de la coupure de courant ce qui permet de déduire s'il y a une coupure de courant ou non.


Abrégé anglais


When a metering coupled to a network loses its primary power source and has a
secondary power source, such as
a super-capacitor, it recognizes and reports a power outage. In this case, the
head end server may verify the power outage report
by querying through the downstream nodes coupled to the network about the
power outage. When a node loses its primary power
source and has no secondary power source, it will fail to make a regularly
scheduled report at the appropriate time. Consequently,
the head end server verify the power outage by polling downstream nodes
coupled to the HAN about the power outage to deduce
whether a power outage.

Revendications

Note : Les revendications sont présentées dans la langue officielle dans laquelle elles ont été soumises.


What is claimed is:
1. A method of confirming a power outage report comprising:
receiving the power outage report from a first node coupled to a first
network;
querying one or more other nodes coupled to the first network about a power
outage;
receiving one or more responses from the one or more other nodes coupled to
the first
network; and
determining whether the power outage report is false based on the one or more
responses from the one or more other nodes in the first network.
2. The method of claim 1, wherein the first network comprises a home area
network (HAN).
3. The method of claim 1, further comprising generating an alarm report if the
power
outage report is confirmed.
4. The method of claim 1, further comprising displaying an alarm message at a
utility
office if the power outage report is confirmed.
5. The method of claim 1, further comprising displaying an alarm message at a
display
coupled to the first network if the power outage report is confirmed.
6. The method of claim 1, further comprising pulling untransmitted data and
reports from
the first node if the power outage report is confirmed.
7. The method of claim 1, wherein the first node comprises a meter having a
secondary
power source.
8. The method of claim 7, wherein the secondary power source is a super-
capacitor.

9. The method of claim 7, wherein the secondary power source is a battery.
10. A system for confirming a power outage report comprising:
a first node coupled to a first network, wherein the first node comprises a
meter, a
register, and a communications module, and further wherein the first node
transmits the power
outage report through the first network to a microportal;
one or more other nodes coupled to the first network;
the microportal for relaying the power outage report through a second network
to a
collector;
the collector for relaying the power outage report through a third network to
a head
end server; and
the head end server for receiving the power outage report and querying the one
or
more other nodes about a power outage.
11. The system of claim 10, wherein the first network comprises a home area
network
(HAN), the second network comprises a neighborhood area network (NAN), and the
third
network comprises a wide area network (WAN).
12. The system of claim 10, wherein the first node has a secondary power
source.
13. The system of claim 12, wherein the secondary power source is a super-
capacitor.
14. The system of claim 12, wherein the secondary power source is a battery.
15. The system of claim 10, wherein the head end server further generates an
alarm report
if the power outage report is confirmed.
61

16. The system of claim 10, wherein the head end server further displays an
alarm
message at a utility office if the power outage report is confirmed.
17. The system of claim 10, wherein the head end server further displays an
alarm
message at a display coupled to the first network if the power outage report
is confirmed.
18. A method of verifying a power outage comprising:
failing to receive a report from a first node coupled to a first network at a
prescheduled
reporting time window;
polling one or more other nodes coupled to the first network about a power
outage;
and
determining whether the power outage exists based on responses from the one or
more
other nodes.
19. The method of claim 18, further comprising re-polling one or more non-
responsive
nodes about the power outage before determining whether the power outage
exists.
20. The method of claim 18, wherein the first network comprises a home area
network (HAN).
21. The method of claim 18, further comprising generating an alarm report if
the power
outage report is determined to exist.
22. The method of claim 18, further comprising displaying an alarm message at
a utility
office if the power outage report is determined to exist.
23. The method of claim 18, further comprising displaying an alarm message at
a display
coupled to the first network if the power outage report is determined to
exist.
62

24. The method of claim 18, wherein the first node does not have a secondary
power
supply.
25. A system for verifying a power outage report comprising:
a first node coupled to a first network, wherein the first node comprises a
meter, a
register, and a communications module, and further wherein the first node
fails to transmit a
report at a prescheduled reporting time window to a head end server; and
the head end server for polling one or more other nodes coupled to the first
network
about a power outage and determining whether the power outage exists based on
responses
from the one or more other nodes.
26. The system of claim 25, wherein the head end server further re-polls one
or more
nonresponsive nodes about the power outage before determining whether the
power outage
exists.
27. The system of claim 25, wherein the head end server further generates an
alarm report
if the power outage report is determined to exist.
28. The system of claim 25, wherein the head end server further displays an
alarm
message at a utility office if the power outage report is determined to exist.
29. The system of claim 25, wherein the head end server further displays an
alarm
message at a display coupled to the first network if the power outage report
is determined to
exist.
30. The system of claim 25, wherein the first node does not have a secondary
power
supply.
63

31. A method of recovering untransmitted information stored at a node
reporting a power
outage, comprising:
receiving a power outage report from the node;
transmitting a request to download all untransmitted information from the
node; and
receiving the untransmitted information from the node.
32. The method of claim 31, wherein the node is scheduled is for removal.
33. A system of recovering untransmitted information stored at a node
reporting a power
outage, comprising:
the node receiving for transmitting a power outage report;
a head end server for:
receiving the power outage report;
transmitting a request to download all untransmitted information from the
node;
receiving the untransmitted information from the node.
34. A computer program product stored in a computer readable media for
execution in a
processor and memory coupled to the processor for performing a method of
confirming a
power outage report comprising:
receiving the power outage report from a first node coupled to a first
network;
querying one or more other nodes coupled to the first network about a power
outage;
receiving one or more responses from the one or more other nodes coupled to
the first
network; and
determining whether the power outage report is false based on the one or more
responses from the one or more other nodes in the first network.
64

35. A computer program product stored in a computer readable media for
execution in a
processor and memory coupled to the processor for performing a method of
verifying a power
outage comprising:
failing to receive a report from a first node coupled to a first network at a
prescheduled
reporting time window;
polling one or more other nodes coupled to the first network about a power
outage;
and
determining whether the power outage exists based on responses from the one or
more
other nodes.
36. A computer program product stored in a computer readable media for
execution in a
processor and memory coupled to the processor for performing a method of
recovering
untransmitted information stored at a node reporting a power outage,
comprising:
receiving a power outage report from the node;
transmitting a request to download all untransmitted information from the
node; and
receiving the untransmitted information from the node.

Description

Note : Les descriptions sont présentées dans la langue officielle dans laquelle elles ont été soumises.


CA 02705094 2010-05-06
WO 2009/067250 PCT/US2008/013018
SYSTEM AND METHOD FOR FALSE ALERT FILTERING OF EVENT
MESSAGES WITHIN A NETWORK
CROSS-REFERENCE TO CO-PENDING APPLICATIONS
[0001] This application claims the benefit of priority to the following United
States
provisional patent applications which are incorporated herein by reference in
their entirety:
= serial number 60/989,957 entitled "Point-to-Point Communication within a
Mesh
Network", filed November 25, 2007 (TR0004-PRO);
= serial number 60/989,967 entitled "Efficient And Compact Transport Layer And
Model
For An Advanced Metering Infrastructure (AMI) Network," filed November 25,
2007
(TR0003-PRO);
= serial number 60/989,958 entitled "Creating And Managing A Mesh Network
Including
Network Association," filed November 25, 2007 (TR0005-PRO);
= serial number 60/989,964 entitled "Route Optimization Within A Mesh
Network," filed
November 25, 2007 (TR0007-PRO);
= serial number 60/989,950 entitled "Application Layer Device Agnostic
Collector
Utilizing ANSI C 12.22," filed November 25, 2007 (TR0009-PRO);
= serial number 60/989,953 entitled "System And Method For Real Time Event
Report
Generation Between Nodes And Head End Server In A Meter Reading Network
Including From Smart And Dumb Meters," filed November 25, 2007 (TR0010-PRO);
= serial number 60/989,956 entitled "System And Method For False Alert
Filtering Of
Event Messages Within A Network," filed November 25, 2007 (TR0011-PRO);
= serial number 60/989,975 entitled "System and Method for Network (Mesh)
Layer And
Application Layer Architecture And Processes," filed November 25, 2007 (TROO14-
PRO);
= serial number 60/989,959 entitled "Tree Routing Within a Mesh Network,"
filed
November 25, 2007 (TR0017-PRO);
1

CA 02705094 2010-05-06
WO 2009/067250 PCT/US2008/013018
= serial number 60/989,961 entitled "Source Routing Within a Mesh Network,"
filed
November 25, 2007 (TROO19-PRO);
= serial number 60/989,962 entitled "Creating and Managing a Mesh Network,"
filed
November 25, 2007 (TR0020-PRO);
= serial number 60/989,951 entitled "Network Node And Collector Architecture
For
Communicating Data And Method Of Communications," filed November 25, 2007
(TR0021-PRO);
= serial number 60/989,955 entitled "System And Method For Recovering From
Head
End Data Loss And Data Collector Failure In An Automated Meter Reading
Infrastructure," filed November 25, 2007 (TR0022-PRO);
= serial number 60/989,952 entitled "System And Method For Assigning
Checkpoints To
A Plurality Of Network Nodes In Communication With A Device Agnostic Data
Collector," filed November 25, 2007 (TR0023-PRO);
= serial number 60/989,954 entitled "System And Method For Synchronizing Data
In An
Automated Meter Reading Infrastructure," filed November 25, 2007 (TR0024-PRO);
= serial number 60/992,312 entitled "Mesh Network Broadcast," filed December
4, 2007
(TR0027-PRO);
= serial number 60/992,313 entitled "Multi Tree Mesh Networks", filed December
4, 2007
(TR0028-PRO);
= serial number 60/992,315 entitled "Mesh Routing Within a Mesh Network,"
filed
December 4, 2007 (TR0029-PRO);
= serial number 61/025,279 entitled "Point-to-Point Communication within a
Mesh
Network", filed January 31, 2008 (TR0030-PRO);
= serial number 61/025,270 entitled "Application Layer Device Agnostic
Collector
Utilizing Standardized Utility Metering Protocol Such As ANSI C12.22," filed
January
31, 2008 (TRO031-PRO);
2

CA 02705094 2010-05-06
WO 2009/067250 PCT/US2008/013018
= serial number 61/025,276 entitled "System And Method For Real-Time Event
Report
Generation Between Nodes And Head End Server In A Meter Reading Network
Including Form Smart And Dumb Meters," filed January 31, 2008 (TR0032-PRO);
= serial number 61/025,288 entitled "System And Method For False Alert
Filtering Of
Event Messages Within A Network," filed January 31, 2008 (TR0033-PRO);
= serial number 61/025,282 entitled "Method And System for Creating And
Managing
Association And Balancing Of A Mesh Device In A Mesh Network," filed January
31,
2008 (TR0035-PRO);
= serial number 61/025,271 entitled "Method And System for Creating And
Managing
Association And Balancing Of A Mesh Device In A Mesh Network," filed January
31,
2008 (TR0037-PRO);
= serial number 61/025,287 entitled "System And Method For Operating Mesh
Devices In
Multi-Tree Overlapping Mesh Networks", filed January 31, 2008 (TR0038-PRO);
= serial number 61/025,278 entitled "System And Method For Recovering From
Head
End Data Loss And Data Collector Failure In An Automated Meter Reading
Infrastructure," filed January 31, 2008 (TR0039-PRO);
= serial number 61/025,273 entitled "System And Method For Assigning
Checkpoints to
A Plurality Of Network Nodes In Communication With A Device-Agnostic Data
Collector," filed January 31, 2008 (TR0040-PRO);
= serial number 61/025,277 entitled "System And Method For Synchronizing Data
In An
Automated Meter Reading Infrastructure," filed January 31, 2008 (TR0041-PRO);
and
= serial number 61/094,116 entitled "Message Formats and Processes for
Communication
Across a Mesh Network," filed September 4, 2008 (TR0049-PRO).
[0002] This application hereby references and incorporates by reference each
of the
following United States patent applications filed contemporaneously herewith:
3

CA 02705094 2010-05-06
WO 2009/067250 PCT/US2008/013018
= serial number entitled "Point-to-Point Communication within a Mesh
Network", filed November 21, 2008 (TR0004-US);
= serial number entitled "Efficient And Compact Transport Layer And
Model For An Advanced Metering Infrastructure (AMI) Network," filed November
21,
2008 (TR0003-US);
= serial number entitled "Communication and Message Route
Optimization and Messaging in a Mesh Network," filed November 21, 2008 (TR0007-
US);
= serial number entitled "Collector Device and System Utilizing
Standardized Utility Metering Protocol," filed November 21, 2008 (TR0009-US);
= serial number entitled "Method and System for Creating and Managing
Association and Balancing of a Mesh Device in a Mesh Network," filed November
21,
2008 (TR0020-US); and
= serial number entitled "System And Method For Operating Mesh Devices
In Multi-Tree Overlapping Mesh Networks", filed November 21, 2008 (TR0038-US).
TECHNICAL FIELD
[0003] The following relates generally to reporting of events within an
advanced metering
infrastructure and more particularly to verifying the reporting of a power
outage event within
an advanced metering infrastructure.
4

CA 02705094 2010-05-06
WO 2009/067250 PCT/US2008/013018
BACKGROUND OF THE INVENTION
[00041 In conventional AMI systems, the system head end server deduces that a
power
outage has occurred at one or more nodes when it does not receive reports from
the nodes
during a scheduled time window for an expected communication. Nodes do not
monitor their
power supply sources nor do they actively report power outages. Therefore, a
need exists for
an advanced metering infrastructure (AMI), the system measures, collects, and
analyzes usage
of utilities such as electricity, gas, and water, through the use of advanced
metering devices,
two-way communication networks, and data management systems.
SUMMARY OF THE INVENTION
[00051 When a node coupled to a network loses its primary power source and has
a
secondary power source, such as a super-capacitor, the node recognizes and
reports a power
outage. In this case, the head end server may verify the power outage report
by querying
through the downstream nodes coupled to the network about the power outage.
When a node
loses its primary power source and has no secondary power source, it will fail
to make a
regularly scheduled report at the appropriate time. Consequently, the head end
server verifies
the power outage by polling downstream nodes coupled to the HAN about the
power outage
to deduce whether a power outage has occurred. Alternatively, the polling of
devices in the
HAN could be initiated by a meter as soon as the meter perceives an outage,
even before the
meter alerts the head-end, as a cross-check on itself regarding the perceived
outage.
[00061 In one aspect, there is provided a method of confirming a power outage
report
comprising: receiving the power outage report from a first node coupled to a
first network;
querying one or more other nodes coupled to the first network about a power
outage;
receiving one or more responses from the one or more other nodes coupled to
the first
network; and determining whether the power outage report is false based on the
one or more
responses from the one or more other nodes in the first network.
100071 In another aspect, there is provided a system for confirming a power
outage report
comprising: a first node coupled to a first network, wherein the first node
comprises a meter, a
register, and a communications module, and further wherein the first node
transmits the power

CA 02705094 2010-05-06
WO 2009/067250 PCT/US2008/013018
outage report through the first network to a microportal; one or more other
nodes coupled to
the first network; the microportal for relaying the power outage report
through a second
network to a collector; the collector for relaying the power outage report
through a third
network to a head end server; and the head end server for receiving the power
outage report
and querying the one or more other nodes about a power outage.
[0008] In another aspect, there is provided a method of verifying a power
outage
comprising: failing to receive a report from a first node coupled to a first
network at a
prescheduled reporting time window; polling one or more other nodes coupled to
the first
network about a power outage; and determining whether the power outage exists
based on
responses from the one or more other nodes.
[0009] In another aspect, there is provided a system for verifying a power
outage report
comprising: a first node coupled to a first network, wherein the first node
comprises a meter, a
register, and a communications module, and further wherein the first node
fails to transmit a
report at a prescheduled reporting time window to a head end server; the head
end server for
polling one or more other nodes coupled to the first network about a power
outage and
determining whether the power outage exists based on responses from the one or
more other
nodes.
[0010] In another aspect, there is provided a method of recovering
untransmitted
information stored at a node reporting a power outage, comprising: receiving a
power outage
report from the node; transmitting a request to download all untransmitted
information from
the node; and receiving the untransmitted information from the node.
[0011] In another aspect, there is provided a system of recovering
untransmitted information
stored at a node reporting a power outage, comprising: the node receiving for
transmitting a
power outage report; a head end server for: receiving the power outage report;
transmitting a
request to download all untransmitted information from the node; and receiving
the
untransmitted information from the node.
[0012] In another aspect, there is provided a computer program product stored
in a computer
readable media for execution in a processor and memory coupled to the
processor for
performing a method of confirming a power outage report comprising: receiving
the power
6

CA 02705094 2010-05-06
WO 2009/067250 PCT/US2008/013018
outage report from a first node coupled to a first network; querying one or
more other nodes
coupled to the first network about a power outage; and receiving one or more
responses from
the one or more other nodes coupled to the first network; and determining
whether the power
outage report is false based on the one or more responses from the one or more
other nodes in
the first network.
[00131 In another aspect, there is provided a computer program product stored
in a computer
readable media for execution in a processor and memory coupled to the
processor for
performing a method of verifying a power outage comprising: failing to receive
a report from
a first node coupled to a first network at a prescheduled reporting time
window; polling one or
more other nodes coupled to the first network about a power outage; and
determining whether
the power outage exists based on responses from the one or more other nodes.
100141 In another aspect, there is provided a computer program product stored
in a computer
readable media for execution in a processor and memory coupled to the
processor for
performing a method of recovering untransmitted information stored at a node
reporting a
power outage, comprising: receiving a power outage report from the node;
transmitting a
request to download all untransmitted information from the node; and receiving
the
untransmitted information from the node.
[00151 This Summary introduces concepts in a simplified form that are
described more fully
below in the Detailed Description. This Summary is not intended to identify
key or essential
features of the claimed subject matter, nor is it intended to be used to limit
the scope of the
claimed subject matter.
7

CA 02705094 2010-05-06
WO 2009/067250 PCT/US2008/013018
BRIEF DESCRIPTION OF THE DRAWINGS
[0016] Examples of a false alert filtering system and method are illustrated
in the
figures. However, the examples and figures are illustrative rather than
limiting. The false
alert filtering system and method are limited only by the claims.
[0017] FIG. 1 is an illustration showing a non-limiting exemplary embodiment
of a
network topology that may be used in conjunction with aspects of the
invention.
[0018] FIGs. 2A and 2B show two examples of block diagrams of an exemplary
node,
according to an aspect of the invention.
[0019] FIG. 3 shows an example of an electrical block diagram of an exemplary
mesh
gate or collector, according to an aspect of the invention.
[0020] FIG. 4 shows an example of an electrical block diagram of an exemplary
microportal, according to an aspect of the invention.
[00211 FIG. 5 shows an example of an electrical block diagram of a head end
server,
according to an aspect of the invention.
[0022] FIGs. 6A and 6B show two examples of block diagrams of exemplary nodes
including a meter, according to an aspect of the invention.
[0023] FIG. 7 is a flow chart illustrating an example of a method of
downloading new
data not previously downloaded from a smart meter register to a communications
card at the
node, according to an aspect of the invention.
[0024] FIG. 8 is a flow chart illustrating an example of a method of
installing a node,
according to an aspect of the invention.
[0025] FIG. 9 is a flow chart illustrating an example of a method of
associating with a
new collector, according to an aspect of the invention.
[0026] FIG. 10 is a flow chart illustrating an example of a method of pulling
a report
from a dumb meter, according to an aspect of the invention.
[0027] FIG. 11 is a flow chart illustrating an example of a method of pulling
a report
from a smart meter, according to an aspect of the invention.
[0028] FIG. 12 is a flow chart illustrating an example of a method of pulling
data from
a smart meter, according to an aspect of the invention.
8

CA 02705094 2010-05-06
WO 2009/067250 PCT/US2008/013018
[0029] FIG. 13 is a flow chart illustrating an example of a method of pushing
data to a
collector from a node, according to an aspect of the invention.
[0030] FIG. 14 shows an example of a block diagram of a node communicating
with a
collector through a network, according to an aspect of the invention.
[0031] FIG. 15 is a flow chart illustrating an example of a method of
temporally
staggering communications from the nodes to the collector, according to an
aspect of the
invention.
[0032] FIG. 16 is a flow chart illustrating an example of a method of tracking
reports
received by a collector, according to an aspect of the invention.
[0033] FIG. 17 shows examples of a packet data format, according to an aspect
of the
invention.
[0034] FIG. 18 shows an example of a block diagram of a system for
transmitting a
report from a node to a head end server, according to an aspect of the
invention.
[0035] FIG. 19 is a flow chart illustrating an example of a method of
informing a
collector about which category a report falls into, according to an aspect of
the invention.
[0036] FIG. 20 is a flow chart illustrating an example of a method of
temporally
staggering when a collector transmits real-time reports to the head end
server, according to an
aspect of the invention.
[0037] FIG. 21 is a flow chart illustrating an example of a method of
transmitting
reports for batch reporting between a collector and a head end server,
according to an aspect
of the invention.
[0038] FIG. 22 is a flow chart illustrating an example of a method of
recovering lost
reports at a head end server, according to an aspect of the invention.
[0039] FIG. 23 is a flow chart illustrating an example of a method of
recovering
untransmitted information from a removed node.
[0040] FIG. 24 is a flow chart illustrating an example of a method of
detecting a false
power outage report.
[0041] FIG. 25 is a flow chart illustrating an example of a method of
detecting a false
power outage report.
9

CA 02705094 2010-05-06
WO 2009/067250 PCT/US2008/013018
DETAILED DESCRIPTION OF THE INVENTION
[0042] Described in detail below is a system, device, method and computer
program
product to filter power outage reports generated at a node of a Home Area
Network (HAN) or
other network to determine if the power outage is real or not. Various aspects
of the invention
will now be described. The following description provides specific details for
a thorough
understanding and enabling description of these examples. One skilled in the
art will
understand, however, that the invention may be practiced without many of these
details.
Additionally, some well-known structures or functions may not be shown or
described in
detail, so as to avoid unnecessarily obscuring the relevant description.
[0043] The terminology used in the description presented below is intended to
be
interpreted in its broadest reasonable manner, even though it is being used in
conjunction with
a detailed description of certain specific examples of the invention. Certain
terms may even be
emphasized below; however, any terminology intended to be interpreted in any
restricted
manner will be overtly and specifically defined as such in this Detailed
Description section.
[0044] Section headers and/or sub-headers are provided merely to guide the
reader and are
not intended to limit the scope of the invention in any way. Aspects,
features, and elements of
the invention and of embodiments of the invention are described throughout the
written
description and the drawings and claims.
[0045] Exemplary Network Topology
[0046] In accordance with at least one non-limiting embodiment, an advanced
metering
infrastructure (AMI) network may span large geographical areas. In order to
provide
communications between nodes at a utility user's site and the head end server
of the utility
which processes usage data, the AMI may advantageously include, but is not
limited to, the
following elements: a head end server 160, also referred to as a system head
end server,
server, head end, or back end; a wide area network 110; a mesh gate 140, also
referred to as a
NAN-WAN gate or an access point; a neighborhood area network or NAN 120; and a
microportal 150 which may more generically be referred to as a micro access
portal for a
residential premise or a home area network (HAN). A microportal device that is
supported by

CA 02705094 2010-05-06
WO 2009/067250 PCT/US2008/013018
the ZigBee Alliance is referred to as an energy service portal (ESP), however
the ESP utilizes
a different protocol. An AMI network may include one or more of any of these
network
elements, some of which are optional.
[0047] In the example of FIG. 1, one exemplary non-limiting embodiment of an
AMI
network topology 100 is shown. This example of an AMI network includes three
networks
(or sub-networks), a wide area network (WAN) 110, a neighborhood area network
(NAN) 120
sometimes also referred to as a local area network (LAN), and a home area
network (HAN)
130 sometimes also referred to as a premise area network (PAN). The WAN 110
typically
uses TCP/IP communications protocol and provides a way for the head end server
160 to
communicate with the mesh gate 140 or NAN-WAN gate. It may be appreciated that
the head
end server may be one or multiple computers and more usually multiple
computers operating
together to provide capacity and redundancy. The head end server hardware and
connectivity
may be any hardware and connectivity known in the art or convenient. The NAN
120 may
advantageously and typically adhere to IEEE 802.15.4 protocol and provides a
way for a
mesh gate 140 to communicate with NAN-associated nodes 121, 122, 123 in its
sub-network
or microportals 150 that are serviced by the NAN 120; however, other different
protocols may
be utilized. The HAN 130 uses a communications protocol, such as for example a
protocol
established by the ZigBee Alliance and provides communications between a
microportal 150
and HAN-associated nodes 131, 132, 133 that are serviced by the HAN 130. The
ZigBee
Alliance is an association of companies working to enable reliable, cost-
effective, low-power,
wirelessly networked, monitoring and control products based on an open global
standard. The
ZigBee Alliance focuses on defining the network, security, and application
software layers,
providing interoperability and conformance testing specifications, promoting
the ZigBee
brand globally to build market awareness, and managing the evolution of the
technology.
Further information about the ZigBee Alliance may be obtained at
www.zigbee.org/en/about/.
It will be apparent to a person of skill in the art that more nodes (or fewer
nodes) than those
shown in FIG. 1 may be serviced by the NAN and the HAN. In fact, hundreds or
thousands
of nodes may communicate over a single NAN, and this will typically be the
case for actual
AMI infrastructures and systems.
11

CA 02705094 2010-05-06
WO 2009/067250 PCT/US2008/013018
[0048] Various communications protocols may be supported and used by the
elements
of the AMI network 100 to communicate over the WAN 110, the NAN 120, and the
HAN
130. However, it will be appreciated that for purposes of convenience,
specific examples of
communications protocols and standards may be indicated, particularly for
aspects of the
invention relative to a device-agnostic-collector.
[0049] NAN-associated nodes serviced by a NAN 121, 122, 123 communicate with a
mesh gate 140 or NAN-WAN gate through the NAN 120. Nodes may, for example,
include a
utility meter for a residential or commercial site or a utility-measuring
device or a utility
consumption device which includes, but is not limited to, thermostats and
appliances within
the residential or commercial site. FIG. 2 shows two examples of block
diagrams of an
exemplary node. FIG. 2A illustrates a functional block diagram 200A of an
exemplary
generic node, and FIG. 2B illustrates an electrical block diagram 200B of an
exemplary node.
[0050] With reference to FIG. 2A, the block diagram 200A shows three
functional
blocks of an exemplary generic node 121, 122, 123, 131, 132, 133: an
input/output device
210, a table 212, and a communications unit 214. For example, if the node 121,
122, 123,
131, 132, 133 has a utility consumption and/or monitoring device such as a
thermostat, then
the input/output device 210 might comprise a keyboard or keypad for operating
or enabling
different display screens, for selecting different items to display, for
controlling the
thermostat, and for otherwise providing an interaction. Other input/output
devices such as
voice command input and speakers or other human interface devices may
alternatively or
additionally be utilized. Table 212 would correspond to data structures
compiled by the
thermostat based upon temperature readings, and the communications unit 214
would be the
means with which the node communicates with the collector (such as for example
with a
mesh gate) using ANSI C12 protocol or other protocols that may be implemented,
such as a
communications card.
[0051] Alternatively, if the node 121, 122, 123, 131, 132, 133 has a utility
sensing
device such as a utility meter, the input/output device 210 may comprise a
sensor for
detecting utility usage. Table 212 may comprise registers in which the sensor
data is stored,
12

CA 02705094 2010-05-06
WO 2009/067250 PCT/US2008/013018
and communications unit 214 may comprise a communications card by which the
meter at the
node communicates with a collector.
[0052] With reference to FIG. 2B, the electrical block diagram 200B is
representative
of an exemplary node 121, 122, 123, 131, 132, 133 which includes a power
regulator 235, an
energy storage device 240 such as a super-capacitor, a microcontroller 245, a
data
input/output device or module 250, a flash memory 255, a real-time clock 260,
and a radio
265.
[0053] The power regulator 235 may regulate the primary power supply for the
node
as well as the energy provided by the energy storage device 240 which acts as
a temporary
back-up or secondary power supply should the main power supply experience an
outage.
[0054] The energy storage device 240 is a secondary power supply that provides
the
node with least a few extra minutes of power so that it can transmit
previously un-transmitted
reports to the collector. In some embodiments, the node may not include an
energy storage
device 240.
[0055] The energy storage device 240 may be a battery, a capacitor, or a
small,
compact but high capacity super-capacitor. Battery power supplies may be used,
but these are
not advantageous as they have limited lifetimes and would require field
servicing. Capacitors
on the other hand may provide practically unlimited lifetime and provide a
power source that
is sufficient to maintain operation and transmit information to the collector
when charged
even if the normal power is interrupted. In one non-limiting embodiment of the
invention, a
super capacitor has a storage capacity of 50 farads with a starting output
voltage of 2.7 volts
and a physical package that is cylindrical with a diameter of 18 mm and a
length of 40 mm. A
super capacitor of this type is made by NESSCAP Co., Ltd. in Soowon, Korea and
may be
used.
[0056] The microcontroller 245 controls the functions of the node including,
but not
limited to, creating reports from data taken by the sensor, transmitting
reports to the collector,
and responding to queries by the head end server or the collector. The
microcontroller 245
may be implemented as one unit or as a plurality of or several units, with
each unit controlling
one (or even more than one) of the functional aspects of the node when plural
units are
13

CA 02705094 2010-05-06
WO 2009/067250, PCT/US2008/013018
provided, the input/output device 210, the table 212, and the communications
unit 214. Other
non-limiting embodiments may distribute functional aspects of the node to a
plurality of units,
and the division of functions may be in any combination.
[00571 The data input/output device 250 in the electrical block diagram 200B
of FIG.
2B has similar functionality as the input/output device 210 as described for
the functional
block diagram 200A of FIG. 2A.
[00581 The non-volatile flash memory 255 stores reports and other data which
the
node does not want to lose if both the main power supply and any secondary
power supply
should fail including when the capacitor or super-capacitor may not store
sufficient energy to
carry out intended operations.
[00591 If the one or more power supplies to the node should fail, the real-
time clock
260 receiving power from an internal capacitor during this time acts as a
counter to determine
how much time elapsed between the time the power supplies to the node ceased
providing
power until the restoration of power. Consequently, upon restoration of power,
the node can
return to normal operations such as taking data at scheduled intervals and
transmitting reports
to the collector as scheduled. In one embodiment, the real-time clock may
continue to count
and provide information regarding elapsed time for between for up to 14 days
when a 1
microfarad capacitor is employed.
[00601 The radio 265 provides a means by which the NAN-associated node 121,
122,
123 communicates with the collector 140 and other NAN-associated nodes 121,
122, 123
through the NAN using a communications protocol, such as the afore described
IEEE
802.15.4 and ANSI C12 protocols or other regional, international, or ISO
protocols.
Alternatively, the radio 265 provides a means by which the HAN-associated node
131, 132,
133 communicates with the microportal 150 and other HAN-associated nodes 131,
132, 133
through the HAN using a communications protocol, such as the afore described
ZigBee
Alliance protocols or other regional, international, or ISO protocols. The
radio 265 includes
both a transmitter for transmitting data packets and a receiver for receiving
data packets
[00611 FIG. 3 is an illustration showing an example of an electrical block
diagram 300
for an access point such as a NAN-WAN gate and also described as a mesh gate
140 in this
14

CA 02705094 2010-05-06
WO 2009/067250 PCT/US2008/013018
and in related applications. The terms may be used interchangeably. The mesh
gate or NAN-
WAN gate may perform any one or more of many different functions including for
example,
but not limited to, one or any combination of. relaying information from a
server (such as
from a head end server) to the mesh network nodes, routing information,
collecting
information from the nodes and microportals within any sub-network that may be
configured
for transmission to a server (such as to the head end server), acting as a HAN
coordinator,
acting as a NAN-WAN gate, transmitting firmware upgrades, and/or multicasting
messages.
A mesh gate 140 may be referred to herein as a collector when focusing upon
the mesh gate's
collector function because among the mesh gate's many functions, it collects
information from
the NAN-associated nodes 121, 122, 123 and/or microportals 150 in its sub-
network.
[00621. While a second access point's sub-network, such as a second mesh
gate's sub-
network, may overlap the geographical area of a first mesh gate's sub-network,
each node and
microportal is advantageously only associated with a single mesh gate at any
given time,
where association is a relationship that enables communication of information
between two
associated entities and may optionally comport with the ANSI protocols for
association. In at
least one non-limiting embodiment, this or these associations may change over
time. Each
mesh gate's network advantageously operates at a different radio frequency
(RF) from other
mesh gate's networks which may be either overlapping in extent or nearby. The
NAN-
associated nodes 121, 122, 123 communicate with the mesh gate 140 through the
Neighborhood-Area Network (NAN) 120, and the head end server 160 communicates
with
the mesh gate 140 through the Wide-Area Network (WAN) 110.
[00631 Although the example AMI network 100 only shows one mesh gate 140, in
an
alternative, any number of mesh gates 140 may be deployed. The mesh gate 140
may provide
a gateway between the NAN network 120 and the head end server 160.
[00641 The mesh gate 140 includes a central processing unit (CPU) 345 or other
processor or processing logic and coupled memory, a WAN radio 350, a NAN radio
355, at
least one and advantageously multiple communication connections such as
Ethernet
connections 360, Random Access Memory (RAM) 330, flash or other non-volatile
memory
335, a real-time clock 340, an optional power regulator 320 where power
regulation may be

CA 02705094 2010-05-06
WO 2009/067250 PCT/US2008/013018
advantageous, and a battery 325 or other energy storage means. The mesh gate
140
communicates with the NAN-associated nodes 121, 122, 123 and microportal 150
through the
NAN radio 355 using a communications protocol such as IEEE 802.15.4 and ANSI
C12
communications protocol or other protocols as may be implemented.
[0065] The NAN radio 355 includes both a transmitter or other means for
transmitting
data packets and a receiver or other means for receiving data packets.
[0066] The WAN radio 350, which advantageously operates under TCP/IP protocol
but
which may use other standard or non-standard or proprietary protocol, is used
to communicate
with the head end server 160 through the WAN 110. The WAN radio 350 includes
both a
transmitter or other means for transmitting data packets and a receiver or
other means for
receiving data packets. The mesh gate's CPU or other processor or processing
logic 345 runs
applications, such as one or more application functions for making information
queries of data
from the nodes, storing the data received from the nodes in memory, processing
data
aggregated from various nodes, and sending commands and messages from the head
end
server to the nodes, among other functions. The CPU or other processor or
processing logic
345 may communicate with other devices or systems, such as with computers
and/or servers
through the Ethernet or other connections 360.
[0067] The flash or other non-volatile memory 335 stores reports and/or other
data
which the mesh gate 140 does not want to lose if both the main power supply
and any
secondary power supply such as the battery 325 or other storage means should
fail or become
exhausted. The Random Access Memory (RAM) 330 may be a volatile memory storage
used
by and coupled with the CPU or other processor or processing logic 345 as is
known in the
art.
[0068] The power regulator 320 regulates the primary power supply for the mesh
gate
140. If the one or more power supplies to the mesh gate should fail, the real-
time clock 340
acts as a counter to determine how much time elapsed between the time the
power supplies to
the mesh gate ceased providing power until the restoration of power, thus
allowing the mesh
gate to return to normal operations upon restoration of power.
16

CA 02705094 2010-05-06
WO 2009/067250 PCT/US2008/013018
[0069] A mesh gate or collector 140 may be placed at many different locations
including, but not limited to, on a street light, on a telephone pole, at a
socket behind a utility
meter, and/or at virtually any location at which it has access to electrical
power. The collector
140 aggregates and stores information from the NAN-associated nodes 121, 122,
123 and
microportal 150 for transmission to the head end server 160 and also provides
communications between the NAN-associated nodes 121, 122, 123 and microportal
150 and
the head end server 160. Essentially, the last several hundred meters of the
AMI
infrastructure farthest from the head end server 160 and closest to the
utility's customers are
advantageously served and controlled by a collector 140.
[0070] HAN-associated nodes 131, 132, 133, advantageously serviced by the HAN
130, communicate with a microportal 150 through the HAN 130. A microportal 150
is
located between a HAN 130 and a NAN 120 but need not share a node with a
meter.
Microportals 150 typically communicate with the HAN-associated nodes 131, 132,
133 within
the premises (residence or commercial premises) of one customer, and multiple
microportals
may be present within one collector's sub-network. The restriction to a single
premise may be
for reasons of security, regulatory requirements, or for other reasons.
Signals received by a
microportal 150 through the NAN 120 from the collector 140 are distributed to
the
appropriate HAN-associated node through the HAN 130, and signals received by a
microportal 150 through the HAN 130 from the HAN-associated nodes 131, 132,
133 are
distributed to the collector 140 through the NAN 120 for transmission to the
head end server
160. For example, if a utility wants to send a text or other message to a home
display of one
of the utility's users, the head end server 160 sends the text or other
message to the collector
140 on the appropriate sub-network to which the user's home display device is
coupled. The
collector 140 transmits the text message through the NAN 120 to the
appropriate microportal
150 which communicates with the intended recipient of the message. The
microportal 150
will know if one or more displays are present in the home and distribute the
message to those
displays. The locations of the displays in the user's home include, but are
not limited to, a
thermostat or an in-home display device. A thermostat may conveniently be
utilized as at
least one such thermostat may typically be present in every residence or
premises.
17

CA 02705094 2010-05-06
WO 2009/067250 PCT/US2008/013018
[0071] FIG. 4 shows an example of an electrical block diagram 400 of an
exemplary
microportal 150. A microportal is a control device that receives control
commands from the
head end server 160 and/or mesh gate 140 using a first protocol and translates
the control
commands and provides some contextual distribution to the HAN-associated notes
131, 132,
133 in a second protocol. The microportal 150 may include a microcontroller
420, a first
radio such as a ZigBee radio 430, a second radio such as a non-Zigbee radio
such as a mesh
NAN radio (or a WAN radio or a PAN radio) 440, a flash memory or other non-
volatile
memory 450, and a real-time clock 460 or other device for counting or
measuring an elapsed
time. The microportal 150 communicates with the collector 140 through the
second or NAN
radio (or a WAN radio) 440 using IEEE 802.15.4 and ANSI C12 communications
protocol or
other standard communications protocols as may be known in the art. The NAN
radio 440
includes both a transmitter for transmitting data packets and a receiver for
receiving data
packets. The first or ZigBee radio 430, which operates under the first
communications
standards, such as for example the ZigBee Alliance communication standards, is
used to
communicate with HAN-associated nodes 131, 132, 133 coupled to the HAN 130.
The
ZigBee radio 430 includes both a transmitter for transmitting data packets and
a receiver for
receiving data packets.
[0072] It may be appreciated that in one non-limiting embodiment the two radio
configuration may include one Zigbee type radio operating at its radio
frequency and
according to its protocol, as well as a second non-Zigbee radio that operates
over the selected
HAN, NAN, or WAN frequency and protocol.
[0073] The microcontroller 420 runs or executes applications for the
microportal 150
which may include, but are not limited to, transmitting messages from the HAN-
associated
nodes 131, 132, 133 on the HAN 130 to the collector 140, and transmitting
messages from the
collector 140 to HAN-associated nodes 131, 132, 133 on the HAN 130. The flash
or other
non-volatile memory 450 stores reports and other data which the microportal
does not want to
lose if its power supply should fail or become exhausted. If the power supply
should fail, the
real-time clock 460 acts as a counter to determine how much time elapsed
between the time
the power supply to the microportal 150 ceases providing energy or power until
the
18

CA 02705094 2010-05-06
WO 2009/067250 PCT/US2008/013018
restoration of energy or power. Thus, the microportal 150 returns to normal
operations upon
restoration of power.
[00741 In one embodiment, the microportal may share the same location and
primary
power source as a node coupled to the HAN 131, 132, 123, such as a meter or
thermostat for
the residential or commercial site. In this case, a single radio (or so called
single-sided radio)
of the node may be replaced by a dual-radio (also referred to as a two-sided
radio) in order to
convert the node to a microportal without having to write new firmware or
implement new
hardware. The functionality of the microportal at the node is or may be hidden
from the
hosting device and the hosting device need not have this knowledge. A normal
single sided
radio may be replaced by a portal radio (also referred to as a micro access
portal). In one non-
limiting embodiment, the two radios of the dual radio may be on the same side
or on different
sides of a common communication card or circuit PC board. In one non-limiting
embodiment, a portal is a radio plus or in combination with a portal
application processing
logic, processor, or CPU. More generally, a portal, micro-portal, micro access
portal and the
like is a node on the mesh network.
100751 Alternatively, the microportal may be a stand-alone device in a
location
separate from any other node. In this embodiment, the microportal would not
reside
topologically at any of the nodes coupled to the HAN 131, 132, 123. That is,
the microportal
150 would have a different address from all other nodes serviced by the HAN.
Thus, if any of
the HAN-associated nodes coupled to the HAN 131, 132, 133 experiences a power
outage, the
other nodes may still communicate with the collector 140 and head end server
160 through the
microportal 150.
[00761 The head end server 160 of the system is responsible for processing
usage data
received from the NAN-associated and HAN-associated nodes 121, 122, 123, 131,
132, 133
through the collector 140. FIG. 5 shows an example of a functional block
diagram 500 for a
head end server 160. Although the example AMI network 100 only shows one head
end
server 160, in an alternative embodiment, any number of head end servers 160
may be
deployed. For example, the head end servers 160 may be distributed by
geographical location
19

CA 02705094 2010-05-06
WO 2009/067250 PCT/US2008/013018
for shorter communication distances and latency times. Alternatively and in
addition, each
utility accessing the AMI network may have one or more head end servers 160.
[0077] The head end server 160 may be one or a plurality of computing
device(s)
configured to receive information, such as meter readings, from a plurality of
networks 100
and NAN-associated and HAN-associated nodes 121, 122, 123, 131, 132, 133.
Typically the
head end server 160 may be one or multiple computers and more usually multiple
computers
operating together to provide capacity and redundancy. The head end server 160
may also be
configured to transmit instructions to the networks 100, mesh gates 140, and
nodes 121, 122,
123, 131, 132, 133. The head end server 160 includes application programs for
a master relay
520, a key manager 530, a task scheduler 550, a load balancer 560, running a
stack 580, and
other applications 540 which perform typical server functions not required to
enable the
current invention. The head end server 160 also includes a network interface
570. In one
non-limiting embodiment, the network interface 570 may be an Internet
interface.
[0078] In one non-limiting embodiment, the processing logic such as a MCU or
CPU
receives calendar information or data from or through the WAN, HAN, or PAN
side radio
directly or indirectly from the head end server 160. This calendar information
may for
example include dynamic pricing information, demand usage information or data,
or other
information that may pertain to days of the week, hours of the day, and/or
other information
or data that may pertain to utility usage. For example, the information may
specify electricity
pricing on an hour by hour basis for the next 24 hour time period. This
pricing may be
programmed into a time of use calendar. The non-Zigbee side (e.g., WAN, NAN,
PAN side)
implements and understands calendar functionality. The Zigbee side does not
provide such
calendar functionality, and the Zigbee standard is set to a point that it does
not have any
practical ability to be modified to provide such functionality. Furthermore,
the network may
provide an ability to identify and use a multicast address on the mesh
network, such as for
example in a load control application, but Zigbee does not have or understand
the notion of
multi-cast address.
[0079] On the other hand, the Zigbee radio is adapted to communicate with the
Zigbee radio
in the Zigbee devices. The Zigbee side may send messages to Zigbee devices
based on the

CA 02705094 2010-05-06
WO 2009/067250 PCT/US2008/013018
information from the WAN side. Although the Zigbee radio and the non-Zigbee
network
radio (e.g., WAN, HAN, PAN, or the like) are separate radios, they both
interface to or
through a common communications circuit or card so that they may share
information. In one
embodiment, the two radios on a single communications card or circuit share a
same
processing logic unit (such as a MCU or CPU) and in another non-limiting
embodiment, they
have separate processing logic units that communicate with each other through
an interface.
[0080] The master relay 520 stores and keeps track of addresses of nodes
registered
with the head end server 160. The process for registration of a node according
to ANSI
C 12.22 protocol is described below.
[0081] The key manager 530 stores and looks up or queries encryption keys used
to
provide secure communications across the components of the AMI. Different
types of keys
may provide different sets of access rights. For example, a node 121, 122,
123, 131, 132, 133
may encrypt a report which only the head end server 160 has the key to decrypt
the report.
[0082] The task scheduler 550 schedules the launch of applications or scripts
at pre-
defined times or after specific time intervals or according to other
predetermined or
dynamically determined events or conditions.
[0083] The load balancer 560 optimizes resource utilization at the head end
server 160
and although optional is advantageously provided.
[0084] The head end server 160 may also execute many other applications 540
which
are not listed here explicitly.
[0085] The head end server 160 also advantageously has multiple network
interface
connections 570, such as Internet Protocol (IP) based connections 570. These
connections
permit the head end server 160 to communicate with other servers and devices
on the
network, such as over an IP network. Examples of a network interface 570
include, but are
not limited to, modems such as cable, ADSL, or optical, interfaces that
communicate through
wireless frequencies or infrared frequencies, and network interface cards. A
non-limiting
example of a network interface 570 includes a transmitter or means for
transmitting read
requests and write requests, a receiver or means for receiving tables, data
structures, reports,
21

CA 02705094 2010-05-06
WO 2009/067250 PCT/US2008/013018
and other information, cell phone, or WAN radio for communicating with one or
more mesh
gates 140.
[0086] The stack 580 is used to run applications by wrapping data packets in
headers
and trailers and later stripping the headers and trailers used by the layers
of the stack 580.
The headers and trailers adhere to the requirements of the various protocols
used by the layers
of the stack 580.
[0087] An AMI network should advantageously adhere to one or more standards
applicable in the region in which it is operated. In at least one non-limiting
embodiment, the
AMI network in or with which aspects of the invention operate adheres to the
ANSI C 12 suite
of standards. Other embodiments may be configured to adhere to other regional
or
international standards or ISO standards as may be adopted from time to time.
In particular,
ANSI C 12.19 defines and standardizes the contents and formatting of tables of
data, and
ANSI C12.22 establishes the protocol standards which allow transport of table
data over a
reliable network communications system. The ANSI C12 protocol is implemented
at the
application layer and is supported by the transport layer, the mesh layer, and
the data link and
physical layers established under the IEEE 802.15.4 protocol. Specific
reference is made to
the 1997 version of ANSI C12.19 and the 1999 versions of ANSI C12.18 and ANSI
C21, all
in effect as of 2006. In addition, reference is made to the 2008 version of
ANSI C12.11 and
the 2003 and 2006 versions of IEEE 802.15.4. Each of these standards is hereby
incorporated
by reference. It may be appreciated by those workers having ordinary skill in
the art in light
of the description provided here that the invention and embodiments, aspect,
and features of
the invention are not limited to specific standards, though some embodiments
may apply
specifically to such standards, and that the invention and aspects thereof are
compatible with
existing standards as well as enhancements, revisions, and future
modifications of such
standards. One example of another standard that may be used is the IEC
standard.
[0088] Exemplary Types of Node Devices and Meters
[0089] A utility meter collects data about utility usage or consumption at
residential and
commercial customer sites. Examples of utilities from which usage data may be
collected
include electricity, gas, water, and communications services. Usage and/or
consumption may
22

CA 02705094 2010-05-06
WO 2009/067250 PCT/US2008/013018
represent total usage during a period of time, temporal consumption such as
instantaneous
usage of one or more utilities, total consumption during a defined time
period, peak usage,
usage during peak or off-peak times, or any other usage or consumption
information
independent of whether it is of an instantaneous, real-time, cumulative,
pattern, or other
usage.
[00901 In accordance with one non-limiting embodiment, meters are conveniently
categorized as one of two basic categories of utility meters, dumb meters and
smart meters.
FIG. 6A shows a block diagram 600A of a node, also referred to as a node
device, 121, 122,
123, 131, 132, 133 that includes a dumb meter 620. A dumb meter 620 has a
sensor 610 or
other instrumentation which counts or measures the usage of a utility such as
electricity, gas,
or water; a dumb meter 620 does not process any usage data, or at least does
not process any
usage data beyond that processing that might be characterized as a collection
or capture
processing. The data captured by a dumb meter sensor 610 may be stored and
transmitted to a
collector through the use of an external electronics circuit or radio, not
considered part of the
dumb meter, such as may be implemented as one or more printed circuit card or
chips which
may include a register 612 for storage and processing functions and a
communications card or
circuit 614 for communications functions. The register 612 processes
measurements made by
the sensor 610 and stores data structures in the form of lists or tables such
as meter readings,
profiles, and alarms data structure(s). The register 612 also creates ANSI C
12.22 envelope
(or other similar or equivalent proprietary, regional, international, or ISO
standard or protocol
envelope) around the data structures to create a report. The communications
card or circuit
614 transmits the reports using the ANSI C12 protocols (or other protocol) to
the collector for
transmission to the head end server. The reports may be either pulled by the
collector and/or
head end server or pushed by the communications card or circuit 614. A dumb
meter 620 in
combination with the afore described circuits or printed circuit card
containing such circuits
which perform the register 612 and communications 614 functions is referred to
herein as a
node or node device 630 in the advanced metering infrastructure (AMI) network.
Reports
may be either pulled or pushed from a node with a dumb meter. Pulling is
always supported
23

CA 02705094 2010-05-06
WO 2009/067250 PCT/US2008/013018
on demand. Push may also be extended to the system, and may for example be
supported as
an extension to the C 12 standard.
[0091] FIG. 6B shows a block diagram 600B of a node, also referred to as a
node
device, 121, 122, 123, 131, 132, 133 that includes a smart meter 650. Similar
to the dumb
meter sensor 610, a smart meter 650 also has a sensor 640 or other
instrumentation which
counts or measures the usage of a utility such as electricity, gas, or water.
However, in
addition, the smart meter 650 includes a register 642 for processing
measurements made by
the sensor 640 and storing data structures in the form of lists or tables such
as meter readings,
profiles, and alarms data structure(s). An external electronics circuit or
radio 644, not
considered part of the smart meter 650, such as may be implemented as one or
more printed
circuit card or chips may implement communications with a radio, or a receiver
645 or means
for receiving data or reports and a transmitter 645 or a means for
transmitting data or reports,
processing with a processor 646 or means for accessing data structures on
lists stored in the
register 642, and memory 647 or means for storing data. In one non-limiting
embodiment, a
smart meter 650 in combination with a communications card or circuits 644 is
referred to as a
node or node device 660 in the advanced metering infrastructure (AMI) and
affiliated system
and method.
[0092] Moreover, in at least one non-limiting embodiment, a node 121, 122,
123, 131,
132, 133 in the AMI may comprise an electronics card (or equivalent circuits)
in combination
with a utility-consumption or utility-measuring device including, but not
limited to, meters on
larger appliances such as a dishwasher or washing machine, meters on any
device that
consumes energy, or other utilities such as light bulbs, gas stoves or ovens,
and/or
thermostats. These devices may be either dumb, in which case the electronics
card provides
both register and communications functions, or smart, in which case the
electronics card
provides only communications functions.
[0093] A communications card 644 may retrieve data from a smart meter 650, by
advantageously connecting to the meter using the ANSI C12.18 point-to-point
connection
protocols or an equivalent adopted standard for the region, such as an ISO or
other
international standard connection protocol.
24

CA 02705094 2010-05-06
WO 2009/067250 PCT/US2008/013018
[00941 FIG. 7 illustrates an example of a method 700 of downloading new data
not
previously downloaded from a smart meter register 642 to a communications card
644 at the
node. In one exemplary but non-limiting embodiment, at block 710 a typical
smart meter 650
stores in a register 642 four types of lists or tables: a history logger list
or table, an event
logger list or table, a profile list or table, and a self-read list or table.
Other data structures
may alternatively be used and some of these lists, tables, or other data
structures may
optionally but advantageously be used. The history logger list or table
advantageously stores
lists of events including, but not limited to, power quality such as low
voltage, tampering,
hardware diagnostics, and received load control commands. The event logger
list or table
advantageously stores events that may have an impact on the utility bill, such
as power
outages, and is specified by the ANSI C12 protocol. The profile list or table
advantageously
captures different measurements at specific intervals of time. The self-read
list or table
advantageously captures all the information needed to bill a customer, such as
by way of
example but not limitation, the number of kilowatt-hours used at a certain
tiered price and
maximum demand.
[00951 At block 720, for each list or table stored by the smart meter register
642, the
register also advantageously stores a corresponding sequence number. The
sequence number
rules and syntax may be as identified or defined by the ANSI C 12.19 protocols
or other
regional or international protocols. At the installation of a meter, the
sequence number of
each list is set to zero or some other predetermined or dynamically determined
reference or
starting number. A sequence number is incremented by one (or other
predetermined or
dynamically determined increment) when a new piece of data is appended to the
list. The
sequence numbers are advantageously never reset during the life of the smart
meter so that
each sequence number is unique to the life of the meter and not reused.
[00961 Each time the communications card (or equivalent circuits) 644
downloads
data from the smart meter register 642 to memory 647 on the communications
card 644, the
sequence numbers corresponding to the last downloaded data entry of each list
are also
downloaded and stored in memory on the communications card. Thus, at block 730
the
communications card 644 uses its processor 646 to access only the data entries
on each list of

CA 02705094 2010-05-06
WO 2009/067250 PCT/US2008/013018
the register 642 having a sequence number greater than the sequence number
stored
previously in the memory 647 on the communications card 644 for that list. For
example, the
processor 646 may read the sequence number entries for each list and compare
them to the
sequence number previously stored for that list, and when the processor
arrives at a sequence
number greater than the previously stored sequence number, the processor will
access the
corresponding data entries.
[0097] Then at block 740, the communications card 644 uses its receiver 645
and
memory 647 to download and store new data and their corresponding sequence
numbers,
where the new data has not previously been downloaded from the smart meter
register 642.
[0098] Besides storing the sequence numbers for each list stored by the smart
meter
register 642, the communications card 644 also needs to know the table (or
other data
structure) identification number which identifies the type of table and the
frequency at which
the smart meter captures the data for that particular table. The information
is stored in the
smart meter register 642. At block 750, the communications card 644 downloads
this
information.
[0099] At block 760, a smart meter may also store data structures that are not
list-
based or table-based, for example, such data structures may include or store
statistics, Global
Positioning System (GPS) location of the meter, configuration information, or
combinations
of any two or more of these or other information.
[00100] In one embodiment, after the communications card 644 downloads data
from
the smart meter register 642, a processor on the communications card 644
creates an ANSI
C 12.22 envelope (or other similar or equivalent proprietary, regional,
international, or ISO
standard or protocol envelope) around the data to create a report. Reports may
include, but
are not limited to, identification information, status of the node such as low
battery, detection
of tampering at the node, power failures, power quality, and leakage;
configuration of the
meter; data formatting information, utility meter readings, consumption
statistics, and a
profile of the interval period at which utility readings are stored. The node
660 may push the
reports to the system head end server 160 for processing through a collector
140.
26

CA 02705094 2010-05-06
WO 2009/067250 PCT/US2008/013018
Alternatively, the head end server 160 and/or the collector 140 may pull the
reports from the
node 660.
[00101] In one embodiment, after the communications card 644 downloads data
from
the smart meter register 642, the communications card 644 does not have the
ability to create
a report from the data. Thus, the collector and/or the head end server would
pull the
information from the communications card 644, rather than having the
communications card
push the data to the collector and/or the head end server. The process of
pulling the data from
the communications card 644 follows conventional ANSI C 12 Protocol
Specification for
Electric Metering (PSEM).
[00102] Installation of Nodes
[00103] Prior to joining an AMI network and transmitting data, a node must
undergo an
installation procedure as specified by ANSI C 12 protocols (or other protocol)
and briefly
described here. FIG. 8 illustrates an example procedure 800 for installing a
new node.
[00104] In one non-limiting embodiment of an installation procedure, at block
810 the
node is initially provided the option of engaging in a commissioning
communication with the
commissioning server at the system head end server 160. The content of the
commissioning
communication depends on the type of device at the node, for example, a meter
or a
thermostat, the data structures supported by the node, and the utility-owner
of the node. Thus,
a thermostat may dump or upload its control schedule to the head end server
160 during the
commissioning communication.
[00105] The next step in the installation procedure is association of the node
with a
new collector at block 820. A mesh network is a wireless network configured to
route data
between nodes within a network. It allows for continuous connections and
reconfigurations
around broken or blocked paths by retransmitting messages from node to node
until a
destination is reached. Mesh networks differ from other networks in that the
component parts
can all connect to each other via multiple hops. Thus, mesh networks are self-
healing: the
network remains operational when a node or a connection fails. A mesh network
may be used
to implement any of the WAN 110, NAN 120, and HAN 130 networks within an AMI
network 100. For convenience, a mesh network may be referred to here simply as
either a
27

CA 02705094 2010-05-06
WO 2009/067250 PCT/US2008/013018
network or sub-network. The association of the node with a new collector at
block 820 is
described in greater detail in FIG. 9 and the text associated with FIG. 9.
1001061 Following the association of the node with a new collector at block
820, the next
step in the installation of a node is registration according to an applicable
protocol
specification, such as for example an ANSI C 12.22 registration according to
the ANSI C 12.22
protocol specification. The node transmits registration information in a
simple ANSI C 12.22
registration message to the collector, and the collector transmits the
information to the master
relay which includes a routing table for tracking all of the C 12.22 nodes
registered to a
C 12.22 network service provider.
1001071 After the registration step, at block 830 of the example procedure 800
for
installing a new node, the master relay notifies the head end server 160 that
there is a new
node 121, 122, 123, 131, 132, 133 on the network 100 and that the node has
been registered
according to the applicable protocol specification such as according to the
ANSI C 12.22
protocol specification.
[001081 Finally, at block 840 the installation procedure concludes with an
initial
communication from the server to the node, requesting static information.
Static information
encompasses information related to the node which does not change and thus
does not need to
be transmitted to the head end server during future data transmissions. Static
information may
include, but is not limited to, the type of measurements that the meter at the
node will make,
the frequency at which the meter will make the measurements, the
identification number of
the meter, and/or any information that may be located on the nameplate of the
meter.
[001091 The installation procedure serves to inform the network of the
presence of the
node, and the data collection process may proceed upon successful completion
of the
installation process.
[001101 FIG. 9 illustrates in greater detail an example node to new-collector
association
procedure 900 for associating a node with a new collector as referenced in
step 820 of FIG. 8.
After association, the node may utilize the new collector and the new
collector's sub-network
to communicate sensor readings and receive instructions or commands.
28

CA 02705094 2010-05-06
WO 2009/067250 PCT/US2008/013018
[00111] At block 910, the node may use a receiver or radio means 265 to detect
active
networks within radio range and collecting information on each. For example,
the node may
determine a signal strength for a particular transmission frequency, a network
name, a
supported version number of each network. The active networks may be compiled
in a list by
a processor or microcontroller 245 in memory 255.
[00112] Each network may be associated with a collector and may periodically
broadcast a banner or other information containing a network name and a
network identifier.
The node may attempt to receive and parse or interpret the banner in order to
determine
nearby networks having a minimum signal strength. In one non-limiting example,
only the
collector may broadcast the banner, but each node within the network may
forward the
banner. In this way, nodes outside direct radio range of the collector may
still participate in
the network through nearby neighbors.
[00113] At block 920, the node may use its microcontroller 245 to select a
prospective
collector with which to associate based upon the information acquired at block
910 about
active networks. From the list of networks collected above, the node may parse
the network
name for a network prefix, network suffix, or other identifier. The network
prefix may
determine, in part, services offered by the network. Alternatively, the
network prefix may
determine a provider of the network. Based on the services offered or a
registered provider of
anetwork, the node may select the prospective network.
[00114] The node may further select the prospective collector based on a
signal
strength. A strong signal may be preferred over a weak signal. The node may
further select
the prospective collector based on a supported version number. It will be
appreciated that the
node may be outside direct radio range of the collector. However,
communications may be
forwarded through neighboring nodes in accordance with network protocols.
[00115] At block 930, the node may transmit a neighbor request to the
prospective
collector selected above. The neighbor request may include a node identifier
and relevant
meter status and be transmitted to the collector associated with the network.
For example, the
meter status may include a list of sensors provided by the node and services
requested by the
node. A schedule of supported sensor reading transmission may be transmitted,
for example,
29

CA 02705094 2010-05-06
WO 2009/067250 PCT/US2008/013018
indicating whether the node will transmit sensor readings every minute, every
hour, every
day, or according to some other predetermined or dynamically determined
schedule or the
like, and any blackout periods.
[00116] As described above, if the node is not in direct radio range of the
collector, the
communications may be forwarded or relayed through the network. The node may
first
transmit to a neighboring node, which then forwards or relays the
communication on. It will
be appreciated that the above sub-process may be executed automatically on
power-up or
upon collector failure of the collector currently associated with the node. No
further input
from a user may be required.
[00117] At block 940, the node may receive a neighbor response. Responsive to
receiving the neighbor request from the node, the collector may compile or
assemble and
transmit the neighbor response via the network. The neighbor response may
provide
information to the node regarding associating with the prospective network.
[00118] For example, the neighbor response may include a next hop to the
collector, a
number of hops to the collector, a path quality, a collector load, a router
load, or some
combination of these. A next hop to the collector may describe the next node
on the path to
the collector. A path quality may be an indicator indicating a signal quality
of the path to the
collector. A collector load may indicate remaining capacity at the collector.
A router load
may indicate remaining capacity at a node next on the path to the collector,
if the node is not
in direct radio range with the collector and forwarding is required.
[00119] At block 950, the node may transmit an association request to the
collector via
the network. The association request may indicate a node's desire to associate
with the
prospective network selected above. For example, the association request may
further include
a node identifier.
[00120] At block 960, the node may test whether an association response was
received.
Responsive to receiving the association request from the node, the collector
may associate the
node with the network and transmit an association response. Similar to above,
the association
response may be forwarded through the network.

CA 02705094 2010-05-06
WO 2009/067250 PCT/US2008/013018
[00121] For example, the collector may check a collector load factor before
allowing
the node to associate. The collector may also authenticate the node before
allowing the node
to associate. For example, the node may transmit an authentication key
verifying its identity.
For example, the collector may look up the node table at a server or in a look
up table or in
another data structure to verify the node is authorized to associate.
[00122] At block 970, the node may associate with the network; thus, the node
may
transmit reports and data to the head end server via the new collector and
also receive
messages from the head end server. The node may update an internal neighbor
table with a
network identifier, a network name, and neighbor information such as a next
hop and a
number of hops to the collector. In this context a hop is a transmission of a
message from one
node to another node until a destination, the collector, is reached.
[00123] Future communications may be transmitted to the next hop, a nearby
neighboring node in the network. After the node is associated with the
network, it may act as
a neighboring node for another new node searching for a network to associate
with.
[00124] It will be appreciated that in the absence of an associated network,
the node
may continue to store sensor readings for future transmission.
[00125] Transferring Data from the Node to the Collector
[00126] When reports or data are transferred from the node to the collector
through a
pull process, the collector must know what type of information to retrieve and
the type of
meter from which the information is being retrieved. The node merely operates
as a server of
data acquired at its location. The collector runs a specific application
program to pull
information from a specific kind of meter and to read the specific data
structures used by the
meter.
[00127] FIG. 10 illustrates a first example Dumb Meter Node-to-Collector data
pull
procedure 1000 for transferring data from a node to a collector using a first
pull scenario. In
the first scenario, the collector 140 pulls a report from a node 630 with a
dumb meter 620.
The collector 140 uses a radio 355, a transmitter, or other transmission means
to transmit a
pull request at block 1010 to the node 630. At block 1020, a report is created
at the register
31

CA 02705094 2010-05-06
WO 2009/067250 PCT/US2008/013018
612 at the node 630. At block 1030, the communications card 614 transmits the
report to the
collector 140 using a radio 265, a transmitter, or other transmission means.
[00128] FIG. 11 illustrates a second example Smart Meter Node-to-Collector
data pull
procedure 1100 for transferring data from a node to a collector using a second
pull scenario in
which the collector 140 pulls a report from a node 660 with a smart meter 650,
where the
node 660 is capable of creating a report. The collector 140 transmits a pull
request at block
1110 to the node 660. At block 1120, the communications card 644 downloads the
data from
the register 642 of the smart meter 650 as detailed above by procedure 700 in
FIG. 7. At
block 1130, the communications card 644 creates the report from the data. The
communications card 644 then transmits the report to the collector 140 at
block 1140.
[00129] FIG. 12 illustrates a third example Alternative Smart Meter Node-to-
Collector
data pull procedure 1200 for transferring data from a node to a collector
using a third pull
scenario that also involves a smart meter, but where the smart meter does not
have the ability
to create a report so the device-agnostic collector pulls the data and creates
the report for the
meter. The collector 140 transmits a pull request at block 1210 to the node
660. At block
1220, the data structures from the register 642 in the smart meter 650 are
downloaded to the
communications card 644. At block 1230, the communications card 644 transmits
the data
structures to the collector 140. The CPU 345 of the collector 140 then creates
the report from
the data structures at block 1240, where a report includes an envelope or
.container for the data
structures, such as an ANSI C12.22 envelope around the data structures.
[00130] Reports created by the collector or pulled by the collector from the
node are
subsequently transmitted to the head end server by the collector.
Alternatively, the head end
server may send a pull data command to the collector, rather than having the
collector initiate
a pull request. In this case, the collector could either pull data from all
nodes from its sub-
network or could pull data from a particular node specified by the head end
server. One
specific example in which data is pulled by the head end server is an on-
demand response,
where only data is sent rather than an entire report. An exemplary process by
which the
collector transmits the reports to the head end server is described in more
detail below in the
section entitled, "Three Step Synchronization Between Head End Server and
Collector."
32

CA 02705094 2010-05-06
WO 2009/067250 PCT/US2008/013018
[001311 In contrast to a pull process, a push process occurs when a node
initiates
transmission of reports or data to the collector and/or the head end server.
Recall that a report
may consist of data plus an envelope for that data. The envelope may include
such
information as security information, sequence information, address
information, etc. A node
may be configured to actively initiate transmission of data or a report to a
collector and/or
head end server rather than merely responding to a pull request for
information. The collector
that receives data or reports pushed from a node should be capable of
receiving unsolicited
transmissions initiated by the node, regardless of the type of meter at the
node or the type of
data structures transmitted by the node. Consequently, this type of collector
may be termed a
meter-agnostic, data structure-agnostic, or device-agnostic collector. Because
some nodes
may not have the ability to push information, a device-agnostic collector may
also
advantageously need to be capable of both pulling data or reports from one
node as well as
receiving pushed data or reports from another node. More details on the push
process are
provided below in the section entitled, "Pushing Reports from the Node to the
Collector."
These various agnostic capabilities are referred to by the general phrase
device-agnostic.
[001321 One of the functions of at least some mesh gates may be the collector
function.
Every valid message read is stored in a First-In-First-Out (FIFO) buffer (or
other buffer as are
known in the art) The head end server 160 has a protocol for head end
synchronization with a
collector. There is provided an address list, and the head end sends the
actual sequence
number for each address, so that based on the sequence number the mesh gate
will only
transfer new reports.
[001331 FIG. 13 is a flow chart illustrating an example 1300 of a method of
pushing
data to a collector from a node, according to an aspect of the invention. A
node may push
information to a device-agnostic collector according to various policies or
criteria.
[001341 At block 1310, a node device collects data through an input device.
For
example, profiler data monitors consumption of a utility, such as for example,
voltage drop or
variation over time due to electricity usage or quantity (e.g. cubic feet) of
water consumed.
The profiler data is measured and collected at regular intervals, such as
every hour.
33

CA 02705094 2010-05-06
WO 2009/067250 PCT/US2008/013018
[00135] After the data is collected, at block 1320, the data is stored in
memory. For the
profiler data example, the profiler data is dumped or stored into a block of
memory. A block
is the repository for data collected at known, regular intervals. The block is
an efficiency
mechanism which does not require a time stamp to be included at each data
capture because
each time data is sent to the block is known.
[00136] At block 1330, a report is created by the node's processor from the
data. For
the profiler data example above, when the block is full, a report is created,
and the report is
appended to the node's reporting list.
[00137] At block 1340, the node transmits the reports on the reporting list to
the
collector at the next scheduled reporting time window by using a radio,
transmitter, or other
transmission means.
[00138] In the profiler data example above, the node pushed information to the
collector when the information was created. A node may also push information
on a schedule
such as the accumulation of statistics relating to energy usage. At
appropriate pre-
programmed intervals, the node transmits the data packet to the device-
agnostic collector.
The device-agnostic collector receives the data packet and forwards the data
packet to the
head end server. Additional description is provided herein elsewhere relative
to particular
batch reporting and real time reporting.
[00139] A device-agnostic collector does not need any knowledge about the
particular
type of meter or utility-consumption device at the node pushing the data and
reports nor the
particular data structure used by the node. Consequently, new metering devices
capable of
pushing information may be installed onto a network, but the device-agnostic
collector does
not need to upgrade its database to include information about the new type of
meter. As
discussed in more detail below in the section "Pushing Reports from the Node
to the
Collector," the node addresses data packets to be processed in a particular
manner to certain
pre-assigned collector ports, and the collector processes the data packets
according to the port
that the packet arrives at. In contrast, if a collector were required to pull
information from a
new type of metering device, the collector would need a specific driver or
other specific
application for each type of meter and update the driver for each new
revision, adding
34

CA 02705094 2010-05-06
WO 2009/067250 PCT/US2008/013018
complexity to the collector. The device-agnostic collector also does not need
to understand
any special data structures pushed by a node because the collector does not
read the contents
of the data packet, only the header on the data packet. A node capable of
initiating a
transmission will push the data using conventional data structures as
established by the
applicable protocol implemented, such as the ANSI C 12 protocol. A report is
created when a
package, container, or envelope are created around the data structure, such as
for example,
when the ANSI C12 envelope is created around the data structure. Reports that
can be pushed
by a node may include, but are not limited to, identification information,
status of the node
such as low battery, detection of tampering at the node, power failures, power
quality, and
leakage; configuration of the meter; data formatting information, utility
meter readings,
consumption statistics, and a profile of the interval period at which utility
readings are stored.
One or more of these reports are captured at the appropriate interval for that
particular data
structure and then appended to a reporting list stored at the node. The
processor,
microcontroller 245, or other means creates a reporting list in memory 225,
and newly created
reports are appended by the processor, microcontroller 245, or other means to
the reporting
list. The reporting list is then transmitted by the node one report at a time,
addressed to the
appropriate device-agnostic collector port at preprogrammed intervals and/or
according to
other policies or rules. Thus, the processor or microcontroller 245 uses the
reporting list to
keep track of the new reports that need to be transmitted to the collector.
1001401 In accordance with one non-limiting embodiment, for security purposes,
the
data structures in the data packet from the node are advantageously encrypted
with a data key
which the device-agnostic collector is not able to decrypt. Only the head end
server is able to
decrypt the data from the nodes. Thus, the manner in which the device-agnostic
collector
responds to a data packet, whether received from a node or from the head end
server, may
depend upon which port of the device-agnostic collector the data packet is
addressed to rather
than the content of the data packet.
[001411 The device-agnostic collector's ports may be reserved according to the
type of
response expected from the collector including, but not limited to, forwarding
the data packet
from the node to the head end server without processing the data packet,
capturing and

CA 02705094 2010-05-06
WO 2009/067250 PCT/US2008/013018
aggregating the data prior to forwarding batched data from multiple nodes to
the head end
server, and forwarding registration information from the node to the head end
server. Thus, a
node pushing data or a report in a data packet to a device-agnostic collector
must address the
data packet to the appropriate pre-assigned port of the collector.
[00142] The pulling or pushing of data advantageously occurs at the
application layer
level in the AMI network. As established by the IEEE 802.15.4 protocols, the
application
layer is supported by the underlying layers, the transport layer, the data
link layer, and the
physical layer. Layer boundaries are somewhat flexible and elastic so that the
data pushing or
pulling may not strictly be limited to a particular layer.
[00143] Collision Avoidance-Transmitting Packets From Node To Collector
[00144] In an AMI network 100, a collector 140 may be required to service up
to and
more than thousands of different nodes 121, 122, 123, 131, 132, 133. Nodes in
any particular
sub-network 120, 130 may be programmed to record meter data at the same time,
for example
every hour on the hour. If data is pulled from the nodes on a collector's sub-
network by the
collector 140 or head end server 160, collision of data on the NAN 120 is
minimized because
each node responds with data packets 600A recorded at the hour only when
queried by the
collector 140. However, if the nodes in a sub-network push the recorded data
to a collector
during a pre-scheduled time window, thousands of data packets may be
transmitted
simultaneously, resulting in multiple collisions. Although the IEEE 802.15.4
MAC layer
implements carrier sense multiple access (CSMA) for handling collisions, the
MAC layer is
only capable of typically handling no more than approximately five nodes
transmitting
simultaneously.
[00145] FIG. 14 shows an example of a block diagram 1400 of a node
communicating
with a collector through a network, according to an aspect of the invention.
The node 1410
includes a radio 1420 and a microcontroller 1430. The radio includes a
transmitter or other
means for transmitting data packets and a receiver or other means for
receiving an
acknowledgment from the collector 1450. The microcontroller 1430 has a
software module
1440, substantially random time slot generator, or other means for generating
one or more
random or substantially random time slots within a pre-scheduled reporting
time window.
36

CA 02705094 2010-05-06
WO 2009/067250 PCT/US2008/013018
The microcontroller 1430 also has another software module 1442 or other means
for seeking a
new collector.
[00146] The node 1410 transmits data packets to a collector 1450 through a
network
1470. The collector includes a radio 1460 or other receiving means for
receiving the data
packets received from the node 1410 and transmission means for transmitting
and
acknowledgment after receipt of each data packet from the nodes.
[00147] FIG. 15 illustrates an example solution 1500 for handling a situation
where
even staggered transmission times for each node may still result in
collisions. At block 1510,
a random or substantially random time slot within a pre-scheduled reporting
time window is
generated for each of the nodes. While the generation of random time slots
within a reporting
time window for each node would be ideal in minimizing the collision of
transmissions from
the nodes to the collector, the assignment of substantially random time slots
would suffice
provided the substantially random slots do not permit more than approximately
five nodes to
transmit simultaneously. These time slots within the prescheduled reporting
time window are
referred to as checkpoints for the nodes. At block 1520, each node transmits
its reports as
data packets to the collector 140 during its checkpoint. Each node uses a
radio 265,
transmitter, or transmission means to transmit the data packets. The result is
that data packets
sent from the different nodes to the collector are transmitted in a temporally
staggered manner
over prescheduled reporting time window rather than being transmitted
simultaneously.
[00148] Checkpoints may be generated by nodes and there is also an option for
a mesh gate
to trigger the generation of a checkpoint. Using a mesh gate to trigger
checkpoint generation
may be advantageous because the mesh gate may typically be in a better
position to control
collisions, but may sometimes have the somewhat disadvantageous effect of
creating more
message traffic. Either or both checkpoint generation schemes may be utilized
depending
upon the tradeoffs. Furthermore, if a tree is broken, the node needs to
initiate the checkpoint
generation because under these conditions, the mesh gate cannot read back to
the node. In
one non-limiting example, the node initialization of a checkpoint serves as a
backup update
routing information for the mesh gate. A node can normally always find a mesh
gate but the
mesh gate may not always find a node.
37

CA 02705094 2010-05-06
WO 2009/067250 PCT/US2008/013018
[00149] At block 1530, the collector transmits an acknowledgement to each node
if the
collector received a data packet from that node. The collector uses a radio
355, receiver, or
receiver means for receiving data packets and a radio 355, transmitter, or
transmission means
to transmit the acknowledgement.
[00150] At decision block 1540, each node uses a radio, receiver; or receiver
means for
checking whether it has received an acknowledgement from the collector if it
sent a data
packet. If each node that sent a data packet to the collector received an
acknowledgement
(block 1540 - Yes), the process ends at block 1570. The data packet may not
reach the
collector, or an acknowledgement may not be received by the transmitting node
for a variety
of reasons including, but not limited to, interference at the RF frequency of
transmission and
collisions with another packet. If the data packet does not arrive at its
destination, as
indicated by the lack of an acknowledgment from the collector, the transport
and MAC layers
may attempt to retransmit the packet. If the transport and MAC layers are not
successful in
re-transmitting the packet, in one embodiment, the node may be configured to
re-transmit the
packet to the collector again before the next scheduled reporting time window.
Thus, if at
least one node did not receive an acknowledgment from the collector after
transmitting a data
packet (block 1540 - No), at block 1550 a second random or substantially
random time slot
within a pre-scheduled re-try time window may be assigned to the
unacknowledged nodes.
The re-try time window may or may not be the same as the prescheduled
reporting time
window used at block 1510 above. At block 1560, each unacknowledged node
transmits its
report to the collector again during its second assigned checkpoint. The
process ends at block
1570.
[00151] In one embodiment, if there are nodes that did not receive an
acknowledgement, these nodes may be configured to wait until the next
scheduled reporting
time window before re-transmitting the packet.
[00152] Any algorithm which implements an effective randomization or pseudo-
randomization of transmission times for the nodes in a collector's sub-network
is suitable.
One example of a randomization algorithm or procedure is presented here.
38

CA 02705094 2010-05-06
WO 2009/067250 PCT/US2008/013018
[00153] Under the IEEE 802.15.4 protocol, 16-bit addresses are assigned to
each meter
sequentially by the mesh gate or coordinator. As described in the IEEE
802.15.4 protocol, a
coordinator implements a general model of communication which allows it to
talk to any
other device and also relays messages. The mesh gate 140 performs the
functions of the
coordinator in the example network topology in FIG. 1.
[00154] Bits one through seven of the address are used to represent bits seven
through
thirteen of the generated random number. Bits one through seven of the meter
manufacturer's
serial number and bits one through seven of the actual meter reading are used
in computing
bits one through seven of the generated random number. Bits one through six of
the
generated random number are obtained by performing an exclusive OR operation
on the first
six bits of the meter's serial number and the first six bits of the actual
meter reading. Bit
seven is obtained by performing an exclusive OR operation on the seventh bit
of the meter's
serial number, the seventh bit of the actual meter reading, and bit one of the
16-bit address.
Bits eight through thirteen correspond respectively to bits two through seven
of the 16-bit
address. The generated random number has thirteen bits; thus it represents a
number between
0 and 8191. This generated random number is multiplied by the total time
window allowed
for the transmission of all the nodes in a collector's sub-network and then
divided by 8191 for
scaling. The resulting value is the time during the window at which a node is
assigned to
transmit its data packet during the time window.
[00155] Alternatively, a random or substantially random time slot or number
generator
may be used to generate the times at which each node is permitted to initiate
transmissions to
the collector, and the time slot or number generator may be performed by a
processor or
microcontroller 245 running an algorithm.
[00156] Last-Transferred-Pointer
[00157] A NAN-associated node 121, 122, 123 may lose communications with its
servicing collector 140 for a variety of reasons including network outages.
However, each of
the reports stored at the node on the reporting list remain in queue on the
reporting list in flash
memory, even during a network or power outage. The reporting list is a
circular buffer that
advantageously uses a first-in first-out protocol. Typically, the reporting
list can store
39

CA 02705094 2010-05-06
WO 2009/067250 PCT/US2008/013018
approximately one year of data, but different size buffers may be used to
store different
durations or quantities of data. A person skilled in the art will understand
that an arbitrary
amount of data may be stored on the reporting list.
[00158] The node implements a last-transferred-pointer in conjunction with the
reporting list. FIG. 16 illustrates an example procedure 1600 for using the
last-transferred-
pointer. The last-transferred-pointer is a programming language data type
stored in memory
255 whose value points to or flags the address in memory 255 of the last
report on the
reporting list that was acknowledged as having been received by the collector.
The report
pointed to by the last-transferred-pointer may be referred to as the flagged
report. The report
to be transmitted next is the one immediately following the flagged report.
[00159] At block 1602, a node creates one or more reports using a processor.
At block
1604, the node appends the one or more reports to a reporting list in a
memory.
[00160] At block 1610, at a node's assigned checkpoint, the node uses a radio
265,
transmitter, or transmitter means to transmit one report in the form of a data
packet from the
reporting list to the collector. If the collector receives the data packet, it
will send an
acknowledgment to the node.
[00161] The node uses a radio 265, receiver, or receiver means to check at
decision block
1620 for an acknowledgment generated and sent by the CPU 345 of the collector.
If a report
transmission is not acknowledged (block 1620 - No), the node does not
increment the
position of the last-transferred-pointer and re-transmits the same report at
the appropriate re-
transmission time at block 1610. If the report is acknowledged (block 1620 -
Yes), at block
1630 the node updates the last-transferred-pointer by using a processor or
microcontroller 245
to increment the last-transferred-pointer stored in memory 255 to point to the
report just
transmitted and acknowledged. At decision block 1640, the node decides whether
there are
more reports to transmit to the collector. If the node has more reports to
transmit to the
collector (block 1640 - Yes), it starts the process from block 1610. Otherwise
(block 1640 -
No), the process ends at block 1650.
[00162] There are two situations which will cause a node to not receive an
acknowledgement. In the first situation, the report transmitted by the node is
not received by

CA 02705094 2010-05-06
WO 2009/067250 PCT/US2008/013018
the collector. When an acknowledgement is not received, the transport and MAC
layers first
attempt to re-transmit the report. If the transport and MAC layers are not
successful in re-
transmitting the report, the node may be configured to re-transmit the report
to the collector
again before the next scheduled checkpoint. Alternatively, the node may be
configured to
wait until the next checkpoint before re-transmitting the report. In either
case, the node will
know which report to re-transmit because it is the report immediately
following the one that
the last-transferred-pointer is pointing to on the reporting list. Using the
last-transferred-
pointer scheme, the node automatically knows which reports have been
acknowledged and do
not need to be re-transmitted.
[001631 In the second situation, a report transmitted by the node was actually
received
by the collector, but the acknowledgement from the collector was not received
by the node.
Because the collector actually did receive the transmission, the collector's
memory buffer has
already been updated with the report from the node. However, if an
acknowledgement is not
received by the node, the transport and MAC layers first attempt to re-
transmit the report. If
the transport and MAC layers are not successful in re-transmitting the report,
the node may be
configured to re-transmit the report to the collector again before the next
scheduled
checkpoint. Alternatively, the node may be configured to wait until the next
checkpoint
before re-transmitting the report. In either case, the node will re-transmit
the same report
because it is the report immediately following the report pointed to by the
last-transferred-
pointer. When the collector receives the new transmission, it will re-
acknowledge the receipt
of the report but will discard the duplicate report which has been sent twice
by the node.
Upon receipt of the acknowledgement, the node will update the last-transferred-
pointer to
point to the last report acknowledged by the collector.
[001641 In a network which implements data pulling, should a collector fail
permanently for any reason such as software or hardware failure, the system
head end server
should direct another collector to take over for the failed collector.
However, in a network in
which nodes push data and reports to the collector, the nodes are autonomous
and will seek
another collector and its associated sub-network on its own and start
transmitting reports
and/or data to the new collector as discussed above. No reports will be lost
due to the failed
41

CA 02705094 2010-05-06
WO 2009/067250 PCT/US2008/013018
collector because a node will transmit its reporting list starting from the
next report after the
one flagged by the last-transferred-pointer.
[00165] Pushing Reports from the Node to the Collector
[00166] There are multiple ways for a NAN-associated node 121, 122, 123 to
push
reports to the head end server 160 through the collector 140. Examples of non-
limiting ways
to push reports include, but are not limited to, (i) batch reporting, and (ii)
real-time reporting.
In accordance with one non-limiting embodiment, most reports are sent through
batch
reporting, for example, interval data and work files. The reports which are
batched are
typically reports not required urgently so they are batched for efficiency.
Batch reporting
makes maximum use of the data packets sent across the network by minimizing
the amount of
traffic transmitted. Real-time reporting is advantageously reserved for data
which may be
needed urgently by the head end server, for example, a meter tamper alert,
power outage
management events, and feedback from network load control devices like
switches.
[00167] With both methods of reporting, NAN-associated nodes 121, 122, 123
first
transmit data packets to the collector 140. The node alerts the collector as
to the type of
report being sent by addressing a particular port of the collector in the
header of the data
packet. One non-limiting embodiment of the format of a data packet 1700A,
including header
formatting, is shown in FIG. 17. The packet 1700A may be composed of an IEEE
802.15.4
MAC header 1710, a layer header such as a Trilliant (Trilliant Networks, Inc.,
1100 Island
Drive, Redwood City, CA 94065) mesh layer header 1712, a transport header such
as a
Trilliant mesh transport (TIP) header 1714, an application layer header 1716,
and an
application payload 1718 such as a report. Each of the headers for the
individual layers is
used by the respective stack layer for transmitting the packet to its
destination.
[00168] The collector port addressed by the node when transmitting a report
resides in
the transport TIP header 1714. When the transport header is the TIP transport
header, the TIP
header 1714 contains the fields 1700B shown in FIG. 17 which includes flags
1720, a packet
sequence number 1722, a last received sequence number 1724, and an extension
field 1726.
In one non-limiting embodiment, the extension field 1726 is an eight-bit
field. Bits 7 through
42

CA 02705094 2010-05-06
WO 2009/067250 PCT/US2008/013018
are used to indicate the type of extension, for example TIP communication or
intra-TIP
communication.
[00169] When the extension type is set to "intra TIP communication", the
extension
field structure 17000 shown in FIG. 17 is used, including a source port number
field 1730 and
a destination port number field 1732. The eight bits of the extension field
1726 is divided
between the source port number comprising bits 7 through 4 and the destination
number
comprising bits 0 through 3. When the node transmits a report to the
collector, it is the source
port number field which contains the particular collector port being
addressed. The relevant
details of the header which the collector needs to know, such as the addressed
port, are made
available to the collector by the operating system.
[00170] FIG. 18 shows an example of a block diagram 1800 of a system for
transmitting a report from a node to a collector and from the collector to a
head end server,
according to an aspect of the invention. The node 1810 includes a transmitter
or radio 1820
or other means for transmitting a data packet to the collector 1830 and re-
transmitting an
unacknowledged data packet to the collector 1830 through the NAN network 1870.
[00171] The collector 1830 includes a radio 1840 and a memory 1850. The radio
1840
includes a transmitter or other means for transmitting data packets and a
receiver or other
means for receiving data packets. The memory 1850 includes source code 1860
having pre-
assigned collector port assignments.
[00172] The head end server 1890 includes a radio 1895. The radio 1895
includes a
transmitter or other means for transmitting requests or information, such as a
read request for
a table of nodes serviced by a collector, a table of new reports, and/or a
table of lost reports
and a write request for a table of last sequence numbers from the collector.
The radio 1895
also includes a receiver or other means for receiving tables and data packets
through the
WAN network 1880.
[00173] FIG. 19 shows an example procedure 1900 for addressing reports to
particular
collector destination ports based upon the type of report. At block 1910,
specific collector
ports are pre-assigned to correspond to high priority real-time reporting,
aggregation for batch
reporting, or other processing including, but not limited to, relaying an on-
demand response.
43

CA 02705094 2010-05-06
WO 2009/067250 PCT/US2008/013018
The pre-assigning of destination ports may be done by using source code stored
in the
collector's memory that has embedded within it the destination port
assignments.
[00174] At block 1915, the node collects and stores data for transmission to
the
collector and creates an envelope around the data to form a report and data
packet.
[00175] At block 1920, the node addresses a data packet containing one or more
reports
to the appropriate port of the collector, where the destination port is
included in a data packet
header. At block 1930, the node transmits the addressed data packet to the
collector.
[00176] At block 1940, the collector receives the data packet and processes
the data
packet according to pre-assigned procedures corresponding to the particular
collector port. At
block 1950, the collector transmits the data packet to the head end server,
and at block 1960,
the head end server receives the data packet from the collector.
[00177] Thus, the collector does not need to read the payload of a data
packet, only the
necessary header information attached to the data packet. And in fact, the
collector will not
be able to read the payload of the data packets because the node encrypts the
data with a data
key, and only the head end server has the key to decrypt the data.
[00178] With real-time reporting, the collector CPU 345 initiates the transfer
of
information to the head end server. All of the timing intervals involved are
known so it is
possible to predict the time it will take for the information to arrive at the
head end server.
Typically, transmission of real-time data will take approximately five minutes
or less but it
may be appreciated that this duration is a typical value for a typical network
and not a
limitation of any or all embodiments.
[00179] With batch reporting, the collector CPU 345 or other processor or
processing
logic aggregates batch data from the nodes and waits for the head end server
to request the
data. The head end server may request the batch data once per day or once per
hour, or
according to other policies or rules and depending upon the system parameters
and
configuration. Thus, in at least one non-limiting embodiment, the time at
which the data will
arrive at the head end server is controlled by the head end server, not by
either the node or the
collector. A three-step synchronization process 2100 followed by the collector
140 for
44

CA 02705094 2010-05-06
WO 2009/067250 PCT/US2008/013018
transmitting batch reports to the head end server is detailed in a section
entitled, "Three-Step
Synchronization Between Head End Server and Collector" below.
[00180] Real-Time Reporting By the Collector
[00181] FIG. 20 illustrates an example collector relative reporting time
determination
procedure 2000 used by a collector to determine when to transmit real-time
reports received
from nodes to the head end server. At decision block 2010, the collector
determines whether
a data packet 600A has been received at a port assigned to receive real-time
reports from the
NAN-associated nodes 121, 122, 123. If no new real-time reports have been
received at the
collector (block 2010 - No), the collector continues waiting for a data packet
to be addressed
to its real-time reporting port at decision block 2010.
[00182] If the collector has received a data packet intended to be delivered
to the head
end server as a real-time report (block 2010 - Yes), at block 2020 the
collector may be
configured to delay the transmission of the report in order to aggregate more
real-time reports.
The delay, minimum delay (MIN-DELAY), is used to allow the network bandwidth
to be
used more efficiently. For example, consider the case where a particular node
"node A" sends
a real-time report to the collector, and another particular node "node B"
sends a real-time
report to the same collector some period of time later, for example 20 seconds
later. It would
be a more efficient use of network bandwidth for the collector to wait for a
limited duration to
aggregate both reports and send them together to the head end server rather
than sending node
A's report immediately and then sending node B's report 20 seconds later. The
impact on the
system of waiting a limited duration is negligible because if an alarm needs
to be sent by the
head end server based upon the two real-time reports, a 20-second (or other
specified short)
delay is not very critical.
[00183] Similar to the situation where reports sent by multiple nodes to a
single
collector may result in collisions, the reports sent by multiple collectors to
the head end server
also have the potential to result in collisions. Thus, after waiting for a
period of time of
minimum delay (e.g., MIN_DELAY) such as may apply to real-time event
notification, power
outage notification or the like, at block 2030 the collector will compute
another delay having

CA 02705094 2010-05-06
WO 2009/067250 PCT/US2008/013018
a substantially random duration equal to or less than a maximum random delay
period (e.g.,
RND_PERIOD).
[00184] At block 2040, the collector waits the duration of the calculated
substantially
random delay prior to sending any aggregated real-time reports. At block 2050,
the collector
transmits the real-time reports to the head end server.
[00185] The substantially random delays computed by each collector will
effectively
result in a temporal staggering of reports from the collectors to the head end
server over an
extended period of time rather than multiple simultaneously transmitted
reports. Multiple
head end servers may use the same WAN so collisions may occur between
transmissions from
collectors to a first head end server and transmissions from the same or other
collectors to a
second head end server.
.[00186] At decision block 2060, the collector determines whether an
acknowledgment
has been received from the head end server. If the aggregated real-time
reporting data packets
from the collector does not reach the head end server or if no acknowledgement
is received, a
sequence of re-try attempts are made at the TCP/IP layer and at the
application layer. If the
re-try attempts made at the TCP/IP layer and application layer are also
unsuccessful such that
no acknowledgment is received at the collector (block 2060 - No), at decision
block 2070 the
collector determines whether the maximum number of re-try attempts established
by the
system has been reached. The system uses a number, maximum retry (MAX_RETRY),
which caps or limits the total number of times a collector is permitted to re-
send real-time
reports if previous attempts have been unsuccessful. The cap is needed or at
least
advantageous to prevent a collector from constantly re-sending the reports and
tying up
network resources.
[00187] If the maximum number of re-try attempts have not been made (block
2070 -
No), the collector will return to block 2030 to compute a new substantially
random delay to
wait before re-transmitting the reports, as before. A similar algorithm is
used as for
generating the first substantially random delay, but a shorter scaling period
is used to generate
shorter delays for re-tries. Shorter delays are used because the majority of
real-time reports
46

CA 02705094 2010-05-06
WO 2009/067250 PCT/US2008/013018
sent the first time by collectors would have been successfully received and
acknowledged,
and there are far fewer collectors trying to re-send reports.
[00188] If the maximum number of re-try attempts have been made (block 2070 -
Yes), the collector returns to decision block 2010 to await the receipt of new
real-time reports
from the nodes. The collector does not re-send the aggregated real-time
reports. In one non-
limiting example, the collector may throw away or discard real-time reports
that have been
unsuccessfully sent. In another non-limiting example, the collector may save
the real-time
reports that have been unsuccessfully sent in order to send them in a next
transmission of real-
time reports. In accordance with one non-limiting embodiment, the reports may
be lost only
if there is a loss of power without a back-up power to preserve the reports.
For example, if it
is battery powered, the mesh gate may enter a power saving state, but before
it shuts down or
enters the power saving state it can store the reports for later retrieval and
transmission. In
non-battery implementations, such as those using a super capacitor, there may
not be
sufficient stored energy for the storage of such real-time reports to have
sufficient priority to
be stored before energy is lost. Note that non-limiting examples of battery
powered nodes,
such as battery powered mesh gates, have rechargeable batteries that may have
battery
capacity to operate 8 hours or more.
[00189] If the collector receives an acknowledgment from the head end server
for the
transmitted real-time reports (block 2060 - Yes), at block 2080 the collector
must wait for
another period of time, sometimes referred to as an exclusion period. The
exclusion period is
a minimum period of time a collector must wait before starting a new
communication in order
to prevent the collector from continually transmitting packets over the
network. This
mechanism places a limit on the maximum number of connections the collector
may make
with the head end server per day. Thus, if the collector is constantly
receiving alarms, it will
be prevented from tying up network resources by trying to communicate with the
head end
server every time.
[00190] Synchronization Between Head End Server And Collector
[00191] The description below of a non-limiting example of a three-step
synchronization process 2100 (or process for synchronizing) followed by the
collector 140 for
47

CA 02705094 2010-05-06
WO 2009/067250 PCT/US2008/013018
transmitting real-time reports to the head end server. In the described
example, the
synchronization process advantageously occurs at the application layer.
However, the
synchronization process 2100 is a communications protocol for use between the
head end
server and the collector, independent of whether a layered structure is used,
or when and if
used, the particular layer at which it occurs in the layer structure. In one
embodiment, the
synchronization process 2100 may be used for communications between the head
end server
and the collector without the use of any layer structure.
[00192] It will also be appreciated that use of a layered structure in
computer programs,
devices, and computer network systems is common and that many protocols are
layered, at
lest at a minimum of a physical layer and another layer that might or would
include the other
non-physical layer.
[00193] It will also be apparent to a person skilled in the art in light of
the description
provided here that the application layer is supported by the transport layer,
the mesh layer,
and the data link and physical layers established under the IEEE 802.15.4
protocol. The
mechanics of the lower support layers which may readily be appreciated by
workers having
ordinary skill in the art in light of the description provided here will not
be described here to
avoid obscuring features and aspects of the invention.
[00194] The head end server may wait for the collector to send batch reports
at a pre-
assigned time window. Alternatively, the head end server may initiate a
request for the
delivery of the collector's aggregated batch reports, whether the reports were
obtained by
pulling or pushing, in a three-step synchronization process 1400. The three-
step
synchronization process contains the following three steps: (1) a first read
request with a
corresponding response to the read request, (2) a write request with a
corresponding response
to the write request, and (3) a second read request with a corresponding
second response to
the second read request. A read request made by a first device is the
equivalent of retrieving
information from a target device to the first device. A write request made by
a first device is
the equivalent of sending information from the first device to a target
device. FIG. 21 shows
the three-step synchronization procedure 2100. The details are described
below.
48

CA 02705094 2010-05-06
WO 2009/067250 PCT/US2008/013018
[00195] First, at block 2110 the head end server uses a transmitter to send a
read table
request to the collector. Tables are the data structures used by the nodes.
The specific table
requested by the head end server in this first request is the list of ApTitles
in the collector's
database. ApTitle, defined in the ANSI C12 protocols, is the application
process title of a
node and corresponds to the address of the node. The ApTitle of a node within
a particular
collector's sub-network uniquely identifies that node.
[00196] At block 2120, the collector responds to the head end server's request
by
transmitting a table containing the ApTitles of all of the nodes in its sub-
network. A
processor 345 may apply one or more suitable compression algorithms to
compress the
ApTitles table transmitted by the collector. It will be apparent to a person
skilled in the art in
light of the description provided here that many different types of
compression algorithms
may be used. Non-limiting examples of compression algorithms include, but are
not limited
to, Burrows-Wheeler transform, dynamic Markov compression, and Huffman coding.
[00197] At block 2130, the head end server sends a write request containing a
table of
the last sequence number of each ApTitle in the table sent by the collector.
The last sequence
number for each node uniquely corresponds to the number of the last report
received by the
head end server from that node. At the installation of a meter, the last
sequence number is set
to zero. The last sequence number is incremented by one each time a new report
is
transmitted by a node, and the last sequence number is never reset during the
life of the meter.
When a node transmits information to the collector, it does not have to
transmit a complete
table, even a transmission incorporating a partially written table where
information has only
been entered in specific fields of the table may constitute a report and be
assigned a
corresponding last sequence number.
[00198] Based upon the last sequence number of each node sent by the head end
server,
the collector will be able to identify the new reports that the head end
server has not received
since the last synchronization procedure. For example, if the last sequence
number for node
A in the head end server's database is 100, the collector knows that all
reports having a last
sequence number greater than 100 from node A need to be sent to the head end
server.
49

CA 02705094 2010-05-06
WO 2009/067250 PCT/US2008/013018
[00199] At decision block 2140, it is determined whether the write request is
proper. If
the collector CPU 345 determines that the head end server's write request is
not made
properly (block 2140 - No), the collector sends an error message at block
2145, and the
synchronization process ends at block 2180. Possible reasons for generating an
error message
include lack of permission for the head end server to access the requested
data and invalid
table number provided by the head end server or that the head end server has
not been
authenticated for any reason. The collector may store in memory 335 lists of
authenticated
head end servers or lists of head end servers permitted to access certain
types of reports from
specific nodes, and the CPU 345 compares the requesting head end server
identification with
the lists stored in memory to determine whether the write request was proper.
[00200] If the collector CPU 345 determines that the head end server's write
request is
made properly (block 2140 - Yes), the collector CPU 345 accepts the write
request at block
2150.
[00201] At block 2160, the head end server sends a read table request to the
collector
for the new reports. The collector responds at block 2170 by fetching the
appropriate reports
the head end server has not received, optionally compressing them with
suitable compression
algorithms performed by a processor, and transmitting them to the head end
server which
receives the reports. Non-limiting examples of compression algorithms include,
but are not
limited to, Burrows-Wheeler transform, dynamic Markov compression, and Huffman
coding.
At this point, the transfer and synchronization process is complete at block
2180.
[00202] The collector uses a buffer for storing reports received from every
node it
services in its sub-network. The buffer may advantageously be a circular or
cyclic buffer. A
first-in first-out protocol is employed with the buffer, and may
advantageously be sized to
hold an appropriate quantity or time duration of data. In one non-limiting
embodiment, the
buffer is sized to hold or store approximately three months' worth of reports.
It will be
apparent to a person skilled in the art in light of the description provided
here that the
collector's buffer may store any amount of information. Consequently, the
three-step
synchronization process may be useful for recovering from a partial loss of
data at the head
end server's database by retrieving the lost data and/or lost reports from the
collector.

CA 02705094 2010-05-06
WO 2009/067250 PCT/US2008/013018
[00203] FIG. 22 is a flow chart illustrating an example of a method 2200 of
recovering
lost reports at a head end server, according to an aspect of the invention.
For example, if the
head end server approximates that the most recent five days of reports
received from a
collector has been lost, the head end server may employ the three-step
synchronization
process and enter the last sequence numbers for the nodes corresponding to a
week prior to
the database loss in order to retrieve all of the reports that the collector
transmitted to the head
end server within the past week. Blocks 2210 and 2220 correspond to blocks
2110 and 2120
of FIG.21 described above. At block 2230, the head end server sends a write
request
containing a table of the last sequence number for each ApTitle, where the
last sequence
number corresponds to the last report received from the corresponding node or
any report for
that node that the head end server still has stored in its database.
[00204] At decision block 2240, it is determined whether the write request is
proper. If
the collector CPU 345 determines that the head end server's write request is
not made
properly (block 2240 - No), the collector sends an error message at block
2245, and the
synchronization process ends at block 2280. If the collector CPU 345
determines that the head
end server's write request is made properly (block 2240 - Yes), the collector
CPU 345 accepts
the write request at block 2250.
[00205] At block 2260, the head end server sends a read table request to the
collector
for the lost reports. The collector responds at block 2270 by fetching the
appropriate reports
the head end server has lost, optionally compressing them with suitable
compression
algorithms performed by a processor, and transmitting them to the head end
server which
receives the reports. At this point, the transfer and synchronization process
is complete at
block 2280.
[00206] The three-step synchronization process may also be useful for testing
of the
head end server or upgrading the head end server. Any number of head end
servers may
synchronize with the collector, and the last sequence number stored at each
head end server
may be different.
51

CA 02705094 2010-05-06
WO 2009/067250 PCT/US2008/013018
[00207] The head end server 160 receives all reported events, such as power
outage and
meter tampering reports, by all NAN-associated nodes 121, 122, 123 and HAN-
associated
nodes 131, 132, 133 in its network. Based upon the events received, the head
end server 160
may choose to create an alarm. For example, if several of the HAN-associated
nodes 131,
132, 133 within a HAN 130 report power outages, the head end server 160 may
decide to
raise a power outage alarm. Alternatively, the head end server 160 may require
a minimum
number of repetitions of a certain type of event before creating an alarm. For
example, if a
meter loses a variable in memory and sends a RAM error event to the head end
server 160, the
meter can sometimes resolve the problem by rebooting. However, if the RAM
error occurs
every hour, and the error event is reported to the head end server 160 each
time, the head end
server 160 will raise an alarm because the RAM error is persistent, and the
meter requires
external help to fix the problem.
[00208] The logic required to turn one or more events into an alarm resides at
a
processor at the head end server 160. Conditions for generating an alarm
include, but are not
limited to, the number of times a particular event must recur and the time
span within which a
particular event recurs. Consequences of creating an alarm include, but are
not limited to,
generating an alarm report by the head end server 160 and displaying an alarm
message on a
display at the utility office and/or at the utility customer's site.
[00209] Nodes 121, 122, 123, 131, 132, 133 typically have access to an
electrical
power source as its primary power supply. Thus, when a node loses its primary
power supply,
the node responds to the event as a power outage. However, a node may also
have a
secondary power supply such as a super-capacitor, battery or other power
supply means
which allows the node to continue operating for at least a few minutes after a
power outage of
the primary power supply has occurred at the node. Typically, a node will wait
for a
minimum period of time, for example sixty seconds, referred to as the
recognition period
before reporting a power outage. The wait time ensures that the power outage
is not just a
temporary power glitch, and the wait time is configurable by the utility that
owns the meter.
If the recognition period has elapsed and the primary power supply still has
not been restored,
the node transmits a power outage report to the collector.
52

CA 02705094 2010-05-06
WO 2009/067250 PCT/US2008/013018
1002101 FIG. 23 is a flow chart illustrating an example of a method 2300 of
recovering
untransmitted information from a node experiencing a power outage. At block
2310, the head
end server receives a power outage report from a node.
[002111 At block 2320, the head ends server sends a command to the collector
140 associated
with the node to pull previously untransmitted reports and data from the node
so that the
information is not lost. The collector 140 then sends a request. to the node
to transmit all
reports starting from the last transferred pointer and all data structures in
progress, even
partial interval data. In this special situation, the collector does not wait
for the node to push
the data at the usual scheduled reporting time window because if the node does
not have a
secondary power supply, the node may be powered by a secondary source capable
of
providing only a few minutes of power. Thus, it is important to trigger the
download of all of
the previously untransmitted information from the node as soon as possible.
[002121 At block 2330, the node transmits all data and reports stored at the
node that has not
been previously transmitted to the head end server through the collector, and
at block 2340
the head end server receives the transmission.
[002131 Nodes reporting a power outage do not initiate the transmission of all
previously
untransmitted data and reports because if the power outage is widespread, the
network cannot
handle hundreds or thousands of reports being transmitted simultaneously by
all affected
nodes.
[002141 A node may experience a power outage when it is physically removed as
part of a
maintenance procedure. When the node is removed, it loses accesses to its
primary power
supply and will transmit a power outage report. The head end server may be
aware of
maintenance schedule and realize that the power outage report is a consequence
of the node's
physical removal. However, it is important for the collector or head end
server to send a
request to the node to download all previously untransmitted data and reports
before any
secondary power source is depleted. One advantage to automatically requesting
a download
of untransmitted information is that the technician who removes the node or
meter does not
have to worry about saving any of the information stored at a memory or
register within the
node prior to removing the device. For example, if the node 630 in FIG. 6A is
removed for
53

CA 02705094 2010-05-06
WO 2009/067250 PCT/US2008/013018
maintenance, the data stored in the register 612 would be lost after any
secondary power
source is depleted. Thus, the data stored in the register 612 would be
downloaded in response
to a request from the collector.
[00215] Whenever a power outage is reported, there exists a possibility that
the reported
power outage is not real. Possible reasons for a false power outage report
include, but are not
limited to, tampering with the meter at the node, hardware problems at the
node, software
problems at the node, and poor power supply quality such as low voltage or
power sags.
Thus, it would be advantageous if the system had a way to verify whether the
power outage is
real, rather than risk creating a false alarm based upon a false power outage
report.
[00216] A reported power outage may be verified by querying other nodes within
the
same HAN as the reporting node that have devices such as thermostats or
appliance switches.
If no confirmation is obtained by the other nodes, the reported power outage
may be
considered a false alarm by the head end server 160.
[00217] FIG. 24 illustrates an example procedure 2400 for verifying a power
outage
report from a meter. At block 2410, the head end server 160 receives a power
outage report
from a meter residing at, for example, HAN-associated node 4 131 in the HAN
130.
[00218] At decision block 2420, the head end server determines whether any
power
outage reports have been received from the other nodes in the same HAN, such
as HAN-
associated nodes 5 and 6, 132, 133. Node 5 132 and node 6 133 may be utility-
consumption
devices such as an appliance, or a utility-measuring device such as a
thermostat. If another
report confirming the power outage within the HAN has been received (block
2420 - Yes), at
block 2460, the head end server 160 may use the confirming report or reports
to verify that a
power outage is really affecting the HAN. The process ends at block 2499.
[00219] If no other reports have been received from the other nodes 132, 133
within the HAN
(block 2420 - No), at block 2430, the head end server 160 queries the other
nodes 132, 133 in
the HAN about the power outage. In one embodiment, the query is transmitted
through the
WAN 110 to the collector 140 which transmits the query through the LAN to the
microportal
150, and the microportal 150 transmits the query through the HAN to the nodes
132, 133.
54

CA 02705094 2010-05-06
WO 2009/067250 PCT/US2008/013018
Alternatively, the head end server may maintain a neighborhood table of
locations of nodes
and direct the request to specific nodes of interest within the HAN.
[00220] At block 2440, the head end server 160 receives the responses to the
query from the
other nodes, 132, 133 relayed through the microportal 150 and the collector
140. The queried
nodes 132, 133 are able to respond to the query because if there is no power
outage, the
primary power sources for the nodes 132, 133 have not been affected. If one or
more of the
nodes are experiencing an outage of the primary power source, in one
embodiment, those
nodes will be running off of the secondary power source. Further, the
secondary power
source will still be operative for those nodes because the nodes have not yet
reported the
power outage independently due to the wait imposed by the recognition period.
Because the
recognition period is set to be shorter than the total period of time the
secondary power source
is able to power the node, the node will have power to respond to the query
from the head end
server 160.
[00221] At decision block 2450, the head end server 160 determines whether it
has received a
confirmation of the power outage within the HAN. If the head end server 160
receives a
power outage report from at least one of the other nodes 132, 133 (block 2450 -
Yes),
confirmation has been received, and at block 2460, the head end server 160 may
conclude that
there is a real power outage affecting the HAN, and the first node's 131
initial power outage
report is confirmed. The process ends at block 2499.
[00222] If the head end server 160 does not receive a power outage
confirmation from at least
one of the other nodes 132, 133 (block 2450 -No), at block 2470 the head end
server 160
may conclude that the power outage report received from the first node 131 is
a false report.
The process ends at block 2499.
[00223] In order for a head end server to query other nodes in the same HAN as
the
node reporting the power outage, the microportal 150 must not also experience
the same
power outage. Thus, as shown in FIG. 1, the microportal 150 must reside
outside of any of
the nodes 131, 132, 133 coupled to the HAN 130.
[00224] In one embodiment, nodes housing meters or other devices may not have
super-capacitors or any other secondary power sources. Thus, when a power
outage occurs,

CA 02705094 2010-05-06
WO 2009/067250 PCT/US2008/013018
these nodes are not capable of transmitting any data. The head end server 160
may determine
that a power outage has occurred when the meter at that node fails to transmit
regularly
scheduled reports at the pre-scheduled reporting time window.
[00225] FIG. 25 illustrates an example procedure 2500 for verifying a power
outage as
a result of a node that does not have a secondary power supply failing to
report as scheduled
and also assuming that the other nodes in the same HAN do not have a secondary
power
supply. At block 2510, the head end server fails to receive scheduled reports
from the meter
residing at HAN-associated node 4 131 in the HAN 130, for example.
[00226] At decision block 2520, the head end server determines if any other
expected reports
at the prescheduled reporting time window have not been received from any
other HAN-
associated nodes 132, 133 within the same HAN. If other expected reports have
not been
received (block 2520 - Yes), at block 2560, the head end server 160 may
conclude that there
is a power outage affecting the HAN. The process ends at block 2599.
[00227] If all other expected reports have been received (block 2520 - No), at
block 2530,
the head end server queries other nodes in the HAN. To implement the polling
process, the
head end server sends a request to the collector servicing the network of the
non-reporting
node. The collector then forwards or relays the information request to the
appropriate
microportal servicing the HAN. Alternatively, the head end server may maintain
a
neighborhood table of locations of nodes and direct the request to specific
nodes of interest
within the HAN. At block 2540, the head end server waits for responses from
the queried
HAN-associated nodes. Alternatively, the polling of devices in the HAN could
be initiated
by a meter as soon as the meter perceives an outage, even before the meter
alerts the head-
end, as a cross-check on itself regarding the perceived outage.
[00228] At decision block 2550, the head end server determines if at least one
response has
not been received. If responses have been received from all of the queried HAN
nodes
because all of the HAN-associated nodes still have power (block 2550 - No), at
block 2570
the head end server 160 may conclude that a problem is affecting only the
first node that
failed to report rather than a power outage is affecting the HAN. The process
ends at
block 2599.
56

CA 02705094 2010-05-06
WO 2009/067250 PCT/US2008/013018
[00229] If at least one response has not been received (block 2550 - Yes), at
block 2552, the
head end server may query again the nodes in the HAN that have not responded
to the first
query, in case the query was not received by the non-responsive nodes or the
response was not
received by the head end server. The query or response may have been sent but
not received
for a variety of reasons including, but not limited to, interference at the RF
frequency of
transmission and collisions with another packet.
[00230] At decision block 2554, the head end server determines if at least one
response still
has not been received. If responses have now been received from all of the
queried HAN
nodes (block 2550 - No), at block 2570 the head end server 160 may conclude
that a problem
is affecting only the first node that failed to report rather than a power
outage is affecting the
HAN. The process ends at block 2599.
[00231] If the head end server still has not received at a response from at
least one node, at
block 2560, the head end server 160 may conclude that there is a power outage
affecting at
least a portion of the HAN. The process ends at block 2599.
[00232] Because a head end server has the ability to query other nodes in a
HAN about
reports sent from the metering node in the HAN, the head end server may
correlate
information obtained from multiple nodes within the HAN to determine whether
information
being reported by the metering node is accurate. Further, the head end server
may alert
maintenance personnel to physically go to the non-reporting node's site to
either repair the
meter and/or the supporting register and communications card or swap out the
meter and/or
supporting register and communications card for a new one.
[00233] The head end server may also correlate a power outage report with
other
known information including, but not limited to, maintenance schedules. For
example, if the
head end server is aware that maintenance will be performed at a particular
node on a
particular day or during a particular time window, then a power outage report
received from
that node during that time will not warrant further verification or the
raising of a power outage
alert.
[00234] The words "herein," "above," "below," and words of similar import,
when
used in this application, shall refer to this application as a whole and not
to any particular
57

CA 02705094 2010-05-06
WO 2009/067250 PCT/US2008/013018
portions of this application. Where the context permits, words in the above
Detailed
Description using the singular or plural number may also include the plural or
singular
number respectively. The word "or," in reference to a list of two or more
items, covers all of
the following interpretations of the word: any of the items in the list, all
of the items in the
list, and any combination of the items in the list.
[00235] The above detailed description of embodiments of the invention is not
intended
to be exhaustive or to limit the invention to the precise form disclosed
above. While specific
embodiments of, and examples for, the invention are described above for
illustrative purposes,
various equivalent modifications are possible within the scope of the
invention, as those
skilled in the relevant art will recognize. For example, while a head end
server receiving
power outage reports from meters at nodes is mentioned, a head end server may
receive
power outage reports from utility-measuring devices such as thermostats under
the principles
disclosed herein. Further any specific numbers noted herein are only examples:
alternative
implementations may employ differing values or ranges.
[00236] The teachings of the invention provided herein can be applied to other
systems,
not necessarily the system described above. The elements and acts of the
various
embodiments described above can be combined to provide further embodiments.
[00237] While the above description describes certain embodiments of the
invention,
and describes the best mode contemplated, no matter how detailed the above
appears in text,
the invention can be practiced in many ways. Details of the system may vary
considerably in
its implementation details, while still being encompassed by the invention
disclosed herein.
As noted above, particular terminology used when describing certain features
or aspects of the
invention should not be taken to imply that the terminology is being redefined
herein to be
restricted to any specific characteristics, features, or aspects of the
invention with which that
terminology is associated. In general, the terms used in the following claims
should not be
construed to limit the invention to the specific embodiments disclosed in the
specification,
unless the above Detailed Description section explicitly defines such terms.
Accordingly, the
actual scope of the invention encompasses not only the disclosed embodiments,
but also all
equivalent ways of practicing or implementing the invention under the claims.
58

CA 02705094 2010-05-06
WO 2009/067250 PCT/US2008/013018
59

Dessin représentatif
Une figure unique qui représente un dessin illustrant l'invention.
États administratifs

2024-08-01 : Dans le cadre de la transition vers les Brevets de nouvelle génération (BNG), la base de données sur les brevets canadiens (BDBC) contient désormais un Historique d'événement plus détaillé, qui reproduit le Journal des événements de notre nouvelle solution interne.

Veuillez noter que les événements débutant par « Inactive : » se réfèrent à des événements qui ne sont plus utilisés dans notre nouvelle solution interne.

Pour une meilleure compréhension de l'état de la demande ou brevet qui figure sur cette page, la rubrique Mise en garde , et les descriptions de Brevet , Historique d'événement , Taxes périodiques et Historique des paiements devraient être consultées.

Historique d'événement

Description Date
Le délai pour l'annulation est expiré 2014-11-21
Demande non rétablie avant l'échéance 2014-11-21
Réputée abandonnée - omission de répondre à un avis sur les taxes pour le maintien en état 2013-11-21
Inactive : Abandon.-RE+surtaxe impayées-Corr envoyée 2013-11-21
Inactive : Lettre officielle 2013-04-09
Inactive : Lettre officielle 2013-04-09
Exigences relatives à la révocation de la nomination d'un agent - jugée conforme 2013-04-09
Exigences relatives à la nomination d'un agent - jugée conforme 2013-04-09
Demande visant la nomination d'un agent 2013-04-02
Demande visant la révocation de la nomination d'un agent 2013-04-02
Inactive : Déclaration des droits - PCT 2010-07-19
Inactive : Page couverture publiée 2010-07-16
Inactive : CIB attribuée 2010-07-05
Inactive : CIB attribuée 2010-07-05
Inactive : CIB en 1re position 2010-07-05
Inactive : CIB enlevée 2010-07-05
Inactive : Inventeur supprimé 2010-06-30
Inactive : Lettre de courtoisie - PCT 2010-06-30
Inactive : Notice - Entrée phase nat. - Pas de RE 2010-06-30
Inactive : Inventeur supprimé 2010-06-30
Inactive : CIB en 1re position 2010-06-23
Inactive : CIB attribuée 2010-06-23
Demande reçue - PCT 2010-06-23
Exigences pour l'entrée dans la phase nationale - jugée conforme 2010-05-06
Demande publiée (accessible au public) 2009-05-28

Historique d'abandonnement

Date d'abandonnement Raison Date de rétablissement
2013-11-21

Taxes périodiques

Le dernier paiement a été reçu le 2012-11-08

Avis : Si le paiement en totalité n'a pas été reçu au plus tard à la date indiquée, une taxe supplémentaire peut être imposée, soit une des taxes suivantes :

  • taxe de rétablissement ;
  • taxe pour paiement en souffrance ; ou
  • taxe additionnelle pour le renversement d'une péremption réputée.

Les taxes sur les brevets sont ajustées au 1er janvier de chaque année. Les montants ci-dessus sont les montants actuels s'ils sont reçus au plus tard le 31 décembre de l'année en cours.
Veuillez vous référer à la page web des taxes sur les brevets de l'OPIC pour voir tous les montants actuels des taxes.

Historique des taxes

Type de taxes Anniversaire Échéance Date payée
TM (demande, 2e anniv.) - générale 02 2010-11-22 2010-05-06
Taxe nationale de base - générale 2010-05-06
TM (demande, 3e anniv.) - générale 03 2011-11-21 2011-10-27
TM (demande, 4e anniv.) - générale 04 2012-11-21 2012-11-08
Titulaires au dossier

Les titulaires actuels et antérieures au dossier sont affichés en ordre alphabétique.

Titulaires actuels au dossier
TRILLIANT NETWORKS, INC.
Titulaires antérieures au dossier
KEVIN HOUSE
MICHEL VEILLETTE
Les propriétaires antérieurs qui ne figurent pas dans la liste des « Propriétaires au dossier » apparaîtront dans d'autres documents au dossier.
Documents

Pour visionner les fichiers sélectionnés, entrer le code reCAPTCHA :



Pour visualiser une image, cliquer sur un lien dans la colonne description du document (Temporairement non-disponible). Pour télécharger l'image (les images), cliquer l'une ou plusieurs cases à cocher dans la première colonne et ensuite cliquer sur le bouton "Télécharger sélection en format PDF (archive Zip)" ou le bouton "Télécharger sélection (en un fichier PDF fusionné)".

Liste des documents de brevet publiés et non publiés sur la BDBC .

Si vous avez des difficultés à accéder au contenu, veuillez communiquer avec le Centre de services à la clientèle au 1-866-997-1936, ou envoyer un courriel au Centre de service à la clientèle de l'OPIC.

({010=Tous les documents, 020=Au moment du dépôt, 030=Au moment de la mise à la disponibilité du public, 040=À la délivrance, 050=Examen, 060=Correspondance reçue, 070=Divers, 080=Correspondance envoyée, 090=Paiement})


Description du
Document 
Date
(aaaa-mm-jj) 
Nombre de pages   Taille de l'image (Ko) 
Description 2010-05-05 59 3 061
Dessins 2010-05-05 24 292
Revendications 2010-05-05 6 179
Abrégé 2010-05-05 2 88
Dessin représentatif 2010-07-15 1 11
Avis d'entree dans la phase nationale 2010-06-29 1 195
Rappel - requête d'examen 2013-07-22 1 117
Courtoisie - Lettre d'abandon (requête d'examen) 2014-01-15 1 164
Courtoisie - Lettre d'abandon (taxe de maintien en état) 2014-01-15 1 172
PCT 2010-05-05 1 50
Correspondance 2010-06-29 1 24
Correspondance 2010-07-18 3 94
Correspondance 2013-04-01 3 91
Correspondance 2013-04-08 1 14
Correspondance 2013-04-08 1 17