Login| Sign Up| Help| Contact|

Patent Searching and Data


Title:
DETERMINING AN OPEN/CLOSE STATUS OF A BARRIER
Document Type and Number:
WIPO Patent Application WO/2018/112617
Kind Code:
A1
Abstract:
In some examples, a method determines an open/close status of a pivotable barrier on a moveable platform based on selective use of a plurality of different filters for filtering measurement data from a sensor device.

Inventors:
HE DAKE (CA)
LEVATO ALEXANDER (CA)
GAO YU (CA)
Application Number:
PCT/CA2017/051537
Publication Date:
June 28, 2018
Filing Date:
December 19, 2017
Export Citation:
Click for automatic bibliography generation   Help
Assignee:
BLACKBERRY LTD (CA)
International Classes:
G01D3/032; E05F7/00; G01P15/00; G01V99/00
Domestic Patent References:
WO2016066422A12016-05-06
WO2016066422A12016-05-06
Foreign References:
US20160054148A12016-02-25
Other References:
See also references of EP 3538847A4
Attorney, Agent or Firm:
MOFFAT & CO. (CA)
Download PDF:
Claims:
What is claimed is: 1 . An apparatus comprising:

a sensor device to mount to a barrier pivotable between an open position and a closed position, the barrier mounted on a moveable platform; and

at least one processor configured to:

attempt to determine an open/close status of the barrier based on first filtered measurement data from the sensor device filtered using a first filter, and

in response to determining that the open/close status is not successfully determined based on the first filtered measurement data, determine the open/close status of the barrier based on second filtered measurement data from the sensor device filtered using a second filter different from the first filter. 2. The apparatus of claim 1 , wherein the first filter is a short filter, and the second filter is a long filter. 3. The apparatus of claim 2, wherein an impact of an input at a previous time point on an output of the long filter is greater than an impact of the input at the previous time point on an output of the short filter. 4. The apparatus of claim 2, wherein each of the short and longer filters includes a coefficient, the coefficient of the short filter having a smaller value than the coefficient of the long filter. 5. The apparatus of claim 4, wherein the short and long filters are infinite impulse response (MR) filters. 6. The apparatus of claim 1 , wherein the sensor device comprises an

accelerometer and a rotation sensor to measure rotation about an axis, wherein the first filter and the second filter are to filter measurement data from the accelerometer.

7. The apparatus of claim 6, wherein the at least one processor is configured to: aggregate rotation data from the rotation sensor at a plurality of time points, the aggregating producing an aggregate value that represents an angle of rotation of the barrier;

determine that the barrier has moved to the open position in response to the aggregate value having a specified relation with respect to a first threshold. 8. The apparatus of claim 6, wherein the at least one processor is configured to: compute a first time threshold based on rotation data from the rotation sensor, wherein the attempting to determine the open/close status of the barrier based on the first filtered measurement data from the sensor device filtered using the first filter uses the first filtered measurement data in a time window having a length based on the first time threshold. 9. The apparatus of claim 8, wherein the at least one processor is configured to: in response to determining that the open/close status is not successfully determined based on the first filtered measurement data, compute a second time threshold based on at least a portion of the first filtered measurement data,

wherein the attempting to determine the open/close status of the barrier based on the second filtered measurement data from the sensor device filtered using the second filter uses the second filtered measurement data in a time window having a length based on the second time threshold.

10. The apparatus of claim 9, wherein the computing the second time threshold based on the at least a portion of the first filtered measurement data uses variances computed using the first filter.

1 1 . The apparatus of claim 6, wherein the rotation sensor is initially in a low power state, and wherein the at least one processor is configured to:

compute a variance based on acceleration data from the accelerometer; and trigger the rotation sensor to transition from the low power state to an operational state in response to the computed variance. 12. The apparatus of claim 1 1 , wherein the computed variance comprises a variance of vertical acceleration data and a variance of tangential acceleration data. 13. The apparatus of claim 12, wherein the at least one processor is configured to further use the variance of the vertical acceleration data to determine an open status of the barrier. 14. The apparatus of claim 6, wherein the at least one processor is configured to: determine the open/close status based on a bias due to gravity, and a noise level. 15. The apparatus of claim 14, wherein the at least one processor is configured to:

determine the bias due to gravity and the noise level by performing a training process. 16. The apparatus of claim 15, wherein the training process comprises:

finding local extrema values for respective sub-sequences of acceleration data samples from the acceloremeter, and then finding a global extrema in the local extrema values. 17. A method comprising:

determining, by at least one processor, an open/close status of a pivotable barrier on a moveable platform based on selective use of a plurality of different filters for filtering measurement data from a sensor device.

18. The method of claim 17, wherein the plurality of different filters comprise a short filter and a long filter, the short filter more sensitive to recent measurement data than the long filter. 19. The method of claim 18, wherein determining the open/close status comprises:

attempting to determine, based on first filtered measurement data filtered by the short filter, whether the barrier has moved to the closed position; and

in response to being unable to determine whether the barrier has moved to the closed position based on the first filtered measurement data, determining, based on second filtered measurement data filtered by the long filter, whether the barrier has moved to the closed position. 20. The method of claim 17, wherein the sensor device is mounted on the barrier and comprises an accelerometer and a rotation sensor to measure rotation about an axis, wherein the short filter and the long filter are to filter measured acceleration data from the accelerometer. 21 . The method of claim 20, further comprising:

computing a first time threshold based on rotation data from the rotation sensor,

attempting to determine the open/close status of the barrier based on the first filtered measurement data from the sensor device in a time window having a length based on the first time threshold, the first filtered measurement data filtered using a first filter of the plurality of different filters.

22. The method of claim 21 , further comprising:

in response to determining that the open/close status is not successfully determined based on the first filtered measurement data:

computing a second time threshold based on at least a portion of the first filtered measurement data, and

attempting to determine the open/close status of the barrier based on second filtered measurement data from the sensor device in a time window having a length based on the second time threshold, the second filtered measurement data filtered using a second filter the plurality of different filters. 23. A non-transitory machine-readable storage medium storing instructions that upon execution cause at least one processor to:

determine an open/close status of a pivotable barrier on a moveable platform based on selective use of a plurality of different filters for filtering measurement data from a sensor device mounted on the barrier.

Description:
DETERMINING AN OPEN/CLOSE STATUS OF A BARRIER Cross-reference to related application

[0001 ] This application claims the benefit under 35 U.S.C. § 1 19(e) of U.S.

Provisional Patent Application No. 62/436,587, filed December 20, 201 6, which is hereby incorporated by reference.

Background

[0002] Trucks, tractor-trailers, and tractors connected to chassis carrying containers can be used to transport cargo that includes goods. Trucks, trailers, and containers typically have doors that can be opened to allow access to cargo that is being transported, and closed to secure the items.

Brief Description Of The Drawings

[0003] Some implementations of the present disclosure are described with respect to the following figures.

[0004] Figs. 1 A and 1 B are schematic diagrams of a container hauled by a vehicle, the container including a door and a sensor device according to some examples mounted to the door.

[0005] Fig. 2 is a block diagram of a sensor device according to some examples.

[0006] Fig. 3A is a flow diagram of a process to determine an open/close status of a door that can be pivoted between an open position and a closed position, according to some examples where filters are not used to filter measurement data from a sensor device.

[0007] Fig. 3B is a flow diagram of a process to determine an open/close status of a door that can be pivoted between an open position and a closed position, according to further examples where multiple filters are used to filter measurement data from a sensor device. [0008] Figs. 4A-4C are graphs of various different data, according to some examples.

[0009] Fig. 5 is a flow diagram of a process to trigger activation of a rotation sensor, according to some examples.

[0010] Fig. 6 is a graph of a gyroscope active window according to some examples.

[001 1 ] Fig. 7 is a flow diagram of a process to compute an open/close status of a door according to examples where filters are not used to filter measurement data from a sensor device.

[0012] Figs. 8A-8B are a flow diagram of determining an open/close status of a door using a single filter, according to further examples.

[0013] Figs. 9A-9B are a flow diagram of determining an open/close status of a door using multiple filters, according to additional examples.

[0014] Fig. 10 is a flow diagram of a process of detecting motion of a moveable platform, according to some examples.

[0015] Fig. 1 1 is a graph illustrating variance values as a function of time, for detecting motion of a moveable platform, according to some examples.

[0016] Fig. 12 is a flow diagram of a training process for computing stationary mean and variance values of acceleration data, according to further examples.

[0017] Fig. 13 is a flow diagram of a process of determining an open/close status of a door according to further examples.

[0018] Throughout the drawings, identical reference numbers designate similar, but not necessarily identical, elements. The figures are not necessarily to scale, and the size of some parts may be exaggerated to more clearly illustrate the example shown. Moreover, the drawings provide examples and/or implementations consistent with the description; however, the description is not limited to the examples and/or implementations provided in the drawings.

Detailed Description

