This application is a Continuation of International Application No. PCT/CN2020/093204, filed on May 29, 2020, the contents of which are hereby incorporated by reference.
Implementations of the present disclosure generally relate to navigation applications, more specifically, to methods, devices, computer program product and computer-readable storage medium for indoor navigation.
Navigation applications have been increasingly popular in recent years. A navigation application may be a computer software program installed on a terminal device equipped with a Global Positioning System (GPS) sensor. Based on signals received from GPS satellites and a map, the navigation application may provide a location of the terminal device. However, when a user of the navigation application enters into a building, the signals from the GPS satellites may be attenuated and scattered by roofs, walls and other objects of the building. Therefore, the navigation application cannot provide accurate indoor navigation.
Dedicated sensors are developed for measuring acceleration and orientation of a moving user. For example, terminal devices such as cell phones are equipped with those sensors and thus acceleration and orientation signals of the user may be detected. However, it is difficult to process these signals and obtain accurate movement of the user in an effective and convenience manner.
In accordance with one implementation of the present disclosure, a new approach for determining a movement orientation of a user is proposed in indoor navigation. Generally speaking, a device orientation of a terminal device is obtained based on at least one signal stream collected from the terminal device carried by a moving user. A deviation degree is determined based on the at least one signal stream, here the deviation degree represents a deviation between a movement orientation of the user and an actual device orientation of the terminal device. The movement orientation is determined based on the device orientation in accordance with a determination that the deviation degree is below a threshold degree. With the above implementation, the movement orientation of the user is determined in a more effective and accurate way, and thus accuracy of the indoor navigation is increased.
It is to be understood that the Summary is not intended to identify key or essential features of implementations of the present disclosure, nor is it intended to be used to limit the scope of the present disclosure. Other features of the present disclosure will become easily comprehensible through the description below.
The details of one or more implementations of the present disclosure are set forth in the accompanying drawings and the description below. Other features, aspects, and advantages of the disclosure will become apparent from the description, the drawings, and the claims, wherein:
Throughout the figures, same or similar reference numbers will always indicate same or similar elements.
Principle of the present disclosure will now be described with reference to some example implementations. It is to be understood that these implementations are described only for the purpose of illustration and help those skilled in the art to understand and implement the present disclosure, without suggesting any limitations as to the scope of the disclosure. The disclosure can be implemented in various manners other than the ones describe below.
As used herein, the term “include” and its variants are to be read as open terms that mean “include, but is not limited to”. The term “based on” is to be read as “based at least in part on”. The term “a” is to be read as “one or more” unless otherwise specified. The term “one implementation” and “an implementation” are to be read as “at least one implementation”. The term “another implementation” is to be read as “at least one other implementation”. Moreover, it is to be understood that in the context of the present disclosure, the terms “first”, “second” and the like are used to indicate individual elements or components, without suggesting any limitation as to the order of these elements. Further, a first element may or may not be the same as a second element. Other definitions, explicit and implicit, may be included below.
Navigation applications are widely installed in terminal devices, and GPS sensors in the terminal devices may receive signals from GPS satellites and provide locations of the terminal device. However, when a user of the terminal device enters into a building, the signals may be weaken and thus become useless. Recently, Inertial Measurement Unit (IMU) sensors have been equipped in terminal devices, and signal streams collected from the IMU sensors may be processed to determine movement of a moving user that carries the terminal device.
Reference will be made to
A Pedestrian Dead Reckoning (PDR) approach has been proposed for the indoor navigation. The PDR approach involves three main steps: 1) identifying a stepping event of a user, 2) determining a step length of the user, and 3) determining an orientation of the user. Here, the stepping event refers to an event that the user extends his/her leg and walks one step. As determining the step length and the orientation are both based on the identified stepping event, stepping event identification becomes a foundation for the indoor navigation. Peak detection and zero-crossing detection algorithms are developed for identifying the stepping event from the signal stream. However, due to noise and bias from the sensor 130, the signal stream should be filtered first. Further, it is hard to build criteria for detecting the peak and zero in the filtered signal stream.
In order to at least partially solve the above and other potential problems, a new method and device for identifying a stepping event are provided herein. In accordance with an example implementation of the present disclosure, two time windows with different lengths are utilized for processing the signal stream collected from the sensor 130. As the two time windows have different widths, signal fragments respectively within the two time windows show different patterns. Then, a stepping event may be identified from the signal stream based on a comparison of the signal fragments. With the above implementation, there is no need for filtering the noise and bias in the signal stream and identify the peak and zero. Instead, the stepping event may be identified in a more efficient and convenience manner.
Reference will be made to
A first time window 210 (illustrated by a shaded block) and a second time window 220 (illustrated by a blank block) are defined, and the first time window 310 is shorter than the second time window 320. A first signal fragment 312 and a second signal fragment 322 are obtained within the first and second time windows 310 and 320 in the acceleration signal stream 330, respectively. Here, the first signal fragment 212 is a portion of the acceleration signal stream 330 within the first time window 310, and the second signal fragment 322 is a portion of the acceleration signal stream 330 within the second time window 320.
During the movement of the user, acceleration amplitudes at different frames may vary in the acceleration signal stream 330. Usually, a change in a short time window is more dramatic than that in a long time window. Therefore, the first and second signal fragments 312 and 322 may involve different amplitude changes and may help to identify a stepping event.
In one example implementation of the present disclosure, the first time window 310 may be within the second time window 320. Although
It is to be understood that
Having described details about obtaining the first and second signal fragments 312 and 322, reference will be made back to
Where aavg1 represents the first amplitude feature 412 for the first time window 310, n1 represents the number of frames included in the first time window 310, ampi1 represents an amplitude at the ith frame in the first signal fragment 312.
The second amplitude feature 422 may be determined in a similar manner based on Formula 2 as below.
Where aavh2 represents the second amplitude feature 422 for the second time window 320, n2 represents the number of frames included in the second time window 320, and ampi2 represents an amplitude at the ith frame in the second signal fragment 322.
It is to be understood that the above Formulas 1 and 2 are just examples for determining the first and second amplitude features 412 and 422. Alternatively and/or in addition to, the first and second amplitude features 412 and 422 may be determined based on an average of a square of the amplitudes, or another formula that may reflect respective amplitudes within respective time windows.
For ease of description, the first and second amplitude features 412 and 422 may be represented by frame identification of the end frames. Supposing both of the first and second time windows 310 and 320 end at the jth frame in the acceleration signal stream 330, the first and second time windows 310 and 320 may be called as the first and second windows for the jth frame, and the first and second amplitude features 412 and 422 may be called as the first and second amplitude features for the jth frame. Further, the first and second amplitude features 412 and 422 may be compared, and a deviation 430 may be determined therebetween.
Referring back to
dev
j
=a
avg
1
−a
avg
2 Formula 3
Where devj represents the deviation 430 at the jth frame in the acceleration signal stream 330, aavg1 and aavg2 represent the first and second amplitude features 412 and 422 for the jth frame, respectively. Continuing the above example, when the first and second time windows 310 and 320 have the same end frame, the jth frame may be the end frame.
It is to be understood that the above Formula 3 is just an example for determining the deviation 430. Alternatively and/or in addition to, the deviation 430 may be determined based on any of Formulas 4 and 5 as below.
dev
j=(aavg1)2−(aavg1) 2 Formula 4
dev
j=√{square root over ((aavg1)2−(aavg1)2)} Formula 5
In Formulas 4 and 5, symbols have the same meaning as those in Formula 3 and details will be omitted.
As the change in the first time window 310 may be more dramatic than the second time window 320, the stepping event may be easily identified based on the deviation 430. In one example implementation of the present disclosure, a stepping event may be identified at the jth frame if the deviation 430 exceeds a threshold deviation, and Formula 6 may be used to identify the stepping event at the jth frame in the acceleration signal stream 330. Here, the threshold deviation may be determined based on a historical experience in advance.
Where Sjdev represents whether a stepping event is identified at the jth frame in the acceleration signal stream 330 based on the deviation 430, devj represents the deviation 430 at the jth frame in the acceleration signal stream 330, and THdev, represents a threshold deviation.
As the deviation 430 is between the first and second amplitude feature 412 and 422 from the same acceleration signal stream suffered by the same noise and bias, the deviation 430 may be less sensitive to the noise and bias, which results in a more reliable identification of the stepping event. Compared with the existing PDR approach based on the peak and zero detection, the present disclosure may reduce impacts of the noise and bias and thus increase the accuracy and performance in identifying the stepping event.
It is to be understood that the above Formula 6 is just an example for identifying a stepping event directly based on the deviation 430 related to a single time point when the user walks. In other example implementations of the present disclosure, the stepping event may be further determined based on deviations determined in other ways. In one example implementation of the present disclosure, the first and second time windows 310 and 320 may move forward along the acceleration signal stream 330, respectively. Then, a step intensity may be determined based on an accumulation of multiple deviations for multiple time points when the user walks. Reference will be made to
Supposing the first and second time windows 310 and 320 have the same end frame, the end frame may cover a group of frames during movement. Therefore, the step intensity may be determined for the group of frames. Specifically, a first group of signal fragments may be obtained within the first time windows 310 during the movement, similarly, a second group of signal fragments may be obtained within the second time windows 320. Further, deviations related to the group of frames may be summed for determining the step intensity.
In one example implementation of the present disclosure, a first group of amplitude features and a second group of amplitude features may be determined based on the first and second groups of signal fragments, respectively. As the first and second time windows 310 and 320 move together, a deviation at each frame during the movement may be determined. Supposing the movement covers a group of m frames, a deviation may be determined for the kth frame in the group of frames. At this point, a summation of a group of deviations between the first and second groups of amplitude features may be determined from Formula 7 as below.
intensityj=Σk=1m (devk)2 Formula 7
Where intensityj represents a step intensity for a group of frames that ends at the jth frame in the acceleration signal stream 330, m represents the number of frames included in the group of frames, and devk represents a deviation for the kth frame in the group of frames, which is determined based on the first and second signal fragments associated with the kth frame according to any of Formulas 3 to 5.
It is to be understood that the above Formula 7 is just an example for determining the step intensity. In another example implementation of the present disclosure, the step intensity may be determined based on any of Formulas 8 to 11 as below.
intensityj=Σk=1mdevk Formula 8
intensityj=Σk=1mdevkΔt Formula 9
intensityj=Σk=1m(devk)2Δt Formula 10
intensityj=√{square root over (Σk=1m(devk)2Δt)} Formula 11
Where symbols in Formulas 8 to 11 have the same meaning as those in Formula 7, and Δt represents a sampling interval of the acceleration signal stream 330.
With the above implementation, deviations related to a group of frames during a time duration are considered in determining the stepping event when the user walks, and continuous changes in the amplitudes of the acceleration signal stream 330 may be monitored for the stepping event identification. Therefore, incorrect identification caused by a single deviation related to a single time point may be reduced, and the accuracy and performance for stepping event identification may be further enhanced.
In one example implementation of the present disclosure, the stepping event may be identified based on a comparison between the step intensity and a threshold intensity according to Formula 12, here the threshold intensity may be determined based on a historical experience.
Where Sjintensity represents whether a stepping event is identified based on the step intensity at the jth frame in the acceleration signal stream 330, intensityj represents a step intensity associated with the jth frame in the acceleration signal stream 330, and THintensity represents a threshold intensity.
In one example implementation of the present disclosure, if the step intensity is below the threshold intensity, the first and second time windows 310 and 320 may move forward by another frame to obtain a new step intensity for a new group of frames including more frames. If the step intensity for the group of frames exceeds the threshold intensity, a stepping event is identified (for example, at the jth frame). Once the stepping event is identified, the group of frames may be reset and begin at a frame following the group of frames. At this point, the first and second time windows 310 and 320 may continuously move forward along the acceleration signal stream 330 for identifying a further stepping event. Reference will be made to
It is to be understood that curves of step intensities in
In one example implementation of the present disclosure, the above methods for identifying the stepping event may be combined. For example, identifications based on the single deviation and the step intensity may be combined together for an enhanced identification. Specifically, a stepping event may be identified at the jth frame in the acceleration signal stream 330 based on Formula 13 as below.
Sjfinal={j|Sjdev∩Sjintensity} Formula 13
Where Sjfinal a final result of whether a stepping event is identified at the jth frame in the acceleration signal stream 330, Sjdev represents a result determined based on Formula 6, and Ajintensity represents a result determined based on Formula 12. With the above implementations, both of the single deviation and the step intensity may be considered in identifying the stepping event. Accordingly, errors caused by accident may be further reduced.
The above paragraphs have described details about identifying the stepping events. Afterwards, the identified stepping events may be further verified based on any of an acceleration amplitude of the acceleration signal stream 330 and a frequency limitation. Reference will be made to
As illustrated in
Where aj represents the acceleration amplitude associated with the jth frame in the acceleration signal stream 330, and amplitude_xj, amplitude_yj and amplitude_zj represent amplitudes in the x, y, and z dimensions, respectively.
Further, the stepping event may be verified based on a comparison between the acceleration amplitude and a threshold amplitude according to Formula 15, here the threshold amplitude may be determined based on a historical experience.
Where Sjamplitude represents whether a stepping event is identified based on the acceleration amplitude at the jth frame in the acceleration signal stream 330, aj represents the acceleration amplitude associated with the jth frame in the acceleration signal stream 330, and THamplitude represents a threshold amplitude.
According to the above Formula 15, if an acceleration amplitude for a frame, at which the stepping event is identified, exceeds the threshold amplitude, then the stepping event may be verified. With this implementation, more accuracy may be brought into the stepping event identification.
In one example implementation of the present disclosure, identifications based on the single deviation, the step intensity, and the acceleration amplitude may be combined together for a further enhanced identification. Specifically, a stepping event may be identified at the jth frame in the acceleration signal stream 330 based on Formula 16 as below.
Sjfinal={j|Sjdev∩Sjintensity∩Sjamplitude} Formula 16
Where Sjfinal a final result of whether a stepping event is identified at the jth frame in the acceleration signal stream 330, Sjdev represents a result determined based on Formula 6, Sjintensity represents a result determined based on Formula 12, and Sjamplitude represents whether a stepping event is verified based on Formula 15. With the above implementations, the accuracy and performance of the stepping event identification may be further enhanced.
In one example implementation of the present disclosure, the stepping event may be verified according to a frequency limitation. The frequency limitation may be defined according to the historical experience. Usually, the historical experience may show that a frequency of a common walk is one to three steps per second. If the frequency is out of the frequency limitation, then a warning may be provided. Supposing a frequency of the stepping events is 2 steps per second, the stepping events may be verified. If a frequency is 5 steps per second, then the stepping event will not be verified and a warning will be outputted. With the above implementation, the identified stepping events may be verified based on common senses about the frequency. Accordingly, more reliable stepping event identification may be provided.
It is to be understood that identifying the stepping event is just a beginning of the indoor navigation. Once a stepping event is identified, a step length associated with the stepping event may be obtained. Reference will be made to
In one example implementation of the present disclosure, the step length model 820 characterizes a polynomial association between a step length of a reference user in the reference users, an extreme value, an average value, and a frequency of an acceleration signal stream collected by an acceleration sensor associated with the reference user. For example, the step length model may be determined based on Formula 17 as below.
Where Lengthstep represents a step length , a, b, c, d and u represent hyper-parameters, respectively, amaxstep, aminstep, and aavgstep represent the maximum, minimum, and the average amplitude of the acceleration signal within the determined step window, respectively, f represents a walking frequency associated with the stepping event, m represents the number of frames included in the step window, and Δt represents a sampling interval of the acceleration signal stream 330.
With the above implementation, the polynomial association may be trained in a simple manner. In one example implementation of the present disclosure, values related to Lengthstep, amaxstep, aminstep, aavgstep, f, m, and Δt may be obtained for training the step length model 820. Once the step length model 820 is successfully trained, the acceleration signal stream 330 may be easily processed and then inputted into the step length model 820 for a step length determination.
In order to obtain the step length for the user, extreme values (including a maximum and a minimum) within the stepping window associated with the stepping event may be identified from the acceleration signal stream 330, an average value for the stepping window may be determined, and a frequency of the stepping event may also be determined. Further, the step length may be determined based on the step length model 820, the extreme value, the average value, and the frequency. In other words, the acceleration signal stream 330 may be processed for extracting parameters related to amaxstep, aminstep, aavgstep, f, m, and Δt. Next, the extracted parameters may be inputted into the step length model 820 and then a step length may be outputted.
It is to be understood that the above Formula 17 is just an example model for the step length. In other implementations, based on various types of machine learning techniques, the step length model 820 may be represented by another form other than the polynomial association.
In one example implementation of the present disclosure, behavior modes of the user may be considered in identifying the stepping event and/or determining the step length. For example, the walking modes may be classified into walking, stroll, still and sway modes. Accordingly, various models may be trained based on the above behavior modes so as to obtain more accurate stepping events and associated step lengths. In one example implementation of the present disclosure, movement orientations related to the identified stepping events may be determined. In turn, a speed and a trajectory of the user may be determined.
In one example implementation of the present disclosure, a speed of the user may be determined based on the step length and the time duration associated with the step length. Alternatively and/or in addition to, the speed may be determined based on multiple step lengths and multiple time durations. For example, a length summation may be calculated from the multiple step lengths and a time summation may be calculated from the multiple time durations. Next, the speed may be determined according to the length summation and the time summation.
Having described how to identify the stepping event and determine the step length associated with the stepping event, hereinafter, reference will be made to
By now, approaches have been proposed for determining the movement orientation of the user. As the device orientation 922 may be determined from dedicated sensors in the terminal device 920, and the device orientation 922 is usually taken as the movement orientation 912. However, the device orientation 922 and the movement orientation 912 are not always the same and the angle difference 930 may also change during the movement. At this point, how to detect the movement orientation 912 of the user 910 becomes a focus.
In order to at least partially solve the above and other potential problems, a new method and device for determining a movement orientation are provided. According to implementations of the present disclosure, a deviation degree is defined for representing a deviation between the movement orientation 912 of the user 910 and an actual device orientation of the terminal device 920. If the deviation degree is below a threshold degree, the movement orientation 912 may be determined based on the device orientation 920. Otherwise, the movement orientation 912 may be estimated based on machine learning techniques.
Reference will be made to
Further, a deviation degree 1020 is determined based on the signal stream 1010. The greater the deviation degree 1010 is, the greater the angle difference 930 may be. A threshold angle 1022 may be predefined based on the historical experience, and then the deviation degree 1020 may be compared with the threshold degree 1022 to obtain a comparison result 1024. Based on the comparison result 1024, one orientation may be selected from the device orientation 922 and a movement orientation estimation 1030 as the movement orientation 912.
With the above implementation, the deviation degree 1020 may measure whether the movement orientation 912 of the user 910 is consistent with an actual device orientation of the terminal device 920. The movement orientation 912 is determined based on the device orientation 922 only if the two orientations are in consistent with each other. Compared with the solutions for directly using the device orientation 922 as the movement orientation 912, the movement orientation 912 may be determined in a more accurate and reliable manner.
Reference will be made to
Referring to
In one example, the device orientation 922 may be determined based on the IMU orientation. Alternatively and/or in addition to, a machine learning model characterizing an association between the device orientations of reference terminal devices and acceleration signal streams and orientation signal streams collected from the reference terminal devices may be built. Once the machine learning model is trained, the acceleration signal stream 330 and the orientation signal stream 1230 may be inputted into the model to obtain the device orientation 922.
Further, the deviation degree 1020 may be determined, and reference will be made back to
In one implementation of the present disclosure, the deviation degree 1020 may be associated with an angle difference. Specifically, the deviation degree 1020 for the ith frame in the signal stream 1010 may be determined based on Formula 18 as below.
DevDegreei=|βi| Formula 18
Where DevDegreei represents the deviation degree 1020 for the ith frame in the signal stream 1010, and βi represents the angle difference for the ith frame.
Here, the angle difference may be estimated from the deviation model 1220 in
In order to train the deviation model 1220, a sample dataset for reference users may be collected. The sample dataset may comprise a plurality of samples, each of which including parameters relating to one reference user. For example, each sample may include an angle difference, an acceleration signal stream and an orientation signal stream collected during a movement of the reference user. Further, the sample dataset may be used to train the deviation model 1220 such that the trained deviation model 1220 may characterize the association between angle differences and signal streams. Next, the acceleration signal stream 330 and the orientation signal stream 1230 for the user 910 may be processed and then inputted into the deviation model 1220 to obtain the angle difference.
With the above implementation, historical experiences about associations between angle differences and signal streams may be utilized to train the deviation model 1220. In turn, the deviation model 1220 may provide solid knowledge in estimating the angle difference during the movement of the user 910.
In one implementation of the present disclosure, the deviation degree 1020 may also be associated with the movement orientation estimation 1030 of the user 910 and the device orientation 922. Specifically, the deviation degree 1020 for the ith frame in the signal stream 1010 may be determined based on Formula 19 as below.
DevDegreei=|βi−(θi−αi)| Formula 19
Where DevDegreei represents the deviation degree 1020 for the ith frame in the signal stream 1010, βi represents the angle difference for the ith frame, θi represents the movement orientation estimation for the ith frame, and αi represents the device orientation for the ith frame. With the above implementation, the deviation degree 1020 also considers impacts of the movement orientation and the device orientation, and thus a more accurate deviation degree 1020 may be obtained.
Here, an orientation model 1240 may be built for providing the movement orientation estimation 1030. The orientation model 1240 may be built based on the (Long Short Term Memory, LSTM) architecture to estimate the movement orientation. Here, a 2D vector of sin( ) an cos( ) functions related to each frame in the signal stream 1010 and movement orientations collected for reference users may be used to train the orientation model 1240.
In training the orientation model 1240, a sample dataset related with reference the users may be collected. The sample dataset may comprise a plurality of samples, each of which relating to one reference user. Each sample may include actual movement orientation of the reference user, as well as an acceleration signal stream and an orientation signal stream collected during a movement of the reference user. Further, the sample dataset may be used to train the orientation model 1240 such that the trained orientation model 1240 may characterize the association between movement orientations and signal streams. Then, the acceleration signal stream 330 and the orientation signal stream 1230 from the user 910 may be received and then inputted into the orientation model 1240 to obtain the movement orientation estimation 1030.
With the above implementation, historical experiences about associations between movement orientation and signal streams may be utilized to train the orientation model 1240. In turn, the orientation model 1240 may provide solid knowledge in estimating the movement orientation during the movement of the user 910.
It is to be understood that
It is to be understood that, movement orientations for two stepping events may be different during the movement of the user 910, and thus the orientation model 1240 may be trained on a basis of stepping events. Accordingly, a step signal fragment may be extracted from the signal stream in the sample dataset based on a stepping event. Here, the stepping event may be identified according to the method 300 as described in the preceding paragraphs, and a first signal fragment and a second signal fragment respectively within a first time window and a second time window may be obtained from the acceleration signal stream of the reference user. Alternatively and/or in addition to, the stepping event may be identified based on other ways.
At this point, each sample in the sample dataset may be related to a plurality of stepping events, and include respective step signal fragments and respective movement orientations for respective stepping events. Then, the orientation model 1240 may be trained on the basis of stepping events so as to characterize an association between movement orientations and signal fragments for stepping events. Once the orientation model 1240 is successfully trained, a step signal fragment may be extracted from the acceleration signal stream 330 and then inputted into the orientation model 1240 to obtain the movement orientation estimation.
In order to extract the step signal fragment from the acceleration signal stream 330, a first signal fragment and a second signal fragment may be obtained respectively, and the extracted signal fragments may be used for identifying a stepping event. Specifically, the method 300 may be implemented to identify the stepping event, and then a step window associated with the stepping event may be determined. Reference will be made to
It is to be understood that the speed of the user 910 is also an important factor of the movement. The greater the speed is, the greater impacts will be caused in a deviation in the trajectory of the user 910. For example, even if the angle difference is small, a trajectory deviation may reach a greater value when the user 910 moves fast. While if the angle difference is great and the user walks very slow and is almost still, the trajectory deviation may be low. Therefore, in one implementation of the present disclosure, the deviation degree 1020 may also be associated with the speed of the user 910. Specifically, the deviation degree 1020 for the ith frame in the signal stream 1010 may be determined based on Formula 20 as below.
DevDegreei=νi×|βdi−(θi−αi)| Formula 20
Where DevDegreei represents the deviation degree 1020 for the ith frame in the signal stream 1010, νi represents the speed of the user 910 for the ith frame, βi represents the angle difference for the ith frame, θi represents the movement orientation estimation for the ith frame, αi represents the device orientation for the ith frame. It is to be understood that the deviation degree 1020 is a scalar value and thus the speed νi may comprise only a numerical value of the speed without considering an orientation.
In this implementation, the speed may be determined based on methods described in the above paragraphs. Alternatively, and/or in addition to, the speed may be obtained from a machine learning model. For example, the deviation model 1220 may be modified to also include an association between speeds and signal streams for the reference users. Then, the speed of the user 910 may be obtained based on the deviation model 1220 and the signal stream 1010 for the user 910. With the above Formula 20, the speed of the user is also considered in determining the deviation degree 1020, and thus a more reliable and accurate deviation degree 1020 may be obtained.
Once the deviation degree 1020 is determined, the movement orientation 912 may be determined based on a comparison of the deviation degree 1020 and the threshold degree 1022. Referring back to
In one example implementation of the present disclosure, if the deviation degree 1020 exceeds the threshold degree 1022, the movement orientation 912 is determined based on the movement orientation estimation 1030. At this point, as the device orientation 922 significantly differs from the actual movement orientation, the movement orientation estimation 1030 obtained from the orientation model 1240 may be used as the movement orientation 912. Due to the movement orientation estimation 1030 is based on correct historical knowledge included in the orientation model 1240, the movement orientation estimation 1030 may be very close to the actual movement orientation and thus increase the accuracy for movement determination.
Although the above paragraphs have described the procedures for identifying the stepping event, determining the step length and determining the movement orientation in multiple implementations, these implementations may be combined together to form another implementation. For example, based on the above implementations, the movement of the user including both the speed and the orientation may be determined, and then the trajectory may be obtained.
In one implementation of the present disclosure, the above methods 300 and 1100 may be repeated for each stepping event, and thus a trajectory of the user 910 may be obtained.
At the position 1420, the user 910 may walk a second step toward another orientation. Supposing a deviation degree for the second step also exceeds the threshold deviation, the movement orientation 1422 is also set to a movement orientation estimation, and then the user 910 reaches a position 430. Further, the user 910 may walk a third step. Supposing a deviation degree for the third step is below the threshold deviation, the movement orientation 1432 is set to the device orientation. With the above implementation, the trajectory may be determined for the indoor navigation.
In accordance with an example implementation of the present disclosure, the above implementations for indoor navigation may be combined with the outdoor navigation. For example, two navigation modes may be provided in the navigator 110, the GPS sensor may be used in the outdoor navigation mode and the acceleration and orientation sensors may be utilized to support the indoor navigation.
Although implementations of the present disclosure are described by taking the terminal device as an example processing device, the implementations may be performed on a general processing device.
As shown, the device 1500 includes at least one processing unit (or processor) 1510 and a memory 1520. The processing unit 1510 executes computer-executable instructions and may be a real or a virtual processor. In a multi-processing system, multiple processing units execute computer-executable instructions to increase processing power. The memory 1520 may be volatile memory (e.g., registers, cache, RAM), non-volatile memory (e.g., ROM, EEPROM, flash memory), or some combination thereof.
In the example shown in
The storage 1530 may be removable or non-removable, and may include computer-readable storage media such as flash drives, magnetic disks or any other medium which can be used to store information and which can be accessed within the device 1500. The input device(s) 1540 may be one or more of various different input devices. For example, the input device(s) 1540 may include a user device such as a mouse, keyboard, trackball, etc. The input device(s) 1540 may implement one or more natural user interface techniques, such as speech recognition or touch and stylus recognition. As other examples, the input device(s) 1540 may include a scanning device; a network adapter; or another device that provides input to the device 1500. The output device(s) 1550 may be a display, printer, speaker, network adapter, or another device that provides output from the device 1500. The input device(s) 1540 and output device(s) 1550 may be incorporated in a single system or device, such as a touch screen or a virtual reality system.
The communication connection(s) 1560 enables communication over a communication medium to another computing entity. Additionally, functionality of the components of the device 1500 may be implemented in a single computing machine or in multiple computing machines that are able to communicate over communication connections. Thus, the device 1500 may operate in a networked environment using logical connections to one or more other servers, network PCs, or another common network node. By way of example, and not limitation, communication media include wired or wireless networking techniques.
In accordance with one implementation of the present disclosure, the navigator 110 may be executed on the device 1500 to identify the stepping event, determine the step length and the movement orientation of the user. Further, the navigator 110 may provide the speed and trajectory of the user.
Now only for the purpose of illustration, some example implemented will be listed below.
In accordance with one implementation of the present disclosure, a computer-implemented method is provided for indoor navigation. The method comprises: obtaining a first signal fragment and a second signal fragment respectively within a first time window and a second time window in an acceleration signal stream, the acceleration signal stream being collected from an acceleration sensor associated with a moving user, the first time window being shorter than the second time window; determining a first amplitude feature and a second amplitude feature for the first and second time windows based on the first and second signal fragments, respectively; and identifying a stepping event of the user based on a deviation between the first and second amplitude features.
In accordance with one implementation of the present disclosure, the first time window is within the second time window and has a same end as the second time window.
In accordance with one implementation of the present disclosure, determining the first amplitude feature comprises determining the first amplitude feature based on an average value of the first signal fragment.
In accordance with one implementation of the present disclosure, identifying the stepping event comprises: determining the deviation based on a difference between the first and second amplitude features; and identifying the stepping event in accordance with a determination that the deviation exceeds a threshold deviation.
In accordance with one implementation of the present disclosure, identifying the stepping event further comprises: moving the first and second time windows forward along the acceleration signal stream, respectively; determining a step intensity associated with movements of the first and second time windows based on a first group of signal fragments and a second groups of signal fragments obtained during the movements; and identifying the stepping event in accordance with a determination that the step intensity exceeds a threshold intensity.
In accordance with one implementation of the present disclosure, determining the step intensity comprises: determining a first group of amplitude features and a second group of amplitude features based on the first and second groups of signal fragments, respectively; and obtaining a summation of a group of deviations between the first and second groups of amplitude features.
In accordance with one implementation of the present disclosure, the method further comprises: determining, based on measurements in a plurality of dimensions of the acceleration signal stream, respective acceleration amplitudes for frames in the acceleration signal stream; and verifying the stepping event in accordance with a determination that an acceleration amplitude for a frame, at which the stepping event is identified, exceeds a threshold amplitude.
In accordance with one implementation of the present disclosure, the method further comprises: verifying the stepping event in accordance with a determination that a frequency of the stepping event is within a frequency limitation.
In accordance with one implementation of the present disclosure, the method further comprises: determining a step length associated with the stepping event based on a step length model characterizing an association between step lengths of reference users and acceleration signal streams collected by acceleration sensors carried by the reference users.
In accordance with one implementation of the present disclosure, determining the step length comprises: identifying, from the acceleration signal stream, an extreme value within a stepping window associated with the stepping event; determining an average value for the stepping window; and determining the step length based on the step length model, the extreme value, the average value, and a frequency of the stepping event.
In accordance with one implementation of the present disclosure, the step length model characterizes a polynomial association between a step length of a reference user in the reference users, an extreme value, an average value, and a frequency of an acceleration signal stream collected by an acceleration sensor associated with the reference user.
In accordance with one implementation of the present disclosure, the method further comprises: obtaining an orientation signal stream collected by an orientation sensor associated with the user; determining a movement orientation associated with the stepping event based on the acceleration signal stream and the orientation signal stream; and determining a trajectory of the user based on the movement orientation and the step length.
In accordance with one implementation of the present disclosure, an electronic device for indoor navigation. The device comprises: a processing unit; and a memory coupled to the processing unit and storing instructions for execution by the processing unit, the instructions, when executed by the processing unit, causing the device to perform acts comprising: obtaining a first signal fragment and a second signal fragment respectively within a first time window and a second time window in an acceleration signal stream, the acceleration signal stream being collected from an acceleration sensor associated with a moving user, the first time window being shorter than the second time window; determining a first amplitude feature and a second amplitude feature for the first and second time windows based on the first and second signal fragments, respectively; and identifying a stepping event of the user based on a deviation between the first and second amplitude features.
In accordance with one implementation of the present disclosure, the first time window is within the second time window and has a same end as the second time window.
In accordance with one implementation of the present disclosure, determining the first amplitude feature comprises determining the first amplitude feature based on an average value of the first signal fragment.
In accordance with one implementation of the present disclosure, identifying the stepping event comprises: determining the deviation based on a difference between the first and second amplitude features; and identifying the stepping event in accordance with a determination that the deviation exceeds a threshold deviation.
In accordance with one implementation of the present disclosure, identifying the stepping event further comprises: moving the first and second time windows forward along the acceleration signal stream, respectively; determining a step intensity associated with movements of the first and second time windows based on a first group of signal fragments and a second groups of signal fragments obtained during the movements; and identifying the stepping event in accordance with a determination that the step intensity exceeds a threshold intensity.
In accordance with one implementation of the present disclosure, determining the step intensity comprises: determining a first group of amplitude features and a second group of amplitude features based on the first and second groups of signal fragments, respectively; and obtaining a summation of a group of deviations between the first and second groups of amplitude features.
In accordance with one implementation of the present disclosure, the acts further comprise: determining, based on measurements in a plurality of dimensions of the acceleration signal stream, respective acceleration amplitudes for frames in the acceleration signal stream; and verifying the stepping event in accordance with a determination that an acceleration amplitude for a frame, at which the stepping event is identified, exceeds a threshold amplitude.
In accordance with one implementation of the present disclosure, the acts further comprise: verifying the stepping event in accordance with a determination that a frequency of the stepping event is within a frequency limitation.
In accordance with one implementation of the present disclosure, the acts further comprise: determining a step length associated with the stepping event based on a step length model characterizing an association between step lengths of reference users and acceleration signal streams collected by acceleration sensors carried by the reference users.
In accordance with one implementation of the present disclosure, determining the step length comprises: identifying, from the acceleration signal stream, an extreme value within a stepping window associated with the stepping event; determining an average value for the stepping window; and determining the step length based on the step length model, the extreme value, the average value, and a frequency of the stepping event.
In accordance with one implementation of the present disclosure, the step length model characterizes a polynomial association between a step length of a reference user in the reference users, an extreme value, an average value, and a frequency of an acceleration signal stream collected by an acceleration sensor associated with the reference user.
In accordance with one implementation of the present disclosure, the acts further comprise: obtaining an orientation signal stream collected by an orientation sensor associated with the user; determining a movement orientation associated with the stepping event based on the acceleration signal stream and the orientation signal stream; and determining a trajectory of the user based on the movement orientation and the step length.
In accordance with one implementation of the present disclosure, a computer program product is provided for indoor navigation. The computer program product comprises a computer-readable storage medium having program instructions embodied therewith, the program instructions being executable by an electronic device to cause the electronic device to perform a method for indoor navigation.
In accordance with one implementation of the present disclosure, a computer-readable storage medium is provided for indoor navigation. The medium has program instructions embodied therewith, the program instructions being executable by an electronic device to cause the electronic device to perform a method for indoor navigation.
In accordance with one implementation of the present disclosure, a computer-implemented method is provided for indoor navigation. The method comprises: obtaining a device orientation of a terminal device based on at least one signal stream collected from the terminal device carried by a moving user; determining, based on the at least one signal stream, a deviation degree representing a deviation between a movement orientation of the user and an actual device orientation of the terminal device; and determining the movement orientation based on the device orientation in accordance with a determination that the deviation degree is below a threshold degree.
In accordance with one implementation of the present disclosure, determining the deviation degree comprises: obtaining a movement orientation estimation of the user based on the at least one signal stream; obtaining an angle difference estimation between the movement orientation and the actual device orientation; and determining the deviation degree based on the device orientation, the movement orientation estimation, and the angle difference estimation.
In accordance with one implementation of the present disclosure, the method further comprises: in accordance with a determination that the deviation degree exceeds the threshold degree, determining the movement orientation based on the movement orientation estimation.
In accordance with one implementation of the present disclosure, obtaining the movement orientation estimation comprises: obtaining an orientation model characterizing an association between movement orientations of reference users and signal streams collected from terminal devices of the reference users; and obtaining the movement orientation estimation based on the orientation model and the at least one signal stream of the user.
In accordance with one implementation of the present disclosure, obtaining the movement orientation estimation further comprises: identifying in the at least one signal stream a step window associated with a stepping event of the user; and obtaining the movement orientation estimation based on the orientation model and a step signal fragment within the step window in the signal stream.
In accordance with one implementation of the present disclosure, the at least one signal stream comprises an acceleration signal stream acquired by an acceleration sensor in the terminal device and an orientation signal stream acquired by an orientation sensor in the terminal device.
In accordance with one implementation of the present disclosure, the stepping event is identified by: obtaining a first signal fragment and a second signal fragment respectively within a first time window and a second time window from the acceleration signal stream; and identifying the stepping event based on a comparison of the first and second signal fragments.
In accordance with one implementation of the present disclosure, obtaining the angle difference estimation comprises: obtaining an deviation model characterizing an association between angle differences of reference users and signal streams collected from terminal devices of the reference users, an angle difference in the angle differences being between a movement orientation of a reference user of the reference users and an actual device orientation of a terminal device of the reference user; and obtaining the angle difference estimation based on the deviation model and the at least one signal stream of the user.
In accordance with one implementation of the present disclosure, obtaining the deviation degree further comprises: determining a movement speed of the user based on the at least one signal stream; and obtaining the deviation degree based on the movement speed, the device orientation, the movement orientation estimation, and the angle difference estimation.
In accordance with one implementation of the present disclosure, the method further comprises: determining a trajectory of the user based on the movement orientation and the movement speed.
In accordance with one implementation of the present disclosure, an electronic device is provided for indoor navigation. The device comprises: a processing unit; and a memory coupled to the processing unit and storing instructions for execution by the processing unit, the instructions, when executed by the processing unit, causing the device to perform acts comprising: obtaining a device orientation of a terminal device based on at least one signal stream collected from the terminal device carried by a moving user; determining, based on the at least one signal stream, a deviation degree representing a deviation between a movement orientation of the user and an actual device orientation of the terminal device; and determining the movement orientation based on the device orientation in accordance with a determination that the deviation degree is below a threshold degree.
In accordance with one implementation of the present disclosure, determining the deviation degree comprises: obtaining a movement orientation estimation of the user based on the at least one signal stream; obtaining an angle difference estimation between the movement orientation and the actual device orientation; and determining the deviation degree based on the device orientation, the movement orientation estimation, and the angle difference estimation.
In accordance with one implementation of the present disclosure, the acts further comprise: in accordance with a determination that the deviation degree exceeds the threshold degree, determining the movement orientation based on the movement orientation estimation.
In accordance with one implementation of the present disclosure, obtaining the movement orientation estimation comprises: obtaining an orientation model characterizing an association between movement orientations of reference users and signal streams collected from terminal devices of the reference users; and obtaining the movement orientation estimation based on the orientation model and the at least one signal stream of the user.
In accordance with one implementation of the present disclosure, obtaining the movement orientation estimation further comprises: identifying in the at least one signal stream a step window associated with a stepping event of the user; and obtaining the movement orientation estimation based on the orientation model and a step signal fragment within the step window in the signal stream.
In accordance with one implementation of the present disclosure, the at least one signal stream comprises an acceleration signal stream acquired by an acceleration sensor in the terminal device and an orientation signal stream acquired by an orientation sensor in the terminal device.
In accordance with one implementation of the present disclosure, the stepping event is identified by: obtaining a first signal fragment and a second signal fragment respectively within a first time window and a second time window from the acceleration signal stream; and identifying the stepping event based on a comparison of the first and second signal fragments.
In accordance with one implementation of the present disclosure, obtaining the angle difference estimation comprises: obtaining an deviation model characterizing an association between angle differences of reference users and signal streams collected from terminal devices of the reference users, an angle difference in the angle differences being between a movement orientation of a reference user of the reference users and an actual device orientation of a terminal device of the reference user; and obtaining the angle difference estimation based on the deviation model and the at least one signal stream of the user.
In accordance with one implementation of the present disclosure, obtaining the deviation degree further comprises: determining a movement speed of the user based on the at least one signal stream; and obtaining the deviation degree based on the movement speed, the device orientation, the movement orientation estimation, and the angle difference estimation.
In accordance with one implementation of the present disclosure, the acts further comprise: determining a trajectory of the user based on the movement orientation and the movement speed.
In accordance with one implementation of the present disclosure, a computer program product is provided for indoor navigation. the computer program product comprises a computer-readable storage medium having program instructions embodied therewith, the program instructions being executable by an electronic device to cause the electronic device to perform a method for indoor navigation.
In accordance with one implementation of the present disclosure, a computer-readable storage medium is provided In accordance with one implementation of the present disclosure. The medium has program instructions embodied therewith, the program instructions being executable by an electronic device to cause the electronic device to perform a method for indoor navigation.
Implementations of the present disclosure may further include one or more computer program products being tangibly stored on a non-transient machine-readable medium and comprising machine-executable instructions. The instructions, when executed on a device, causing the device to carry out one or more processes as described above.
In general, the various example implementations may be implemented in hardware or special purpose circuits, software, logic or any combination thereof. Some aspects may be implemented in hardware, while other aspects may be implemented in firmware or software which may be executed by a controller, microprocessor or other computing device. While various aspects of the example implementations of the present disclosure are illustrated and described as block diagrams, flowcharts, or using some other pictorial representation, it will be to be understood that the blocks, apparatus, systems, techniques or methods described herein may be implemented in, as non-limiting examples, hardware, software, firmware, special purpose circuits or logic, general purpose hardware or controller or other computing devices, or some combination thereof.
In the context of the present disclosure, a machine readable medium may be any tangible medium that can contain, or store a program for use by or in connection with an instruction execution system, apparatus, or device. The machine readable medium may be a machine readable signal medium or a machine readable storage medium. A machine readable medium may include but not limited to an electronic, magnetic, optical, electromagnetic, infrared, or semiconductor system, apparatus, or device, or any suitable combination of the foregoing. More specific examples of the machine readable storage medium would include an electrical connection having one or more wires, a portable computer diskette, a hard disk, a random access memory (RAM), a read-only memory (ROM), an erasable programmable read-only memory (EPROM or Flash memory), an optical fiber, a portable compact disc read-only memory (CD-ROM), an optical storage device, a magnetic storage device, or any suitable combination of the foregoing.
Computer program code for carrying out methods of the present disclosure may be written in any combination of one or more programming languages. These computer program codes may be provided to a processor of a general purpose computer, special purpose computer, or other programmable data processing apparatus, such that the program codes, when executed by the processor of the computer or other programmable data processing apparatus, cause the functions or operations specified in the flowcharts and/or block diagrams to be implemented. The program code may execute entirely on a computer, partly on the computer, as a stand-alone software package, partly on the computer and partly on a remote computer or entirely on the remote computer or server.
Further, while operations are depicted in a particular order, this should not be understood as requiring that such operations be performed in the particular order shown or in sequential order, or that all illustrated operations be performed, to achieve desirable results. In certain circumstances, multitasking and parallel processing may be advantageous. Likewise, while several specific implementation details are contained in the above discussions, these should not be construed as limitations on the scope of any disclosure or of what may be claimed, but rather as descriptions of features that may be specific to particular implementations of particular disclosures. Certain features that are described in this specification in the context of separate implementations can also be implemented in combination in a single implementation. Conversely, various features that are described in the context of a single implementation can also be implemented in multiple implementations separately or in any suitable sub-combination.
Various modifications, adaptations to the foregoing example implementations of this disclosure may become apparent to those skilled in the relevant arts in view of the foregoing description, when read in conjunction with the accompanying drawings. Any and all modifications will still fall within the scope of the non-limiting and example implementations of this disclosure. Furthermore, other implementations of the disclosures set forth herein will come to mind to one skilled in the art to which these implementations of the disclosure pertain having the benefit of the teachings presented in the foregoing descriptions and the drawings. Therefore, it will be to be understood that the implementations of the disclosure are not to be limited to the specific implementations disclosed and that modifications and other implementations are intended to be included within the scope of the appended claims. Although specific terms are used herein, they are used in a generic and descriptive sense only and not for purposes of limitation.
Number | Date | Country | |
---|---|---|---|
Parent | PCT/CN2020/093204 | May 2020 | US |
Child | 18052212 | US |