The present disclosure relates to the transportation of goods, and in particular relates to load detection for vehicles or for containers on a trailer chasses.
During the transportation of goods, determining whether a trailer is loaded is an important aspect of trailer asset management. With the transportation of shipping containers using tractor trailers, it is important to understand whether a trailer, referred to herein as a chassis, is loaded or not.
The information on vehicle loading may be beneficial to the transportation company. In particular, a transportation company managing a fleet of vehicles needs to know which vehicles are loaded and which vehicles are empty.
Typically, vehicle loading is determined by manual inspection, which is a cumbersome process that can be slow and inaccurate.
The present disclosure will be better understood with reference to the drawings, in which:
The present disclosure provides a method at a computing device, the method comprising: obtaining sensor data for a vehicle providing vibration frequency and magnitude; calculating an energy for each of a low frequency passband and a high frequency passband of a bandpass filter pair; finding an energy ratio based on the energy for the low frequency passband and the energy for the high frequency passband; applying weighting constants to each of the energy for the low frequency passband, the energy for the high frequency passband and the energy ratio to calculate a decision variable; and finding that the vehicle is unloaded if the decision variable is below a threshold and finding that the vehicle is loaded if the decision variable is above a threshold.
The present disclosure further provides a computing device comprising: a processor; and a communications subsystem, wherein the computing device is configured to: obtain sensor data for a vehicle providing vibration frequency and magnitude; calculate an energy for each of a low frequency passband and a high frequency passband of a bandpass filter pair; find an energy ratio based on the energy for the low frequency passband and the energy for the high frequency passband; apply weighting constants to each of the energy for the low frequency passband, the energy for the high frequency passband and the energy ratio to calculate a decision variable; and find that the vehicle is unloaded if the decision variable is below a threshold and finding that the vehicle is loaded if the decision variable is above a threshold.
The present disclosure further provides a computer readable medium for storing instruction code, which, when executed by a processor on a computing device cause the computing device to: obtain sensor data for a vehicle providing vibration frequency and magnitude; calculate an energy for each of a low frequency passband and a high frequency passband of a bandpass filter pair; find an energy ratio based on the energy for the low frequency passband and the energy for the high frequency passband; apply weighting constants to each of the energy for the low frequency passband, the energy for the high frequency passband and the energy ratio to calculate a decision variable; and find that the vehicle is unloaded if the decision variable is below a threshold and finding that the vehicle is loaded if the decision variable is above a threshold.
In accordance with the embodiments described below, cargo load detection systems utilizing a vertical accelerometer and/or strain gauges are described.
In the embodiments described below, the load detection is performed on a trailer chassis which is connected to a tractor. However, in other cases, the measurements may be made on other shipping containers, including, but not limited to, railcars, trucks, automobiles, among others.
In order to perform load detection, a sensor apparatus may be affixed to a container, trailer, or other similar asset. Such sensor apparatus may, for example, be mounted inside of a chassis of a flatbed trailer configured to receive shipping containers. Reference is now made to
In the embodiment of
However, in other cases it may be beneficial to have a different position for the sensor apparatus. Further, in some embodiments it may be useful to have a plurality of such sensor apparatuses within the trailer 110.
The sensor apparatuses within trailer 110 may be used alone in some embodiments, or may be combined into sets of two or more sensor apparatuses and/or external sensors for load determination calculations.
In the embodiment of
Apparatus
One sensor apparatus for a vehicle, chassis, trailer, container, or other transportation asset is shown with regard to
Reference is now made to
Sensor apparatus 210 comprises a processor 220 and at least one communications subsystem 230, where the processor 220 and communications subsystem 230 cooperate to perform the methods of the embodiments described herein. Communications subsystem 230 may, in some embodiments, comprise multiple subsystems, for example for different radio technologies.
Communications subsystem 230 allows sensor apparatus 210 to communicate with other devices or network elements. Communications subsystem 230 may use one or more of a variety of communications types, including but not limited to cellular, satellite, Bluetooth™, Bluetooth™ Low Energy, Wi-Fi, wireless local area network (WLAN), sub-giga hertz radios, near field communications (NFC), IEEE 802.15, wired connections such as Ethernet or fiber, among other options.
As such, a communications subsystem 230 for wireless communications will typically have one or more receivers and transmitters, as well as associated components such as one or more antenna elements, local oscillators (LOs), and may include a processing module such as a digital signal processor (DSP) or System on Chip (SOC). As will be apparent to those skilled in the field of communications, the particular design of the communication subsystem 230 will be dependent upon the communication network or communication technology on which the sensor apparatus is intended to operate.
Processor 220 generally controls the overall operation of the sensor apparatus 210 and is configured to execute programmable logic, which may be stored, along with data, using memory 240. Memory 240 can be any tangible, non-transitory computer readable storage medium, including DRAM, Flash, optical (e.g., CD, DVD, etc.), magnetic (e.g., tape), flash drive, hard drive, or other memory known in the art.
Alternatively, or in addition to memory 240, sensor apparatus 210 may access data or programmable logic from an external storage medium (not shown), for example through communications subsystem 230.
In the embodiment of
Examples of sensors in the embodiment of
Further, accelerometer 255 would typically provide acceleration sensors in three dimensions. Thus, accelerometer 255 would generally include three individual accelerometers. The readings from each of the three individual accelerometers could be isolated.
Communications between the various elements of sensor apparatus 210 may be through an internal bus 265 in one embodiment. However, other forms of communication are possible.
In the embodiment of
The sensor apparatus 210 may communicate with the strain gauge sensor 270 or strain gauge 259 to query the strain gauge reading under a trigger condition. Examples of trigger conditions could be: on a regular wake-up schedule negotiated between the sensor(s) and the sensor apparatus unit; when the trailer is in motion; and/or when the trailer stops, among other options.
A strain gauge will typically be displaced when the container is loaded and could be calibrated to estimate the relative or absolute weight of the container.
Sensor apparatus 210 may be affixed to any fixed or portable platform. For example, sensor apparatus 210 may be affixed to shipping containers or truck trailers in one embodiment. In other embodiments, sensor apparatus 210 may be affixed to a chassis of a trailer, as for example shown in
In other cases, sensor apparatus 210 may be part of a container that could be carried on or within a vehicle, for example container 120 from
Such a sensor apparatus 210 may be a power limited device. For example, sensor apparatus 210 could be a battery-operated device that can be affixed to a shipping container or trailer in some embodiments. Other limited power sources could include any limited power supply, such as a small generator or dynamo, a fuel cell, solar power, energy harvesting, among other options.
In other embodiments, sensor apparatus 210 may utilize external power, for example from the battery or power system of a tractor pulling the trailer, via a wiring harness connected to a 7-pin plug, from a land power source for example on a plugged-in recreational vehicle or from a building power supply, among other options. Thus, the sensor apparatus 210 may also be connected to a power cord that receives its power from a power source.
External power may further allow for recharging of batteries to allow the sensor apparatus 210 to then operate in a power limited mode again. Recharging methods may also include other power sources, such as, but not limited to, solar, electromagnetic, acoustic or vibration charging.
The sensor apparatus from
Referring to
In the example of
Further, in some embodiments, sensor apparatus 310 could communicate through a wired access point such as Ethernet or fiber, among other options.
The communication may then proceed over a wide area network such as Internet 330 and proceed to servers 340 or 342.
Similarly, sensor apparatus 312 and sensor apparatus 314 may communicate with server 340 or server 342 through one or both of the base station 320 or access point 322, among other options for such communication.
In other embodiments, any one of sensor apparatuses 310, 312 or 314 may communicate through satellite communication technology. This, for example, may be useful if the sensor apparatus is travelling to areas that are outside of cellular coverage or access point coverage.
In other embodiments, sensor apparatus 312 may be out of range of access point 322, and may communicate with sensor apparatus 310 to allow sensor apparatus 310 to act as a relay for communications.
Communication between sensor apparatus 310 and server 340 may be one directional or bidirectional. Thus, in one embodiment sensor apparatus 310 may provide information to server 340 but server 340 does not respond. In other cases, server 340 may issue commands to sensor apparatus 310 but data may be stored internally on sensor apparatus 310 until the sensor apparatus arrives at a particular location, possibly during a particular time window. In other cases, two-way communication may exist between sensor apparatus 310 and server 340.
A server, central server, processing service, endpoint, Uniform Resource Identifier (URI), Uniform Resource Locator (URL), back-end, and/or processing system may be used interchangeably in the descriptions herein. The server functionality typically represents data processing/reporting that are not closely tied to the location of sensor apparatuses 310, 312, 314, etc. For example, the server may be located essentially anywhere so long as it has network access to communicate with sensor apparatuses 310, 312, 314, etc.
Server 340 may, for example, be a fleet management centralized monitoring station. In this case, server 340 may receive information from a sensor apparatus associated with various trailers or cargo containers, providing information such as the location of such cargo containers, the temperature within such cargo containers, any unusual events including sudden decelerations, temperature warnings when the temperature is either too high or too low, cargo loading status for the trailer, the mass of the trailer, among other data. The server 340 may compile such information and store it for future reference.
Other examples of functionality for server 340 are possible.
In the embodiment of
For example, data services provider 350 may be a subscription-based service used by server 340 to obtain current road and weather conditions, or may be an inventory control system in some cases.
Data repository or database 360 may for example provide information such as image data associated with a particular location, aerial maps, detailed street maps, or other such information.
The types of information provided by data service provider 350 or the data repository or database 360 is not limited to the above examples and the information provided could be any data useful to server 340.
In some embodiments, information from data service provider 350 or the data repository from database 360 can be provided to one or more of sensor apparatuses 310, 312, or 314 for processing at those sensor apparatuses.
A sensor apparatus such as that described in
Calculating Trailer Loading
In accordance with some embodiments of the present disclosure, the rear segment of a transportation vehicle or trailer can be modelled as a simple spring with a mass “m” representing the mass of the container and the mass of the chassis, and a spring constant “k”, where k is the stiffness of the structure and suspension. Further, a damper which may be dependent on the suspension of the chassis is represented with a damping constant “c”. For example, reference is now made to
In the embodiment of
A spring 420 is shown having a spring constant “k”, which is representative of the stiffness of the structure and suspension.
Further, the damping constant “c” is shown using a representation 422 of the suspension.
A displacement “h” shows the amount of motion of the chassis from the rest position of the chassis towards the ground, for example when a bump is encountered by the chassis while the vehicle is operating.
The equation describing the motion of the chassis in one-dimension, using a single spring-damper, can be expressed as provided in equation 1 below:
In equation 1, m is the mass of the system, h is the displacement of the chassis from a rest position, t is time, k is the spring constant and c is the damping constant.
Solving equation 1 for the frequency of vibration yields equation 2:
Based on equation 2, the frequency of vibration is inversely proportional to the mass applied to the trailer. When the trailer is under the same moving conditions, the vibration frequency of the trailer will shift lower when a shipping container is loaded on the chassis.
If a truck, trailer or other similar asset is loaded within safe operating limits, the springs on the axles should not experience any significant deformations, which may affect the frequency of vibration.
The amplitude of the oscillations depends on the forces of any impacts between the wheels in the ground, but do not affect the frequency of vibration.
For example, reference is now made to
Based on
One method for using the different frequencies for a loaded and unloaded chassis may be to calculate the energy ratio (eRatio) for a comparison between the lower frequencies and a combination of the lower and higher frequencies. In particular, a pair of bandpass filters, one at a lower-band and one at a higher-band, may be used. Such bandpass filters may be set around the typical loaded and unloaded frequencies to capture the average energy around these frequencies.
After n tests, n log files of raw data from a sensor may be collected. For example, a log file may contain 1024 samples. However, this number of samples is merely provided for illustration, and is not limiting.
The raw data from these files is then processed by a detector, where each of the lower-band bandpass filter (LBPF) and higher-band bandpass filter (HBPF) generates n values of the output averaged energy corresponding to the n log files. For example, these output values may be denoted by EL(i) and EH(i), where the subscript “L” and “H” indicate the LBPF and the HBPF respectively, and i=1, 2, . . . , n. In the detector, the energy ratio (eRatio) is further calculated as:
Using equation 3 above, when the cut-off frequencies of both filters are set properly, ideally EH(i) should be zero when the loading status (LS) is “ON”, resulting in R(i) being 1. Conversely, when the LS is “OFF”, ideally EL(i) should be zero and in turn R(i) should also be 0.
Under practical conditions, the energy ratio generally is found to be between zero and one using equation 3 above.
For example, reference is now made to
In some cases, it may be easier to deal with a loading status of “off” corresponding to −1 and a loading status of “on” corresponding to 1. In this case, a dependent variable for the eRatio, R′(i), may be defined as:
The above ratios are based solely on the phenomenon that the vibrating frequency (VF) of the chassis spring varies as a function of the loading mass. In particular, heavier loading results in a lower VF. By comparing the energy output from the LBPF and the HBPF using the eRatio, loading status is detected. However, occasionally when R′(i) is close to 0 (i.e. when R(i) is close to 0.5) then the detection is not reliable and may result in an erroneous detection.
Vibration Magnitude
To improve loading status detection reliability, a vibration magnitude (VM) variation may also be considered for loading status. In particular, when a chassis is empty, and therefore lighter, a spring on the chassis will typically vibrate more freely and hence with a higher VM. Conversely, when the chassis is loaded with a heavy container, the spring vibrates with a suppressed magnitude. In other words, the VM also carries certain information about loading status.
Therefore, in accordance with embodiments described below, loading status detection may be based on both the energy ratio, R(i), and the vibration magnitude which is equivalently represented by the values of EL(i) and EH(i).
Reference is now made to
In order to facilitate such separation, a method widely used in Machine Learning (ML) may be adopted, and a decision variable S(i) is defined for the i-th test data. For instance, if the values of eRatio, EL and EH are to be used, equation 6 below may be defined as:
S(i)=w0+w1R(i)+w2EL(i)+w3EH(i) (6)
Equation 6 simply means that S(i) is a weighted linear combination of R(i), EL(i) and EH(i), with proper weighting coefficients (WC) w1, j=0,1,2 and 3. These WCs are to be optimized.
If only the eRatio and EL are to be used, then w3 can be set to zero in equation 6 above.
In some cases, optimization may be achieved by training the detector using collected testing results with known loading status. Assuming enough raw data has been collected from n tests with known loading status, the raw data for R(i), EL(i) and EH(i) can be derived. Then, using these variables and the known LS, optimum WCs can be obtained by training, as described below.
However, in some cases, the training may be performed for one type of chassis and then the values for the WCs can be propagated to sensor apparatuses in similar chassis. In this case, training would only need to occur in a subset of the chassis.
After training is completed or once the WC values are received at the sensor apparatus, equation 6 above may then be used to calculate the value of S(i). Once the S(i) value is known, a loading status decision may be made based on equation 7 below.
In equation 7 above, the value of “0” is an arbitrarily assigned value decided during training. As will be appreciated by those in the art, when using equation 6, the S(i) value can be found to be around any midpoint by changing the WCs. Therefore, equation 7 is merely one example of a decision equation.
Training
Optimization of the weighting coefficients in equation 6 above through training is a major topic of machine learning. Many well-known ML techniques exist, including but not limited to logistic regression (LR) and neural networks (NN). In these methods, starting from a set of randomly selected initial values for WCs, a certain number of iterative calculations may be performed. WCs are updated in each iteration, and eventually converge to the final values for WCs.
In the embodiments described herein for the application of cargo load detection, two solutions are described as examples for the obtaining of optimum WCs. In a first solution, a minimum-mean squared error (MSE) solution is provided. In a second solution, a support-vector machine (SVM) solution is provided. However, these solutions are provided only for illustration and, in other cases, different optimization algorithms may be utilized to find the values of the WC variables.
Without a loss of generality, it is assumed that a solution to equation 6 above is being found, using the values found for the eRatio, EL and EH. In particular, raw data from n tests with a known loading status have been collected, and from this raw data, R(i), EL(i) and EH(i) have been derived using a pair of the properly designed LBPF and HBPF, where i=1, 2, . . . , n. In machine learning these variables are referred to as features, and the known loading status as the target.
Since there are n samples, where each sample has three features associated with one target, for convenience the features may be denoted as xi1,xi2, and xi3 for R(i), EL(i) and EH(i) respectively. The target may be denoted as yi. In one example, the target yi=1 if the known LS(i) is ON and the target yi=−1 if the known LS(i) is OFF.
MSE Solution
Using a minimum-mean squared error approach, since yi is the target for each test, ideally the decision variable S(i)=yi. Thus from equation 6 above, the equation for each value of i for the training set is:
The purpose of training is to find a solution for the four unknown WCs which satisfy (8) above under known values of yi and xij. This may be done by utilizing matrix and vector notation as described below.
In particular, the X matrix may be defined as:
Further, a y matrix may be defined as:
y=[y1y2 . . . yn]T (10)
And a w matrix may be defined as:
w=[w0w1w2w3]T (11)
In (10) and (11) above, the superscript T denotes a transpose. Using the matrices of (9), (10) and (11) above, the formulas from (8) can be written into a concise form as:
y=Xw (12)
Mathematically, when the number of samples is greater than the number of features plus 1 (in this case when n>4) then the equations in (8) have no solution. However, there is a uniquely least squares solution for the WCs:
w=X\y=(XTX)−1XTy (13)
In equation 13 above, X\y reads ‘y is left-divided by X’. Further, equation 13 is valid if all columns of X are independent. Equation 13 leads to the minimum mean-squared error between y and S=Xw.
In general, to accommodate m features, m≥1, the matrix X of (9) consists of (m+1) columns with the first column consisting of all “1”, and w consists of (m+1) WCs.
SVM Solution
A support-vector machine is a supervised binary classification algorithm of ML applicable to the embodiments of the present disclosure. SVM is a robust process to solve both simple and highly complex ML problems with a large number of features and a small number of samples.
After enough training iterations, SVM finds a linear decision surface that can separate the two classes with a maximum margin. In other words, a decision line in 2-D models or a decision hyperplane in multi-dimension models may be found.
Mathematically, SVM gives a solution for the weighting coefficients w which has minimized magnitude ∥w∥ subject to the constraint of (14) below:
YXw≥1 (14)
In (14) above, 1 is an all-one column vector, and Y is a diagonal matrix whose diagonal elements are yj, j=1, 2, . . . , n, in order. Fast algorithms have been developed to implement SVM. Two non-limiting examples of such algorithms include John C. Platt, “Sequential Minimal Optimization: A Fast Algorithm for Training Support Vector Machines”, Technical Report MSR-TR-98-14, Apr. 21, 1998; and Stanford University, “The Simplified SMO Algorithm”, CS 229.
Multiple Pairs of Filters
In the above embodiments, a single pair of bandpass filters was used for the filtering the raw data in order to make loaded/unloaded decisions. This assumes that the passbands represented by the cutoff frequencies of the two bandpass filters have been properly selected.
In practice, in some embodiments it may not be known exactly what or which frequency bands should be selected for each of the two bandpass filters as the passband. In this case, in accordance with an alternative embodiment of the present disclosure, multiple pairs of bandpass filters may be utilized.
In particular, a detector contains K pairs of LBPFs and HBPFs, where K is greater than or equal to one. Each pair of filters is set with different passbands. The raw data from a sensor may then be applied to the K pairs of filters at the same time.
For example, Table 1 below illustrates one case in which K=3, and the passbands for each of the pairs is shown.
Therefore, as shown in Table 1, each pair of bandpass filters has different cutoff frequencies. For the i-th test, from the k-th BPF pair, k equals 1, 2 and 3, we can derive three variables: Rk(i), Ek,L(i), Ek,H(i), and in total there are nine variables/features available.
When there are three pairs of the bandpass filters, equation 6 above may be rewritten as:
S(i)=w0+w1R1(i)+w2E1,L(i)+w3E1,H(i)+w4R2(i)+w5E2,L(i)+w6E2,H(i)+w7R3(i)+w8E3,L(i)+w9E3,H(i) (15)
Equation 15 above can be solved through various techniques, including using MSC or SVM as described above. Further, in some cases, if Ek,H(i) is ignored then equation 15 may be rewritten as:
S(i)=w0+w1R1(i)+w2E1,L(i)+w3R2(i)+w4E2,L(i)+w5R3(i)+w6E3,L(i) (16)
Again, equation 16 may be solved through various techniques, including using MSE or SVM as described above.
While the examples above provide for three pairs of bandpass filters, this is merely provided for illustration and more or less pairs of bandpass filters could be utilized. In particular, if only one pair of bandpass filters is utilized and then the solutions described above may be used. However, in some cases two pairs of bandpass filters or four or more pairs of bandpass filters may be used.
Process for Determining Loaded/Unloaded Status
In practice, to make determinations on the loaded/unloaded status of the vehicle, a sensor apparatus associated with the vehicle may measure the vibration frequency and magnitude. In some cases, this raw data may be processed at the sensor apparatus or other computing device associated with the vehicle. In other cases, this data may be provided to a server to perform the processing.
For example, a high-level overview of a process for making loaded/unloaded decisions is provided in
In other cases, training may not be needed if the chassis type is similar to other chassis types in which training has already been performed. In this case, a server may pass weighting coefficients to the sensor apparatus or may indicate to the sensor apparatus that weighting coefficients exist at the server.
In other cases, a server may issue a command to a sensor apparatus to start a loaded/unloaded determination. In this case, the command may include the weighting coefficients or an indication that the weighting coefficients exist at the server. If this information is missing from the command, the sensor apparatus or other computing device associated with the vehicle may conclude training is required.
Other examples of where training may not be needed are also possible.
If training is needed, the process proceeds from block 912 to block 920 in which training is performed. The performance of training is described in more detail below with regard to
Once the training has been performed, the process proceeds to block 930 in which the weighting coefficients are determined. The determination of the weighting coefficients may result in that the weighting coefficients being stored at a server or at the sensor apparatus.
After the training is completed, or if training is not needed at block 912, and then sensor apparatus, along with a server in some cases, may make loaded/unloading decisions, as shown at block 940, using the weighting coefficients that were previously determined or assigned to the vehicle.
The process then proceeds to block 950 and ends.
Based on
If decisions and/or processing are performed by a server, a reliable communication link would typically exist between the sensor apparatus and the server.
With regard to training, training may occur completely at a server or other similar computing device, as for example illustrated in
Reference is now made to
Once the training is started, either the sensor apparatus or the server needs to have a loading status of the the trailer or chassis input. The input may be based on various factors. For example, in some cases an operator of the vehicle may input the loading status into the vehicle or sensor apparatus. This may occur based on a user interface on the sensor apparatus, a user interface on the vehicle itself, or a communication interface that the operator of the vehicle may access. For example, in one case the operator of the vehicle may be required to input the loading status into a text message which is sent to a server or to the sensor apparatus during the training period. In other cases, the operator of the vehicle may be required to press a button or toggle a switch to indicate whether the trailer is loaded or unloaded. Other options for providing information to the sensor apparatus or server about the loading status of the vehicle are also possible.
In other cases, during the training period, a server may know whether the trailer is loaded or unloaded, for example based on a transportation schedule, and use such information to correlate with the sensor data.
In other cases, external inputs may be used to receive the loading status on the vehicle. For example, a camera in a shipping yard may provide visual images of the vehicle as it leaves the shipping yard, thereby identifying whether the trailer is loaded or unloaded. Such image may verify if a container is loaded or unloaded, or may in some cases show the wheels closer to the chassis on a closed container if the trailer is loaded, among other options.
In still other cases, the sensor apparatus may have a secondary mechanism for identifying whether the vehicle is unloaded or loaded, such as cameras, cargo loading detectors such as light beam or laser projectors and detectors to sense whether a closed trailer includes cargo, among other options.
Therefore, as illustrated in
Sensor apparatus 1010 may then collect raw data with regard to the frequency and magnitude of vibration, as shown at block 1040. This may be done, for example based on accelerometers or strain gauges, among other options.
Once the raw data is collected, the raw data may be sent to server 1012, as shown by message 1042. If the loading status was received at block 1030, message 1042 may further include the loading status.
In some cases, message 1042 includes a complete set of log information to allow the server 1012 to determine the weighting coefficients. In other cases, message 1042 may be periodically sent with partial information (for example one single log entry). In this case, the steps at blocks 1020, 1030, 1032, 1040 and 1042 may be repeated numerous times to allow server 1012 to compile enough data to determine the weighting coefficients.
Once a complete set of training logs are received at server 1012, the server may then calculate Rk(i), Ek,L(i), and Ek,H(i), as shown at block 1050. For example, Ek,L(i) and Ek,H(i) may be calculated by applying one or more of the pairs of bandpass filters. These values may then be used to calculate Rk(i).
Once Rk(i), Ek,L(i), and Ek,H(i) are calculated, the process proceeds to block 1052 in which the weighting coefficients may be calculated. The calculation of the weighting coefficients may use the MSE or SVM methods as described above, among other options.
Once the weighting coefficients are calculated, the process proceeds to block 1054 in which the weighting coefficients may be stored at the server, provided to the sensor apparatus, or both stored at the server and provided to the sensor apparatus.
At this point the training is finished and the weighting coefficients may then be used for the loaded/unloaded determinations.
In some cases, more of the processing can be performed at the sensor apparatus or similar computing device associated with the vehicle. Reference is now made to
In the embodiment of
As with the embodiment of
Further, similar to the embodiment of
The sensor apparatus 1110 then collects raw data, as shown by block 1140. One a complete training log is compiled, in the embodiment of
Once calculated, the sensor apparatus 1110 may then provide Ek,L(i), and Ek,H(i) to server 1112 in message 1144. Further, if the loading status was received at block 1130, the loading status may also be provided in message 1144 to server 1112.
Server 1112, once having received all of the log information in one or more messages 1144, may then calculate the Rk(i), as shown at block 1150.
The process then proceeds to block 1152 in which the weighting coefficients may be calculated, for example as provided above.
The process then proceeds to block 1154 in which the server 1112 may store the weighting coefficients, send the weighting coefficients to sensor apparatus 1110, or both store the weighting coefficients and send the weighting coefficients to sensor apparatus 1110.
Thereafter, the weighting coefficients may be used to calculate loaded/unloaded status on the vehicle.
In still a further embodiment, the processing may be completely done at the sensor apparatus. Reference is now made to
In the embodiment of
The process then proceeds to block 1220, in which the loading status of the vehicle is input or received at the sensor apparatus. The loading status may be provided to the sensor apparatus, for example, based on manual input from an operator of the vehicle, from sensors on the vehicle or in the area surrounding the vehicle, from commands or information provided by a server or other computing device, among other options.
The process then proceeds to block 1222 in which the raw data is collected. Such raw data may include the readings from an accelerometer and/or a stress gauge, among other options.
From block 1222, the process proceeds to block 1230 in which that the Rk(i), Ek,L(i), and Ek,H(i) are calculated based on one or more bandpass filter pairs.
The process then proceeds to block 1240 in which the weighting coefficients are calculated based on the techniques described above or based on similar techniques.
The process then proceeds to block 1242 in which the weighting coefficients are stored at the sensor apparatus, sent to the server, or both stored at the sensor apparatus and sent to the server.
From block 1242, the process proceeds to block 1250 and ends.
The weighting coefficients calculated at block 1240 may thereafter be used for making loaded/unloaded decisions.
Once training is complete, the weighting coefficients may be used by one or both of the sensor apparatus and server to calculate a loaded/unloaded status. Reference is now made to
In the embodiment of
The process then proceeds to block 1330 in which raw data including the frequency of vibration and the magnitude of vibration is obtained.
The raw data may then be provided to the server 1312, as shown by message 1332. In some cases, if the weighting coefficients are stored at the sensor apparatus 1310, message 1332 may further include the weighting coefficients for the vehicle.
On receiving message 1332, the server 1312 may calculate Rk(i), Ek,L(i), and Ek,H(i) as provided above. This is done, for example, at block 1340 in the embodiment of
The process then proceeds to block 1350 in which the weighting coefficients which are either stored at server 1312 or received in message 1332 may be used to determine the loaded/unloaded status of the vehicle. For example, equations 6, 15 or 16 may be used to find decision variable S(i). Once found, the decision variable may then be input into equation 7 to determine whether the vehicle is loaded or unloaded. The equations may be solved, for example, by placing the variables into a matrix X from equation 9 above and then using w and X from equation 12.
In other cases, the processing may completely be done at the sensor apparatus. Reference is now made to
The process of
Once the trigger is met, the process proceeds to block 1422 in which the raw data for the vehicle is collected. This may include sensor readings from an accelerometer and/or a stress gauge, among other options.
From block 1422 the process proceeds to block 1430 in which the Rk(i), Ek,L(i), and Ek,H(i) are calculated as described above.
The process then proceeds to block 1450 in which the weighting coefficients stored at the sensor apparatus (or received from a server) may be used to determine the loaded/unloaded status of the vehicle. For example, equations 6, 15 or 16 may be used to find decision variable S(i). Once found, the decision variable may then be input into equation 7 to determine whether the vehicle is loaded or unloaded. The equations may be solved, for example, by placing the variables into a matrix X from equation 9 above and then using w and X from equation 12.
In some cases, once the the loaded/unloaded status is determined, the sensor apparatus may report this status to the server (not shown).
The process then proceeds to block 1450 and ends.
The embodiments of
The embodiments above were tested in a real world environment. In particular, as shown in Table 2 in Appendix A below, relevant data with known loading status is provided. In Table 2, the third column lists the the known loading status, where 1 indicates loaded and −1 indicates unloaded. This loading status constitutes the vector y from equation 12 above. The fourth, fifth and sixth columns of Table 2 list the R(i), EL(i), and EH(i) respectively. These columns constitute the last three columns of the matrix X from equation 9 above.
As a simple example, consider a loading status detector utilizing two features, namely the R(i) and EL(i). Calculating using equation 13 for MSE, weighting coefficients wMSE=[−1.4742,3.1522,−0.1449]T are found. On the other hand, with SVM, the weighting coefficients are wSVM=[−2.9758,6.3533,−0.3371]T.
To see the improvement compared to the detection scheme based on R′(i) only, the following from equation 17 was calculated:
S=Xw (17)
The resultant S(i) is listed in the 2nd˜4th columns of Table 4 in Appendix C.
The histogram distributions of the decision variables obtained from MSE vs. based on eRatio only are shown in
The histogram distributions of the decision variables obtained from SVM vs. based on eRatio only are shown in
In the examples of
In another example, the outputs R(i) and EL(i) from each of the three pairs of BPFs specified in Table 1 are used to train SVM. The training data is provided in Table 3 of Appendix B below. Correspondingly, the new decision variable is designated pursuant to equation 16 above.
After training with SVM, the weighting coefficients obtained are w=[−2.942, 3.433, 1.439, 2.098, 0.063, 0.407, −1.369]T.
The relevant data and results are listed in the last column of Table 4 in Appendix C below.
Servers
A server such as servers 340, 342 or 350 may be any network node. For example, one simplified server that may perform the embodiments described above is provided with regards to
In
The processor 1920 is configured to execute programmable logic, which may be stored, along with data, on the server 1910, and is shown in the example of
Alternatively, or in addition to the memory 1940, the server 1910 may access data or programmable logic from an external storage medium, for example through the communications subsystem 1930.
The communications subsystem 1930 allows the server 1910 to communicate with other devices or network elements.
Communications between the various elements of the server 1910 may be through an internal bus 1960 in one embodiment. However, other forms of communication are possible.
The embodiments described herein are examples of structures, systems or methods having elements corresponding to elements of the techniques of this application. This written description may enable those skilled in the art to make and use embodiments having alternative elements that likewise correspond to the elements of the techniques of this application. The intended scope of the techniques of this application thus includes other structures, systems or methods that do not differ from the techniques of this application as described herein, and further includes other structures, systems or methods with insubstantial differences from the techniques of this application as described herein.
While operations are depicted in the drawings 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 employed. Moreover, the separation of various system components in the implementation descried above should not be understood as requiring such separation in all implementations, and it should be understood that the described program components and systems can generally be integrated together in a single software product or packaged into multiple software products. In some cases, functions may be performed entirely in hardware and such a solution may be the functional equivalent of a software solution.
Also, techniques, systems, subsystems, and methods described and illustrated in the various implementations as discrete or separate may be combined or integrated with other systems, modules, techniques, or methods. Other items shown or discussed as coupled or directly coupled or communicating with each other may be indirectly coupled or communicating through some interface, device, or intermediate component, whether electrically, mechanically, or otherwise. Other examples of changes, substitutions, and alterations are ascertainable by one skilled in the art and may be made.
While the above detailed description has shown, described, and pointed out the fundamental novel features of the disclosure as applied to various implementations, it will be understood that various omissions, substitutions, and changes in the form and details of the system illustrated may be made by those skilled in the art. In addition, the order of method steps is not implied by the order they appear in the claims.
When messages are sent to/from an electronic device, such operations may not be immediate or from the server directly. They may be synchronously or asynchronously delivered, from a server or other computing system infrastructure supporting the devices/methods/systems described herein. The foregoing steps may include, in whole or in part, synchronous/asynchronous communications to/from the device/infrastructure. Moreover, communication from the electronic device may be to one or more endpoints on a network. These endpoints may be serviced by a server, a distributed computing system, a stream processor, etc. Content Delivery Networks (CDNs) may also provide communication to an electronic device. For example, rather than a typical server response, the server may also provision or indicate data for a content delivery network (CDN) to await download by the electronic device at a later time, such as a subsequent activity of electronic device. Thus, data may be sent directly from the server, or other infrastructure, such as a distributed infrastructure, or a CDN, as part of or separate from the system.
Typically, storage mediums 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.
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.
Number | Name | Date | Kind |
---|---|---|---|
5877455 | Kyrtsos | Mar 1999 | A |
5973273 | Tai | Oct 1999 | A |
8483942 | Watanabe | Jul 2013 | B2 |
8958940 | Kawasaki | Feb 2015 | B2 |
20060041403 | Jaber | Feb 2006 | A1 |
20060293815 | McCann | Dec 2006 | A1 |
20160072649 | Tu | Mar 2016 | A1 |
20160114809 | Savaresi | Apr 2016 | A1 |
20170372229 | Ura | Dec 2017 | A1 |
20180094966 | Buether | Apr 2018 | A1 |
20180114381 | Hiemer | Apr 2018 | A1 |
20180186208 | Coombs | Jul 2018 | A1 |
20180361994 | Seaman | Dec 2018 | A1 |
Number | Date | Country |
---|---|---|
2570558 | Jul 2019 | GB |
Entry |
---|
Extended European Search Report, EP Application No. 20201181.3, dated Mar. 24, 2021. |
John C Platt, Sequential Minimal Optimization: A Fast Algorithm for Training Support Vector Machines, Technical Report MSR-TR-98-14, Apr. 21, 1998. |
Stanford University, CS 229 The Simplified SMO Algorithm, Autumn 2009. |
European Office Action, EP Application No. 20201181.3, dated Mar. 17, 2022. |
Number | Date | Country | |
---|---|---|---|
20210123795 A1 | Apr 2021 | US |