[0019] In the present disclosure, use of the term "a," "an", or "the" is intended to include the plural forms as well, unless the context clearly indicates otherwise. Also, the term "includes," "including," "comprises," "comprising," "have," or "having" when used in this disclosure specifies the presence of the stated elements, but do not preclude the presence or addition of other elements.

[0020] A moveable platform can be used to carry physical items (such as cargo) between different geographic locations. Such moveable platforms can also be referred to as cargo transportation units (CTUs). For example, the moveable platform can be a container (that is attached to a tractor), a truck, or a trailer in which the physical items can be stored during shipment. In other examples, the moveable platform can include another type of carrier structure that is able to carry physical items. More generally, the moveable platform can be part of, mounted on, or attached to a vehicle, such as a truck, a tractor, a car, a railed vehicle (e.g., a train), a watercraft (e.g., a ship), an aircraft, a spacecraft, and so forth. It is noted that although the present discussion refers to a moveable platform as a container, techniques or mechanisms according to some implementations of the present disclosure are applicable to other cargo carrying platforms with an entry barrier that can be opened and closed.

[0021 ] The moveable platform can include a door through which physical items can be loaded or unloaded into or from an inner chamber of the moveable platform, respectively. The door is an example of an entry barrier (or more simply "barrier") that can be opened and closed. Other examples of barriers include a window or any other structure that can be opened to allow entry through an opening, or closed to block entry through the opening.

[0022] In some cases, it may be desirable to detect when the barrier is in an open state or in a closed state. Due to movement of the moveable platform on which the barrier is mounted, it is possible for the orientation of the moveable platform to change as the moveable platform is moved to different locations. For example, at a first location, the moveable platform can be located on a relatively flat ground surface. However, at a second location, the moveable platform can be located on a slope.

[0023] Because the potential movement of the moveable platform can cause the orientation of the moveable platform to change (e.g., an angle of the moveable platform with respect to a horizontal plane can change), it may be challenging to determine an open/close status of the barrier using a single sensor. The "open/close status" of a barrier can refer to a status that indicates whether the barrier is in an open position or a closed position.

[0024] In accordance with some examples, techniques or mechanisms are provided to allow for the determination of the open/close status of a barrier that can be opened and closed (i.e., that can be moved between an open position and a closed position) irrespective of the orientation. The barrier is mounted on a moveable platform that is moveable between different geographic locations.

[0025] Typically, door opening and closing on a moveable platform is determined by a contact sensor (e.g., a Hall effect sensor) such that when the door is opened or closed the state change (contact made or broken) is detected by the contact sensor and communicated to a sensor device. This approach involves wiring the contact sensor to the sensor device. Moveable platforms can be subjected to rough handling with heavy cargo, and as a result, the wires between the contact sensor and the sensor device can easily be cut. Moreover, the additional wiring and installation adds cost.

[0026] Fig. 1 A illustrates an example truck 1 00 that includes a tractor unit 102 and a container 104 (provided on a chassis) hauled by the tractor unit 1 02. Fig. 1 B is a perspective view of the container 104. The container 104 is an example of a moveable platform that can be used to carry physical items. The container 104 includes a door 106 that is pivotable between an open position and a closed position. In Figs. 1 A-1 B, the door 106 is in the open position. [0027] The door 106 is pivotally mounted on hinges 1 16, which are attached to a frame 105 (referred to as "door frame") of the container 104. The door 106 is able to rotate about the hinges 1 16 between the open position and the closed position. In Fig. 1 A, two hinges 1 16 are shown. In other examples, the door 106 can be mounted on just one hinge, or on more than two hinges.

[0028] In accordance with some examples, a sensor device 108 is mounted to the door 1 06. The sensor device 108 can be mounted to an outer surface of the door 106 that faces the environment outside the container 104, or alternatively, the sensor device 108 can be mounted to an inner surface of the door 1 08 that faces into an inner chamber 1 1 0 of the container 1 04. In yet further examples, the sensor device 108 can be provided within a recess in the wall of the door 108.

[0029] The sensor device 108 can include sensors 1 12 and 1 14 and one or more processors 1 18. A processor can include any or some combination of the following: a microprocessor, a core of a multi-core microprocessor, a microcontroller, a programmable gate array, a programmable integrated circuit device, or another hardware processing circuit. Although the processor(s) 1 18 is depicted as being part of the sensor device 108 in some examples, it is noted that the processor(s) 1 18 can be separate from the sensor device 108 in other examples. More generally, sensors 1 12, 1 14 and the processor(s) 1 18 can either be integrated into the sensor device 108, such as on a circuit board or in an integrated circuit chip, or the sensors 1 12, 1 14 and the processor(s) 1 18 can be part of separate assemblies.

[0030] The sensor device 108 can also include a communication component to communicate over a network. In some examples, the sensor device 108 (along with other similar sensor devices arranged on barriers of other moveable platforms) can be part of a larger network of devices. This larger network of devices can be part of the "Internet-of-Things" (loT) technology paradigm to allow different types of devices to communicate different types of data (including sensor data, voice data, video data, e-mail data, text messaging data, web browsing data, and so forth).

[0031 ] The ability of the sensor device 108 to communicate over a network can allow an entity (such as a distributor of goods, a manufacturer, or any other entity) to track assets of the entity as the assets are being transported throughout a

geographic region.

[0032] In other examples, the sensor device 108 does not communicate data over a network.

[0033] Detecting the open/close status of the door 1 06 can be used to trigger various actions. For example, the sensor device 108 can send a notification (such as to a central service that is remotely located, or to the driver of the truck 100, or to another device on the truck 1 00) in response to detecting the door 1 06 in the open or closed position. Alternatively, the open/close status can be used to trigger measurement of other information (e.g., temperature, humidity, position of the container 104, or cargo load status, etc.), either by the sensor device 1 08 or by another sensor device. Other actions can be triggered by a detected open/close status in other examples.

[0034] The sensors of the sensor device 1 08 can include an accelerometer 1 1 2 and a rotation sensor 1 14. Although reference is made to an accelerometer or a rotation sensor in the singular sense, it is noted that techniques or mechanisms according to some implementations can be applied in other examples where there are multiple accelerometers and/or multiple rotation sensors that are part of the sensor device 108. The accelerometer 1 12 is used to measure acceleration along one or multiple axes, and can output acceleration data. The rotation sensor 1 14 is used to measure rotation about each of one or more axes. More specifically, the rotation sensor 1 14 can measure the rotation speed or rate of rotation about each respective axis.

[0035] In some examples, the rotation sensor 1 14 can include a gyroscope. In other examples, the rotation sensor 1 14 can include a rotation vector sensor, where a rotation vector produced by the rotation vector sensor represents the orientation of the rotation vector sensor as a combination of an angle and an axis, in which a device has been rotated through an angle around a specific axis. [0036] Because the sensor device 108 is used to check the open/close status of a door that is mounted on a moveable platform, the rotation data from the gyroscope is used because comparing the acceleration data from the accelerometer against a threshold may not accurately determine the open/close status of the door, since the threshold that is used may not correspond to door movement depending upon the orientation of the frame (e.g., 105 in Fig. 1 ) on which the door is mounted. In other words, different thresholds may have to be used for different door frame orientations. Note also that parameters can be used for determining the open/close status of a door. Such parameters trained and learned for one door frame orientation may not be valid for a different orientation of the door frame.

[0037] Thus, according to some examples, since the door is mounted on a moveable platform whose position and orientation may change, the process for determining the open/close status of the door additionally uses rotation data from the gyroscope (or other rotation sensor) and further considers an orientation of the moveable platform.

[0038] Measurement data from the accelerometer can also be used to determine motion of the moveable platform.

[0039] In the ensuing discussion, reference is made to detecting the open/close status of a door, such as the door 106. It is noted that techniques or mechanisms according to some examples can be applied more generally to the detection of an open/close status of any type of barrier in other examples.

[0040] Sensor output can be noisy, where noise can come from a variety of different sources: mechanical vibration, electrical and thermal fluctuation, etc. As result, a processing technique to process sensor output for door status or motion status detection should account for the effect of noise for robust and accurate determination of door status or motion status.

[0041 ] A filter can be used to reduce noise in measurement data from a sensor device (e.g., 108 in Figs. 1 A and 1 B). In a resource-constrained system like the sensor device 108 mounted on the moveable platform 104, it may be more desirable to use infinite impulse response (IIR) filters instead of finite impulse response (FIR) filters, since the storage load and computational complexity of IIR filters are typically lower than that of FIR filters.

[0042] An IIR filter can be described by using the following equation.

where y[n] denote the filter output at time point n, x[n - i] denote the filter input at time point n - i, bi is called the i-th feedforward coefficient, and α j is called the ;-th feedback coefficient. In the above, N is called the feedforward filter order and M is called the feedback filter order. When N = M = 1 and α 1 + b 0 = 1, a simple IIR filter can be defined by a single parameter α 1 ,

[0043] Expanding the above equation, it is seen that for any 0 < α 1 < l, the impact of x[n - i] on y[n] decreases exponentially as the time distance i from the time point n grows, i.e.,

[0044] Thus, a large impulse will have a longer impact on the filter output for a filter whose coefficient α 1 is large than for a filter whose coefficient α 1 is small. For this reason, a filter with a larger coefficient α 1 may be referred to as a long filter, and a filter with a smaller coefficient α 1 can be referred to as a short filter. Due to their respective constructions, note that:

• a long filter is less sensitive to local changes than a short filter; and

• a short filter is faster to adapt to change in statistics than a long filter. [0045] Stated differently, an impact of an input, x[n - i] , at a previous time point on an output, y[n] , of the long filter is greater than an impact of the input at the previous time point on an output of the short filter.

[0046] In accordance with some implementations of the present disclosure, door status detection systems and techniques can satisfy the following conditions C1 and C2. As explained further below, to address noisy measurement data from a sensor device, filters can be used that consider both conditions C1 and C2.

C1 . A door status detection system or technique has to be fast and responsive so that the probability of missing a true door event is low; and

C2. The door status detection system or technique is expected to be robust and reliable so that the probability of reporting a false event (falsely reporting a door as open when the door is closed, or falsely reporting the door as closed when the door is open) is low.

[0047] Note that door status detection is to be disabled when the moveable platform is detected to be in motion. As such, door status detection depends upon motion detection.

[0048] In practice, even when a door is in a closed position, it may be subject to environmental disruptions like strong winds. In addition, the moveable platform itself may be in harsh environments like an open sea where movement can be

unpredictable. With these in mind, it is desirable to consider condition C2 in designing and developing solutions for door status detection.

[0049] In Fig. 1 B, three axes are defined: X, Y, and Z. In the view of Fig. 1 B, the X axis points generally upwardly, which in the view of Fig. 1 B is generally parallel with a rotation axis of each hinge 1 16. The door 106 is rotatable about the rotation axis of the hinge 1 16. The Y axis is a radial axis that is perpendicular to the X axis (where the X axis is also referred to as a vertical or gravitational axis). In the view shown in Fig. 1 B, the Y axis is parallel to the main surface of the door 1 06 and points towards the hinges 1 16. The Z axis (also referred to as a tangential axis) is in a direction that is normal to the main surface of the door 106; when the door 106 is in the closed position, the Z axis points into the inner chamber 1 1 0 of the container 104.

[0050] Although reference is made to the X axis as pointing upwardly in the view shown in Fig. 1 B, it is noted that in other examples, the X axis can point in a different direction. More generally, the X axis is parallel to the rotation axis of a hinge about which the door 106 is rotatably mounted. Thus, in a different example, a hinge of the door 106 can be mounted such that its rotation axis extends along a horizontal axis, or along a diagonal axis. In other examples, rolling doors that move up and down do not have hinges but have rollers or other mechanisms to move up and down.

[0051 ] In some examples, the accelerometer 1 1 2 can measure acceleration along each of the X, Y, and Z axes, and the rotation sensor 1 14 can measure rotation data about each of the X, Y, and Z axes. In other examples, the

accelerometer 1 12 can measure acceleration in a subset of the X, Y, and Z axes, such as along the X and Y axes, and the rotation sensor 1 14 can measure rotation data about just the X axis.

[0052] An example of the sensor device 108 is shown in Fig. 2. The sensor device 108 includes the accelerometer 1 12, the rotation sensor 1 14, and the one or more processors 1 18. The sensor device 108 can be implemented as a circuit board on which are mounted the accelerometer 1 12, the rotation sensor 1 14, and the processor(s) 1 18 plus associated memory and circuits, all housed in a suitable enclosure. In other examples, the sensor device 108 can be implemented as an integrated circuit chip with the accelerometer 1 12, the rotation sensor 1 14, and the processor(s) 1 18 plus associated memory and circuits, all housed in a suitable enclosure. In yet further examples, the processor(s) 1 18 can be separate from an assembly including the sensors 1 1 2 and 1 14.

[0053] The processor(s) 1 18 can receive acceleration data from the

accelerometer 1 12, and rotation data from the rotation sensor 1 14.

[0054] The sensor device 108 further includes a storage medium 206 that stores a motion detection module 208 (which can include machine-readable instructions such as software or firmware) to detect motion of the moveable platform 104, and a door status detection module 21 0 (which can include machine-readable instructions such as software or firmware) to determine an open/close status of the door 106. Each of the motion detection module 208 and the door status detection module 210 is executable on the processor(s) 1 18. Although examples refer to the motion detection module 208 and/or the door status detection module 210 implemented as machine-readable instructions executable on processor(s), in other examples, the motion detection module 208 and/or the door status detection module 210 can be implemented with just a hardware processing circuit.

[0055] The motion detection module 208 uses the acceleration data from the accelerometer 1 12 to determine motion of the moveable platform 106 in accordance with some implementations of the present disclosure.

[0056] The door status detection module 21 0 uses the acceleration data from the accelerometer 1 12 and the rotation data from the rotation sensor 1 14 to determine the open/close status of the door 106.

[0057] A communication component 202 can transmit an output indication 204 to a destination over a data network. The output indication 204 can be in the form of a message, an information field in a message, or other indicator.

[0058] The output indication 204 can be a motion indicator to indicate whether or not the moveable platform 104 is in motion. For example, if the motion indicator is set to a first value, that indicates that the moveable platform 104 is in motion.

However, if the motion indicator is set to a second value, that indicates that the moveable platform 104 is not in motion.

[0059] In further examples, the motion indicator is not output by the sensor device 108. Rather, the motion indicator is communicated by the motion detection module 208 to the door status detection module 21 0 for use by the door status detection module 210 in triggering a process to detect the open/close status of the door 106. [0060] In additional examples, the output indication 204 can include an open/close status indicator to indicate whether the door 1 06 is open or closed. The open/close status indicator if set to a first value indicates that the door 106 is open, and if set to a second value indicates that the door 106 is closed.

[0061 ] The communication component 202 can include a wireless transceiver and associated circuits to allow for wireless communication by the sensor device 108 to the data network. The wireless communication can include wireless

communication over a cellular access network, a wireless local area network, a satellite network, and so forth.

[0062] Alternatively, the communication component 202 can include a wired transceiver and associated circuits to perform wired communications between the sensor device 108 and the destination. More generally, the communication component 202 includes a communication transceiver and associated circuits.

[0063] The destination to which the output indication 204 is sent can include a server or a collection of servers and associated network equipment which may be located at one fixed location or in a mobile unit or as part of a data center or cloud.

[0064] In further examples, instead of communicating the output indication 204 to a destination device that is external of the sensor device 108, the output indication 204 can instead be used internally in the sensor device 108 to trigger an action, such as to cause other sensor(s) (not shown) of the sensor device 108 to measure one or more parameters or to take another action.

[0065] In the ensuing discussion, reference is made to examples where the rotation sensor 1 14 includes a gyroscope. In other examples, it is noted that techniques or mechanisms according to some implementations can be applied with other types of rotation sensors.

[0066] A gyroscope may consume a relatively large amount of power, in some cases greater than the power consumed by an accelerometer, for example. As such, it is desirable to maintain the gyroscope in a low power state, until the gyroscope is to be used for measuring rotation data. A low power state can refer to a state of the gyroscope where the gyroscope is powered off, or where some portion of the gyroscope is powered off to reduce power consumption by the gyroscope. The gyroscope can be activated to transition the gyroscope from the lower power state to an operational state, where the operational state of the gyroscope refers to a state of the gyroscope where the gyroscope can measure rotation data and output the rotation data.

[0067] Fig. 3A is a flow diagram of a general door open/close (DOC) process of determining an open/close status of a door (e.g., the door 106) mounted on a moveable platform (e.g., the container 104). The DOC process of Fig. 3A does not use filters to filter measurement data from the sensor device 108.

[0068] The DOC process of Fig. 3A can be performed by a computing device, such as by the processor(s) 1 18 according to some examples. The DOC process of Fig. 3A can receive (at 302) acceleration data from an accelerometer, such as the accelerometer 1 12 that is part of the sensor device 108 mounted on the door. The DOC process can determine (at 304) whether to activate a gyroscope (e.g., 1 14 in Fig. 1 B or 2) based on the acceleration data from the accelerometer, where activating the gyroscope refers to transitioning the gyroscope from the low power state to the operational state.

[0069] If the gyroscope is not to be activated, then the DOC process can continue to receive further acceleration data from the accelerometer. However, if it is determined that the gyroscope is to be activated, then the DOC process can cause activation (at 306) of the gyroscope. The DOC process receives (at 308) rotation data from the activated gyroscope.

[0070] The DOC process of Fig. 3A further includes determining (at 31 0) an open/close status of the door based on the rotation data from the gyroscope (and possibly also on the acceleration data from the accelerometer). It is noted that the determined open/close status of the door also accounts for the orientation of the moveable platform on which the door is mounted, where the orientation can change as a result of the moveable platform moving to different locations. [0071 ] In some implementations, the DOC process can be disabled when the moveable platform is detected to be in motion. Detecting motion of the moveable platform can be based on any or some combination of the following: the acceleration data from the accelerometer 1 12, based on positioning information from a global positioning system (GPS) receiver, based on speed information provided by the vehicle, and so forth. In response to detecting that the moveable platform is in motion, the DOC process deactivates determination of the open/close status of the door.

[0072] Although rotation data from the gyroscope can detect door opening with relatively high reliability, detecting door closing is analogous to proving a negative. As a result, the DOC process according to some implementations can use both the rotation data from the gyroscope and the acceleration data from the accelerometer under certain conditions to improve reliability in detecting door closing.

[0073] In further examples, a DOC process (that does not use filters to filter measurement data from the sensor device 1 08) can follow the procedure below.

51 . Monitor the tangential component (along the Z axis) of the acceleration data (hereinafter referred to as the "tangential acceleration data") from the accelerometer. If a substantial jump in the tangential acceleration data is detected (based on determining if a variance of the tangential acceleration data satisfies specified conditions G1 and G2 as discussed further below), the procedure continues to S2.

52. Activate the gyroscope to track the angle movement around the X axis (vertical or gravitational axis).

a. If the angle movement is away from the door frame and the turned angle is large enough (e.g., as determined according to Fig. 7 discussed further below), a door open event is reported;

b. If the angle movement is small, the procedure continues to S3.

53. Check if the tangential acceleration data of the acceleration is stable and close to a bias trained when the door is closed and at a stationary position (e.g., as determined according to Fig. 7). If the answer is yes, a door close event is reported.

[0074] As noted above, to compensate for noisy measurements from a sensor, such as the accelerometer 1 12, a filter, such as an MR filter, can be applied. A filter can be used to filter acceleration data from the accelerometer 1 12 during both a training process (to train the system or technique for detecting the open/close status of a barrier) and a detection process (to detect the open/door status of a barrier). However, use of a single filter, such as a single M R filter, may not adequately address conditions C1 and C2 above.

[0075] To meet condition C1 , a short filter may be preferred. However, to meet condition C2, a long filter may be preferred. As a result, if just one MR filter is used, a dilemma may arise in selecting an optimal MR filter to address conditions C1 and C2, which can result in a trade-off between a door status detection solution that is fast and responsive or that is robust and reliable.

[0076] In accordance with some implementations of the present disclosure, a DOC process can determine an open/close status of a door (or other pivotable barrier) on a moveable platform based on selective use of a plurality of different filters (e.g., selective use of a short filter and a long filter) for filtering measurement data from a sensor device (e.g., 108 in Fig. 1 B or 2).

[0077] As shown in Fig. 3B, the DOC process according to some

implementations can attempt (at 320) to determine an open/close status of the door based on first filtered measurement data from the sensor device filtered using a first filter (e.g., the short filter). In response to determining that the open/close status is not successfully determined based on the first filtered measurement data, the DOC process determines (at 322) the open/close status of the door based on second filtered measurement data from the sensor device filtered using a second filter (e.g. the long filter) different from the first filter.

[0078] The following assumes that the accelerometer 1 12 is a three-axis accelerometer that can measure acceleration data in each of the X, Y, and Z axes, and that the gyroscope 1 14 is a three-axis gyroscope that can measure rotation data about each of the X, Y, and Z axes. However, in other examples, the acceleroemter 1 12 and the gyroscope 1 14 can measure respective measurement data for a smaller number of axes. For example, the accelerometer can measure acceleration data along only the Y and Z axes, and the gyroscope can measure rotation data about only the X axis.

[0079] The acceleration data from the accelerometer 1 1 2 includes radial acceleration data (along the Y axis), tagential acceleration data (along the Z axis), and gravitational acceleration data (along the X axis), which are denoted respectively by r t r 2 ... (radial acceleration data), t t t 2 ... (tangential acceleration data), and v 1 v 2 ... (gravitational acceleration data). The rotation data from the gyroscope 1 14 includes rotation data about the X axis, Y axis, and Z axis, which are denoted g Xil g Xi2 —,

9y,l9y,2 " " > and g zA g Zi2 ···, respectively.

[0080] The gyroscope is to remain inactive until it is activated. In some implementations, once activated, the gyroscope can operate for a specified time duration, during which the gyroscope is able to measure rotation data. In response to expiration of the specified time duration, the gyroscope is deactivated to reduce power consumption.

[0081 ] The output of the DOC process includes an open/close indication e t at time point i, where e t can be set by the DOC process to one of multiple different values, such as: e t = 0 indicates no door movement,

e t = 1 indicates door closing movement (door closed status), and

e t = -1 indicates door opening movement (door open status).

[0082] Although specific values of e t are provided above, it is noted that in other examples, e t can be set to different values to indicate different door status. [0083] A door opening movement is characterized by the door opening by at least a specified angle (e.g., 8 q , 1 0 e , etc.) during the specified duration of operation of the gyroscope, in response to a detectable force.

[0084] A door closing movement is characterized by the door hitting the door frame with a detectable force and remaining stationary at the door frame for at least a second time duration, such as a fractional end portion of the specified time duration of operation of the gyroscope.

[0085] In some examples, the DOC process outputs a sequence

where N > 1, for respective time points 1 , 2, ···, N, and each e t at time point i can have one of the three example values noted above.

[0086] The accelerometer and gyroscope can be sampled at the same frequency f s , such as 50 Hertz (Hz) or a different frequency.

[0087] Figs. 4A-4C are three graphs that depict rotation data (Fig. 4A), tangential acceleration data (Fig. 4B), and the open/close status (Fig. 4C) as a function of time. A curve 402 in Fig. 4A depicts gyroscope rotation data about the X axis at respective time points. A curve 404 in Fig. 4B represents tangential acceleration data about the Z axis from the accelerometer at respective time points. A curve 406 represents a result of the open/close determination performed by the DOC process according to some examples. Fig. 4C also shows a ground truth curve 408 that indicates the actual open/close status of the door. The ground truth curve 408 being below value zero indicates that the door is closed, while the ground truth curve 408 being below zero indicates that the door is closed. As indicated by the ground truth curve 408, the door starts in the closed position, is moved to the open position, and is then moved to the closed position. In the exampe shown in Fig. 4C, as indicatd by the ground truth curve 408, a door opening sequence is centered at time T1 , while a door closing sequence is centered at time T2.

[0088] An upward spike 410 of the curve 406 in Fig. 4C indicates a door open status, while a downward spike 412 of the curve 404 indicates a door close status. [0089] In general, the DOC process according to some examples of the present disclosure includes two sub-processes: (1 ) determining whether to activate the gyroscope based on the acceleration data from the accelerometer, and (2) determining the open/close status of the door based on the gyroscope data and possibly the acceleration data.

[0090] Triggering activation of the gyroscope

[0091 ] The following describes the sub-process in the DOC process for triggering activation of the gyroscope 1 14, based on acceleration data from the accelerometer 1 1 2. Generally, in some examples, the triggering of the activation of the gyroscope can be based on a variance of the acceleration data. Variance can refer to the expectation of the squared deviation of a random variable (in this case acceleration data) from its mean. The DOC process can determine whether the computed variance satisfies one or more conditions, and if so, that is an indication that the door may be moving and thus the gyroscope should be activated to perform the determination of the open/close status of the door.

[0092] For simplicity, in the following discussion, it is assumed that the DOC process uses just the tangential acceleration data t t 2 ... (along the Z axis) from the accelerometer to determine whether the gyroscope is to be activated or not. In other examples, the acceleration data along one or more of the X axis and Y axis can be used to determine wehther the gyroscope is to be activated or not.

[0093] At time point i, the DOC process computes a gyroscope activation indication, gi as follows: gii = 1 indicates that the gyroscope is to be activated; and

gi t = 0 indicates that the gyroscope is not to be activated.

[0094] Although specific values for g t are noted above, it is contemplated that the gyroscope activation indication g t can have other values in other examples for indicating whether or not the gyroscope is to be activated. [0095] Fig. 5 is a flow diagram of an example process to control activation of the gyroscope that is initially in a low power state. The process of Fig. 5 can be performed by the processor(s) 1 1 8 of Fig. 1 B and 2, or by a different computing device. In the following discussion, represents the mean of the tangential

acceleration data at each time point i, while represents the variance of the

tangential acceleration data at each time point i. The process of Fig. 5 computes (at 502) the mean and variance parameters according to:

where

[0096] In Eqs. 1 -4, the parameter K is a specified constant value that represents a time window size in terms of number of samples (at respective time points) of the tangential acceleration data over which the respective mean and variance are computed, where each sample is collected at a respective time point.

[0097] More generally, Eq. 3 sums the tangential acceleration data from

time poin to a current time point i to compute S t i , and Eq. 4 sums the

square of the tangential acceleration data from time point

current time point i to compute The values S t i and S are used in Eqs. 1 and

2, respectively, to compute the mean and the variance

[0098] The process sets (at 504) (gyroscope inactive).

[0099] The process determines (at 506) if one or more of specified conditions G1 and G2 are satisfied, where

Condition G1 :

Condition G2:

[00100] Condition G1 relates to whether the variance computed according to

Eq. 2 is greater than where C x is a specified constant value. Condition G1

includes a comparison of a current variance at time point i with a value based on a product of the constant C 1 and the variance computed at the beginning of the

time window at i - K.

[00101 ] Condition G2 relates to a determination of whether a current variance at time point i is greater than a threshold C 2 , which is a specified constant value.

[00102] In the foregoing computations, the constants C x and C 2 are used to determine if the force used to generate tangential movement is significant enough in that it may be due to door opening or closing. The values of K, C 1 , and C 2 can be empirically set based on past experience and the specific characteristics of the sensor device and the door whose open/close status is to be determined. In some examples, K = 25, CI = 16, and C2 = 0.6. However, in other examples, other values of K, c , and C 2 can be used. For example, C 2 may be determined by statistics, e.g., variance, from accelerometer readings from other axes, e.g., the X axis, the Y axis, or a combination of both X and Y axes. Note that the variance of acceleration along the X axis is often used to determine whether the platform on which the door is mounted, e.g., a container or a trailer, is moving or not. C 2 as a function of the variance of acceleration along the X axis essentially indicates that G2 is conditioned upon the movement of the platform.

[00103] If either condition G1 or G2 is satisfied, then the process sets (at 508) to cause activation of the gyroscope. However, if neither condition G1 nor

G2 is satisfied, then the process maintains and returns to task 502.

[00104] In further examples, in task 502, the variance may be multiplied b to obtain an unbiased sample variance. Furthermore, S t i in Eq. 3 may be efficiently computed from by using the following equation.

[00105] Similarly, in Eq. 4 may be efficiently computed from ^ by using

[00106] In alternative examples in task 502 may be approximated by

using MR filters. Let α denote an MR filter parameter. Then

[00107] In such alternative examples, the Fig. 5 process can be modifed to use the variance computed according to Eq. 9 rather than the variance computed according to Eq. 2.

[00108] Also, tasks 506 and 508 can be modified to detect if conditions G1 and G2 are consistently met over a number of consecutive samples to reduce false positives. In other words, rather than set when condition G1 or G2 is satisfied for time

point i , the setting of is based on whether the condition G1 or G2 is also

satisifed over the next number of time points. In the case where MR filters are used, the threshold on the number of samples over which conditions G1 and G2 are evaluated may be adaptive to -the larger is observed, the higher the threshold

is, reflecting the fact that the MR filters have longer tails for larger values.

[00109] Detecting open/close status of the door

[001 10] The following process describes how the open/close status of the door is determined, based on rotation data from the gyroscope. It is noted that in some cases, the closed status of the door may not be determined with just the rotation data; in such cases, acceleration data would also be used.

[001 1 1 ] Once the gyroscope is triggered at time point i in response to setting 1 (task 508 in Fig. 5), the gyroscope remains active for a specified time duration (e.g., three seconds or some other time duration). The reason that the gyroscope stays on for the specified time duration is to ensure that the gyroscope returns to a low power state after the rotation data measurements have been made in the specified time duration. In some examples, at a sampling frequency f s = 50 Hz, assuming a three-second time duration when the gyroscope is activated, a total of 150 rotation data samples from the gyroscope are collected for use in detecting door opening and closing. In other examples, different time durations and different sampling frequencies can be used.

[001 12] In the ensuing discussion, the time duration during which the gyroscope is activated to collect rotation data is referred to as the "gyroscope active window," shown as 602 in Fig. 6. In Fig. 6, each upwardly pointing arrow represents a rotation data sample collected at a respective time point by the gyroscope.

[001 13] Since door movement in some examples involves rotation along the X axis, the DOC process uses just the gyroscope's rotation data about the X axis,

(assuming that 1 50 samples of rotation data are collected in the

gyroscope active window 602).

[001 14] Let j = i + 149, where j represents the end of the gyroscope active window 602, and i represents the beginning of the gyroscope active window. The DOC process computes the open/close indication e i based on rotation data samples 9x,i9x,i+i ··· 9x,j (from time point i to time point ; ' ) according to the process shown in Fig. 7. As noted above, the open/close indication e i can be set to one of three values (-1 to indicate door open, 1 to indicate door close, and 0 to indicate otherwise).

[001 15] Note that the process of Fig. 7 does not use filters to filter measurement data from the sensor device 108.

[001 16] Task 702: In some examples, the process finds the smallest time point k (in the time range from time point i to time point ; ' ) where a rotation data sample indicates that the door is rotating away from the door frame (e.g., 105 in Fig. 1 B). Note that the door is rotating away from the door frame i Stated differently,

this task involves finding the index k such tha and denoting this smallest index k by k * . If no such k exists, s

[001 17] In other examples, instead of finding the smallest time point k, the process may choose, for example, to save computational complexity, to find a time point k where a rotation data sample g x k indicates that the door is rotating away from the door frame.

[001 18] Task 704: The process computes an angle of rotation of the door away from the door frame by computing an approximate integration of the rotation data samples from the gyroscope, in the time range from time point k * to time point The approximate integration of the rotation data is computed as

[001 19] In Eq. 10 above, α j - is produced by aggregating (e.g., summing) the rotation data samples, which produces an aggregate value, α j - , that represents an approximation of the rotation angle of movement of the door (i.e., how many degrees the door has rotated about the X axis).

[00120] Task 706: The process computes a number of samples of the rotation data (g x k ) indicating that the door is rotating away from the door frame, in a fractional end portion (604 shown in Fig. 6) of the gyroscope active window 602. In the case of a door close event, the number of samples of the rotation data indicating that the door is opening in the fractional end portion 604 should be less than some specified threshold. Even when the door has hit the door frame when being closed, vibration of the door due to the elasticity of the door can cause some rotation data samples in the fractional end portion 604 of the gyroscope active window 602 to be greater than zero (to indicate movement away from the door farme). More specifically, this number of samples of the rotation data indicating that the door is opening in the fractional end portion 604 is expressed as

[001 21 ] In Eq. 1 1 corresponds to the duration of the fractional

end portion 604, which starts at j - f s /2 and ends at j.

[001 22] Task 708: The process computes the open/close indication e 7 as follows.

[001 23] The open/close indication e 7 is computed based on comparing the angle of rotation of the door away from the door frame (α j ) with respect to thresholds C3 and C4, and based on comparing n 7 to the threshold CS.

[001 24] The parameters C3 , C4, and CS are specified constants. The parameter C3 represents a threshold amount of rotation angle (e.g. , 8 °, 1 0 °, etc.) that the door has to rotate in a direction away from the door frame to indicate that the door has moved to the open position. For example, C3 is set to 8 to indicate 8 °, set to 1 0 to indicate 1 0 °, and so forth. Thus, α j > C3 indicates that the door has rotated away from the door frame by more than C3 degrees.

[001 25] The parameter C4 represents a threshold amount of rotation angle (e.g., 3 °, etc.) that α j should be less than to indicate that the door has possibly moved to the closed position.

[001 26] Thus, generally, the DOC process determines that the door has moved to the open position in response to the aggregate value, α j , having a specified relation with respect to a first threshold (e.g. , α j > C3). The DOC process determines that the door has moved to the closed position in response to the aggregate value, α j , having a specified relationship with respect to a second threshold (e.g., α j < C4), and further based on another condition that confirms the door closed status (e.g., n j < CS). [001 27] The parameter C5 (e.g., 2, etc.) represents a threshold number of samples of rotation data exceeding zero (to indicate rotation away from the door frame) used to confirm a door close event. Thus, specifies that the number

of samples of rotation data indicating that the door is opening in the fractional end portion 604 is less than or equal to C5. More generally, n ; - is a stationary indication value (a bias) for indicating whether the door is stationary (e.g., indicates

that the door is stationary). If both are true, then a door close

status is confirmed, and e i is set to 1 .

[001 28] However, if the door may still be in the middle of a

closing sequence before stopping. In view of this, the DOC process can continue checking (for up to 5 seconds or another time duration, for example) if the tangential acceleration data and the radial acceleration data converge to

stationary values estimated when the door is still and closed. If convergence of the tangential acceleration data and the radial acceleration data is detected at time point , then the DOC process sets e jr = 1.

[001 29] Thus, a determination of a closed status of the door under the condition that α.j < C4 but Tij > C5 is based on the rotation data from the gyroscope and a determined convergence that is based on the orientation of the moveable platform on which the door is mounted. More specifically, the determination of the closed status of the door is based on the rotation data and convergence of the acceleration data that is based on the orientation of the moveable platform.

[001 30] The convergence of tangential acceleration data and radial acceleration data is discussed further below.

[001 31 ] Use of M R filters for door open/close status detection

[001 32] To compensate for noise in measurement data from the acceleration data when determining the open/close status of a barrier, Figs. 8A-8B illustrate a procedure according to examples where just one M R filter is used. Note that the biases used in determining whether the door is closed or not based on tangential acceleration data are learned by using learning techniques discussed further below.

[00133] As noted above, use of just one M R filter may not adequately satisfy both conditions C1 and C2 discussed further above.

[00134] Figs. 8A-8B depict an iterative procedure that iterates over multiple time points i.

[00135] Task 802: The procedure increments time point i.

[00136] Task 804: The procedure receives acceleration data from the

accelerometer.

[00137] Task 806: The procedure filters each component in the acceleration data by using the MR filter to obtain filtered output including filtered acceleration

Variances are estimated based on the acceleration data

[00138] Task 808: The procedure determines if the gyroscope is activated.

[00139] Task 810: If the gyroscope is activated, the procedure receives rotation data g x i (rotation data about the X axis at time point i) from the gyroscope.

[00140] Task 812: The procedure determines if the elapsed time (i - i * ) is greater than or equal to T G , which represents the time duration during which the gyroscope is activated before placing the gyroscope to sleep. The parameter V represents the time point at which the gyroscope was activated. In some examples, T G can be set to 3/ s , i.e., three times the sampling frequency f s , which is equivalent to 3 seconds. In other examples, other values of T G can be used. If the elapsed time (i - Γ) is not greater than or equal to T G , then the process increments i (task 802) and continues to receive additional acceleration and rotation data.

[00141 ] Task 814: If the elapsed time is greater than or equal to then the procedure places the gyroscope in sleep mode. An amount of rotation of the door is computed from , such as according to Eq. 10 above.

[00142] Task 816: The procedure determines if is greater than or equal to (which is a specified threshold representing an amount of rotation indicating that the door has been opened). If is not greater than or equal to then the process

returns to task 802 (the door status remains indicated as closed).

[00143] Task 818: I is greater than or equal to then the procedure

changes the door status to "Open." The procedure can send an indication of the open status to a target entity.

[00144] Task 820: If the determination at task 808 indicates that the gyroscope is not activated, then the procedure determines whether a parameter

useAccelForDoorDecision is set to True. If so, that indicates that acceleration data is to be used for determining whether the door is closed.

[00145] Task 822: If the parameter useAccelForDoorDecision is not set to True, then the procedure determines, based on variance data (computed from

tangential acceleration data in task 806), whether there is a possible door event. K represents a size of a time window over which a determination is to be made regarding whether a possible door event should trigger activation of the gyroscope. If it is determined there is not a possible door event, then the process returns to task 802. The determination if there is a possible door event based on may

involve the following:

• Compute where L t is a threshold to

determine whether the variance is significant and possibly due to door movement. L t may depend upon the sampling frequency f s . An example value of L t is 0.6 when f s = 50Hz. Other values of L t can be used in other examples.

• If n t > C t , where C t is a specified threshold depending upon f s , then it is likely there is a possible door event. In the above, C t may be set to 3 when f s = 50Hz, in some examples. Other values of C t can be used in other examples. [00146] Task 824: If it is determined at task 822 that there is a possible door event, then the procedure activates the gyroscope, and the procedure sets V = i (to indicate the time point at which he gyroscope was activated).

[00147] Task 826: If the parameter useAccelForDoorDecision is set to True (as determined at 820), then the procedure sets the parameter

useAccelForDoorDecision to True, and sets ΐ = i. Also, the procedure computes a threshold T A based on is used to control how long the

accelerometer is to be used to determine whether the door is in a closed position. may be determined by * as follows. Let G denote a specified

threshold that depends upon

• Compute where L G

is a threshold set according to the gyroscope's typical readings in a stationary position without movement. An example value of L G is 0.2. Other values of L G can be used in other examples.

• If n G > C G , where C G is a specified threshold depending upon f s , then it is likely that the gyroscope is not yet stabilized due to door movement. As a result, T A is set to a larger value, e.g., 20/ s ; otherwise, since the gyroscope is stabilized, T A is set to a smaller value, e.g., In the above, C G may be set to 3 when Other values of C G can be used in other examples.

[00148] Task 828: The procedure determines if the elapsed time (i - ΐ) is greater than or equal to T A . If not, the process returns to task 802.

[00149] Task 830: If the elapsed time (i - ΐ) is greater than or equal to T A , then the procedure determines based on the filtered tangential acceleration data

f tne door is in tne closed position. If not, then the process returns to task

802.

[001 50] Task 832: If it is determined at task 830 that the door is in the closed position, then the procedure changes the door status to "Closed," and can send an indication of the closed status to a target entity. [00151 ] Use of multiple filters

[00152] The foregoing procedure of Figs. 8A-8B uses a single MR filter to filter acceleration data.

[00153] In some implementations of the present disclosure, multiple different filters can be used to filter acceleration data, to address the dilemma when selecting a single MR filter to meet both conditions C1 and C2 can be difficult or sub-optimal.

[00154] The following solution uses two filters (a short filter and a long filter) to perform door status detection.

51 . Monitor the tangential acceleration data from the accelerometer. If a substantial jump in the tangential acceleration data is detected, continue to S2.

52. Activate the gyroscope to track the angle movement.

a. If the angle movement is away from the door frame and the turned angle is large enough, a door open event is reported;

b. If the angle movement is small, continue to S3.

53. Check if the filtered tangential acceleration data (filtered using a short filter) is stable and close to a bias trained by using the same short filter when the door is closed and at a stationary position. If the answer is yes, a door close event is reported; otherwise continue to S4.

54. Check if the filtered tangential acceleration data (filtered using a long filter) is stable and close to a bias trained by using the same long filter when the door is closed and at a stationary position. If the answer is yes, a door close event is reported.

[00155] The short filter ensures that successful detection can be promptly completed in normal conditions and thus condition C1 is met. The long filter ensures that robust and reliable detection is possible in adverse conditions (e.g., in strong winds or on an open sea or in other unstable environments) and thus condition C2 is met. [00156] Figs. 9A-9B illustrate a procedure where a long filter and a short filter are used. In Figs. 9A-9B, similar tasks as those depicted in Figs. 8A-8B are assigned the same reference numerals. The following describes just the changed tasks or new tasks in Figs. 9A-9B, as compared to the tasks of Figs. 8A-8B.

[00157] Task 906: Based on the acceleration data from the

accelerometer received at 804, first filtered acceleration data and first

variances are derived using the short MR filter, and second filtered data

a nd second variances are derived using the long MR

filter.

[00158] Task 924: If it is determined at task 822 that there is a possible door event, then the procedure activates the gyroscope, and the procedure sets and determines a threshold T G . T G may be adjusted according to e.g., if significantly large values are observed in may be adjusted higher. Let u denote a positive threshold, and let N(U) denote the number of times that

a re over u > i- e - where \S \ denotes

the cardinality of a set S. Then if N(U) is less than a specified threshold, then T G is set to a default value, say 3 seconds; otherwise, if N(U) is greater than or equal to

the specified threshold, then T G is adjusted to a larger value, say 5 seconds. The threshold U may be learned from offline training data, and may depend upon what filter is being used. Example values of U are 0.1 meter per squared second (m/s 2 ), 0.5 m/s 2 , 1 m/s 2 , or another value. The threshold used to check N(U) is likely dependent upon the sampling frequency Example values of such a

threshold fo is 25, 30, 50, 100, or another value.

[00159] Task 830: If the elapsed time (i - ΐ) is greater than or equal to T A , then the procedure determines based on the filtered tangential acceleration data (filtered using the short filter) if the door is in the closed position. If not (which means that the procedure is unable to determine the door closed status using filtered tangential acceleration data filtered using the short filter), then the procedure proceeds to task 934. [00160] Task 832: If it is determined at task 830 that the door is in the closed position, then the procedure changes the door status to "Closed," and can send an indication of the closed status to a target entity.

[00161 ] Task 934: If the procedure is unable to determine (at 830) based on the filtered acceleration data (filtered using the short filter) that the door is not

in the closed position, then the procedure determines another threshold, based on may be based o and

by using a method similar to the one used to determine T G above.

That is, T B may be adjusted higher if significantly large values are observed in

Similar to the technique discussed above for determining T G , the

procedure can choose between a default value and a second value that is larger than the default value for T B . In addition, the filtered tangential acceleration data

(filtered using the short filter) may be used to adjust T B . Specifically, the

procedure can check the number of times deviate from a trained

mean, i.e., how many times the following condition is not met in the time period

. If N t is less than a specified

threshold, then T B is determined according to by using a method

similar to that described for T G above; otherwise, T B is adjusted to a third value that is larger than the default value. Note that the second value and the third value may be the same in some cases.

[00162] Task 936: The procedure determines if the elapsed time (t - ΐ) is greater than or equal to T B . If not, then the procedure returns to task 802.

[00163] Task 938: If the elapsed time (t - t) is greater than or equal to T B , then the procedure determines based on the filtered tangential acceleration data

(filtered using the long filter) if the door is in a closed position. If the

procedure is able to determine that the door is in the closed position, then the procedure proceeds to task 832. However, if the procedure is unable to determine that the door is in the closed position, then the procedure returns to task 802. [00164] Note that the biases used to determine whether the door is closed or not based on can be different from the biases used together with

These biases may be trained using a method similar to that described below, but with its own set of parameters, which in turn depend upon the filter (short filter or long filter) selected.

[00165] Motion Detection

[00166] Door status detection is enabled only when the moveable platform is not in motion. As discussed above, to detect the motion status of the moveable platform, the motion detection module 208 (Fig. 2) makes use of acceleration data from an accelerometer (e.g., 1 12 in Fig. 2). Specifically, let v t denote the vertical (gravitational) component of the acceleration data (hereinafter referred to as the "vertical acceleration data") from the accelerometer at time instant i. The proposed solution detects the motion status as follows.

[00167] Fig. 10 is a flow diagram of a motion detection procedure according to some examples, which can be performed by the motion detection module 208, for example. The following describes tasks of Fig. 10.

[00168] Task 1 002: The motion detection procedure filters the vertical acceleration data v t to obtain filtered vertical acceleration data v and to estimate a local variance

[00169] Task 1 004: If the variances (variance values) in a motion detection time window between time instants i and remain above a specified

threshol remains above L), the motion detection

procedure proceeds to task 1005; otherwise, the motion detection procedure continues to task 1006. The motion detection procedure detects the variances in the motion detection time window between time instants i and i - T being above L by using a counter to count a number of time instants that the variances are above L; if the counter counts that there has been τ consecutive variances above L, then the procedure proceeds to task 1005. T is a specified constant set according to the sampling frequency f s of the accelerometer. An example value of T is or

some other value.

[00170] Task 1005: The motion detection procedure sets the motion status to "in motion" and continues to task 1 010.

[00171 ] Task 1006: The motion detection procedure detects whether there is a falling edge in the variances between time instants i and where

m is a specified positive integer number. If a "falling edge" (explained below) is detected, the motion detection procedure proceeds to task 1007; otherwise, the procedure continues to task 1008.

[00172] Task 1 007: The motion detection procedure sets the motion status to "no motion", and continues to task 101 0.

[00173] Task 1 008: If the variances in a motion detection time window between time instants i and remain below a specified threshold 0 < U < L,

the motion detection procedure proceeds to task 1009; otherwise the procedure proceeds to task 101 0. The motion detection procedure detects the variances in the motion detection time window between time instants i and i - T being below U by using a counter to count a number of time instants that the variances are below U; if the counter counts that there has been τ consecutive variances above u, then the motion detection procedure proceeds to task 1009.

[00174] Task 1 009: The motion detection procedure sets the motion status to "no motion".

[00175] Task 1 010: The motion detection procedure increments i, i = i + and re-iterates tasks 1002-1009.

[00176] Fig. 1 1 shows a curve 1 102 that represents variances (vertical axis) as a function of time (horizontal axis). Fig. 1 1 also depicts the thresholds L and U, as well as a falling edge 1 104 in the variances. In Fig. 10, the falling edge 1 1 04 is detected in task 1 106, based on a detection of variances in a falling edge time window between time instants i and A "falling edge" refers to a

drop in the variances from a level that is above the threshold L to a level that is below the threshold U. The falling edge 1 104 indicates a transition of the moveable platform from being in motion to being not in motion.

[00177] In Fig. 1 1 , prior to the falling edge 1 104, the moveable platform is indicated to be in motion since the variances in a motion detection time window between time instants i and before the falling edge 1 104 is above

the threshold L. After the falling edge 1 1 04, the moveable platform is indicated to be not in motion if the variances in a motion detection time window between time instants i and remain below U.

[00178] When f s = 50Hz, an example value of L is 0.5 and an example value of U is 0.08. When the sampling frequency f s changes, different L and U can be used. In other examples, other values of L and u can be used.

[00179] Note that the proposed motion detection solution above is asymmetric in that it uses both edge detection and a counter associated with an upper bound u to detect "no motion" and it uses only a counter associated with a lower bound to detect "in motion". The primary reason for such an asymmetric design is that the

requirements for detecting "in motion" and those for detecting "no motion" are different.

[00180] A "no motion" status is detected within a few seconds (depending upon the sampling frequency of the accelerometer) after the moveable platform comes to a stop so that door status detection is ready to use. Since detection of a falling edge can be faster than determining whethe remains below U, the solution

chooses to use a hybrid approach of detecting "no motion" status where both edge detection and a variance upper bound are used.

[00181 ] The detection of "in motion" status is expected to be robust but is subject to less stringent time constraint than the detection of "no motion" status. [00182] In task 1002 in Fig. 10, an MR filter with coefficient α may be used to filter the vertical acceleration data v i and to estimate recursively as follows.

[00183] In the foregoing, the variance σξ χ of the vertical acceleration data at time point i is computed based on calculating a square of the vertical acceleration data (vf). Examples of the coefficient a are 0.008 and 0.016 when the sampling frequency of the accelerometer is 50Hz. The coefficient a may be scaled by when the sampling frequency f s is not 50Hz. In other examples, other values of the coefficient a may be used.

[00184] In some cases, the variance may be further filtered by using a second

M R filter to obtain for more stability. In these cases, will be used in place of

in the motion detection solution above. An example of such a second MR filter is

a filter with coefficient a set to 0.02 or some other value.

[00185] Training

[00186] To use the first filtered tangential acceleration data (filtered

using the short filter) to detect whether a door is in a closed position, the DOC process according to some implementations checks if both of the following conditions hold for all where D is a specified constant depending upon

the sampling frequency f s . An example value of D is 2f s which is equivalent to 2 seconds in an example. In other examples, other values of D can be used.

In the above, are respectively the tangential bias due to gravity, the radial bias due to gravity, and the tangential noise level. Similar checks are performed for the second filtered tangential acceleration data (filtered using the long filter), where a different set of may be used. In the above,

an example value of the constant C 1 is 0.0175, which is roughly equal to

sin(1 * pi/180) and obtained by using the Taylor series of the sine or cosine function. An example value of the constant C 2 is 2.5758 and an example value of the constant

In other examples, other values of and C 3 can be used.

[00187] In accordance with some implementations, the DOC process can train the bias values and the noise levels The training process is initiated as soon

as the moveable platform's motion status is detected to be in "no motion". Let i 0 denote the starting time of the training (or learning) process.

[00188] To account for the possibility that a previous known door state may be wrong, the training process can run as long as one of the following conditions is true: a. The current door status is either closed or unknown.

b. and optionally where F is a specified threshold. An

example value of F is 0.01 when the sampling frequency is 50 Hz. In other examples, other values of F can be used.

[00189] The training process computes the mean and variance of the radial acceleration data and the mean and variance of the tangential acceleration

data For example, may be computed using Eqs. 1 -4 discussed

above, which are reproduced below.

[001 90] The values of (μ Τιί , σ Γ 2 ; ) can be computed in a similar manner. In the above, K is the window length used to compute the mean and variances, and may depend upon the sampling frequency f s .

[001 91 ] The training process of learning stationary values of acceleration data (radial acceleration data and tangential acceleration data) is depicted in Fig. 1 2.

[001 92] Task 1 202: The process initializes the following buffers that are used in the training process: and B r . The A t buffer is used to store a

computed stationary mean value of the tangential acceleration data, the buffer 4 r is used to store a computed stationary mean value of the radial acceleration data, the buffer B t is used to store a computed stationary variance value of the tangential acceleration data, and the buffer B r is used to store a computed stationary variance value of the radial acceleration data. The buffer A M is used to store a stationary variance value of the acceleration magnitude (M t calculated according to M t = of the acceleration data.

[001 93] Let N be a positive integer. Example values of N can be 7, 8, 1 1 , 1 3, 1 6, 1 7, and so forth. The training process then divides the sequence of acceleration data samples into N sub-sequences. In some examples, N buffers are used to store the respective variance and mean values computed for the respective subsequences.

[001 94] If N buffers are used, then there are: N A M buffers, represented as

buffers, represented as buffers, represented as

buffers, represented as and N B r buffers,

represented as

[001 95] Although Fig. 1 2 refers to an example where specific buffers are used, it is noted that in other examples, other data structures can be used to store the respective values. [00196] Task 1 204: The training process computes the mean and variance of the radial acceleration data and the mean and variance of the tangential

acceleration data using computations similar to that performed in Eqs. 1 -4

above.

[00197] Task 1 206: Since a sequence of acceleration data samples is divided into N sub-sequences, in some examples, N buffers are used to store the respective variance and mean values computed for the respective sub-sequences. The training process updates the buffers according to local minima values, as follows. Let s = i mod N. If max then update the buffers as follows.

[00198] In the foregoing, at time point i is less

than the value in the buffer then the buffer A MiS is updated with the value

max (i.e., maximum of and the remaining buffers

and B r s are updated with respective mean and variance values and

[00199] Effectively, after all of the tangential and radial acceleration data samples have been processed, the N buffers contain N respective local minima

of the mean of the tangential acceleration data samples. Similarly, the N buffers

contain N respective local minima of the mean of the radial

acceleration data samples, the N buffers contain N respective local

minima of the variance of the tangential acceleration data samples, and the L

buffers contain N respective local minima of the variance of the

radial acceleration data samples. [00200] Task 1 208: If or a door open event is detected, where T 0 is a

specified time limit for training since motion status is changed to "no motion," then the training process updates the stationary mean and variance values of the radial and tangential acceleration data according to global extrema. More specifically, in some examples, the training process finds the index Γ = org max l A M l , which finds the maximum (an example of the global extrema) of each of the variance values in the N buffers Note that T 0 represents a learning time period

expressed as a number of acceleration data samples. An example value of T 0 is 30 * 50, which is equivalent to 30 seconds when the sampling frequency is 50 Hz. In other examples, other values of T 0 can be used. After learning for T 0 samples, the mean and variance values of the radial and tangential acceleration data is updated as fi t , fi r , of , and σ 2 . Task 1208 includes:

• recording as the stationary estimates of tangential and

radial components, respectively;

• recording as the estimates of tangential and radial

variance corresponding to the stationary values, respectively; and

• resetting A M such that A M l = M * , I = 0, ··· , N - 1.

[00201 ] After the initial training period since motion status changes (the initial training process might end either after T 0 samples are processed or at a door open event), a longer training period may be used. For example, 7\ may be set to

8 * 3600 * 50, which is equivalent to 8 hours when the sampling frequency is 50Hz. Note that the initial training period applies whenever the motion status is switched from "in motion" to "no motion".

[00202] In the above, the task 1206 essentially computes

[00203] As such, the traiing process described above is a maxmin method. In other examples, a minmax method can be used to estimate the stationary radial and acceleration mean and variance values by altering the order of minimization and maximization operations above. [00204] In some cases, the above training process can be simplified by using

in place Of max

[00205] In some examples, 2 may be approximated by using an M R filter

with coefficient α as follows.

[00206] Similarly and may be approximated by using the MR filter.

[00207] More generally, finding the mean and variance of the tangential and radial acceleration data values involves 1 ) finding local extrema values

(minimum values or maximum values depending upon whether the maxmin method or the minmax method is used) for respective sub-sequences

then finding a global extrema (either maximum or minimum depending upon whether the maxmin method or the minmax method is used) in the local extrema values, and 3) finally determining the mean and variance of the tangential and radial acceleration data values that corrrespond to the global extrema found (e.g., co-located). For example, if the global extrema is reached at time instant V, then the mean and variance computed at time instant may be used as

the estimates of respectively.

[00208] The stationary mean and variance values of the tangential and radial acceleration data values can be used directly in detecting

convergence of the tangential and radial acceleration data as discussed above for determining whether a door close event has occurred. For each learning period, the current stationary mean tangential and acceleration data values fi t and fi r can be used for the next T samples until new estimates are available for the next learning period.

[00209] Combined Door Status Detection and Motion Detection [00210] In some cases, activation of the gyroscope in the DOC process may be further improved to distinguish normal door operations from full-body moveable platform movement, e.g., the moveable platform may turn when a vehicle towing the moveable platform is making a turn or the moveable platform may swivel around when the moveable platform is lifted by a crane. In these cases, vertical acceleration data may be used in conjunction with tangential acceleration data in the DOC process. This is based on the observation that vertical variance is typically higher in full body movement than in normal door operations. As such gi t (the gyroscope activation indication) may be set to 0 (to maintain the gyroscope deactivated) if large vertical variance is observed in the absence of large tangential variance. Note that when the moveable platform is moving with its door in the open position, significant tangential variance may be observed. In one example, gi t is set to 0 if the following conditions are both satisfied: i) is greater than a specified threshold, say 0.2, 0.3, 1 , or some other

value. ii) is less than a specified threshold, say 5, 10, 20, or some other value.

[0021 1 ] In another example, a third condition may have to be satisfied as

well. Generally, the foregoing criteria specify that the gyroscope is not to be turned on if the vertical variance is large (greater than a specified threshold), and the tangential variance is small (less than a specified threshold).

[00212] To further improve robustness of door status detection against full body movement, in some cases the DOC process may be modified to track vertical acceleration data in determining whether the door is in the open position or not. Specifically, as shown in Fig. 13, the DOC process starts in an idle state, where the gyroscope is deactivated. In response to detecting a trigger (such as based on the condition in task 822 of Fig. 9A), the DOC process transitions to a gyroscope waiting state 1304 (where gyroscope calibration can be performed as part of activating the gyroscope). Upon completion of the gyroscope calibration, the gyroscope is ready for operation, and the DOC process transitions to the gyroscope active state 1306 where the gyroscope waits for time duration T G and determines whether the door has moved to the open position in response to the aggregate value, α,- , computed based on measurements from the gyroscope over the time duration T G . If the door is detected to be open, the the DOC process transitions back to the idle state 1302.

[00213] However, if the time duration T G expires and the DOC process detects a door open angle (the angle of rotation of the door is greater than 9 open as determined at task 816 in Fig. 9A) but that the moveable platform is not stationary, the DOC process transitions from the state 1306 to a state 1 308 where the DOC process may continue tracking the vertical variance, of the vertical acceleration data for a time

duration T 0 to make sure that the angle movement is not due to full body movement of the moveable platform due to making a turn or some other movement. For example, the DOC process may report that the door is in the open position only if remains below a specified threshold, e.g., 0.05, 0.1 , 0.2, or some other value, which may depend upon the moveable platform and/or door type, for 0.5, 1 , 2 seconds, or some other time interval. In the above, T 0 may be set for 3, 5, 10 seconds, or some other time duration.

[00214] The DOC process returns from the state 1308 to the idle state 1 302 in response to the door open status being successfully detected or in response to the time duration T 0 expiring and the DOC unable to conclusively determine that the door is open.

[00215] From the state 1 306, if the time duration T G expires and the DOC process detects a small angle of rotation of the door (the angle of rotation of the door is less than , the DOC process transitions from the state 1306 to a state 131 0 where

the DOC process uses short filtered tangential acceleration data (filtered using the short filter) to determine after passage of the time duration T A (see tasks 828 and 830 in Fig. 9B) whether the door is in the closed state. If a door close status is detected, the DOC process returns from the state 1 310 to the idle state 1302.

[00216] If the time duration T A expires and the detection using the short filtered tangential acceleration data is inconclusive, the DOC process transitions from the state 1310 to the state 1312, where the DOC process uses short filtered tangential acceleration data (filtered using the short filter) to determine after passage of the time duration T B (see tasks 936 and 938 in Fig. 9B) whether the door is in the closed state. If a door close status is detected or the time duration T B expired and the door close detection is inconclusive, the DOC process returns from the state 1 312 to the idle state 1302.

[00217] In some other cases, the DOC process may make use of the result of motion detection. For example, if a moveable platform is detected to be in motion, tangential acceleration data is likely subject to significant variation if the door is open. Such observation can lead to the following modifications to the DOC process. If all of the following conditions are satisfied, the DOC process determines that the door is in the closed position. a) Motion is detected, e.g., by observing vertical acceleration data as described above. b) Door status is unknown or in the open position. c) Tangential variance remains below a specified threshold, e.g. 10, 20, or some other value, for an extended period of time, e.g. 20, 30, 60 seconds, or some other time duration.

[00218] System architecture

[00219] The processes (e.g., DOC process or training process) described above can be performed by the processor(s) 1 18 of the sensor device 108, or by

processor(s) of a computer system (implemented with a computer or multiple computers), where the computer system is separate from the sensor device 108. In some examples, the processes can be performed by machine-readable instructions executable on the processor(s) 1 1 8. The machine-readable instructions can be stored in a non-transitory computer-readable or machine-readable storage medium. The storage medium can include any or some combination of the following: a semiconductor memory device such as a dynamic or static random access memory (a DRAM or SRAM), an erasable and programmable read-only memory (EPROM), an electrically erasable and programmable read-only memory (EEPROM) and flash memory; a magnetic disk such as a fixed, floppy and removable disk; another magnetic medium including tape; an optical medium such as a compact disk (CD) or a digital video disk (DVD); or another type of storage device. Note that the instructions discussed above can be provided on one computer-readable or machine-readable storage medium, or alternatively, can be provided on multiple computer-readable or machine-readable storage media distributed in a large system having possibly plural nodes. Such computer-readable or machine-readable storage medium or media is (are) considered to be part of an article (or article of

manufacture). An article or article of manufacture can refer to any manufactured single component or multiple components. The storage medium or media can be located either in the machine running the machine-readable instructions, or located at a remote site from which machine-readable instructions can be downloaded over a network for execution.

[00220] In the foregoing description, numerous details are set forth to provide an understanding of the subject disclosed herein. However, implementations may be practiced without some of these details. Other implementations may include modifications and variations from the details discussed above. It is intended that the appended claims cover such modifications and variations.