This application is based upon and claims the benefit of priority of the prior Japanese Patent Application No. 2013-264613, filed on Dec. 20, 2013, and the Japanese Patent Application No. 2014-189103, filed on Sep. 17, 2014, the entire contents of which are incorporated herein by reference.
This invention relates to a system identification technique.
In a field such as an automatic control, there is an issue of identification of a linear system. For example, when an analogue input u(t) and an analogue output y(t) are given with respect to a physical system, which is represented by a linear ordinary differential equation as illustrated in
In this patent application, a case where P(d/dt) y(t) is almost equal to u(t) is represented as P(d/dt)y(t) being equal to u(t).
However, sensor values such as output values of an accelerometer, which is recently used, are digital values (i.e. discrete values) instead of analogue values. Therefore, as illustrated in
Therefore, in order to realize this, the digital data is converted to the analogue data. As for that method, there is a fitting method. The spline method is a conventional famous fitting method, however, it has a problem that it is possible to differentiate the spline curve a few times, for example. Therefore, when order m of the differential operator is high, the spline method cannot be applied.
Moreover, even when another fitting method is adopted, it is not realistic in view of the calculation amount that the differential operations are calculated for all times, and it is not possible to identify the system that is represented by the differential equation including higher-order differential operators.
An information processing method relating to this invention includes (A) generating a fitting curve represented by a sum of exponential functions for each of a set of digital inputs and a set of digital outputs for a physical system that is represented by one or plural equations including m-order differential operators (m is an integer equal to or greater than 1.) The set of the digital inputs and the set of the digital outputs are stored in a data storage unit; and (B) calculating coefficients of the differential operators, which are included in first coefficients, so that a first coefficient of each exponential function included in an expression obtained by a product of the differential operators and the fitting curve for the set of the digital inputs is equal to a second coefficient of the same exponential function, which is included in the fitting curve for the set of the digital outputs.
The object and advantages of the embodiment will be realized and attained by means of the elements and combinations particularly pointed out in the claims.
It is to be understood that both the foregoing general description and the following detailed description are exemplary and explanatory and are not restrictive of the embodiment, as claimed.
The communication unit 103 of the detection apparatus 100 in the vehicle 1000 transmits measurement data to an information processing apparatus 300, for example, within a cloud, data center or the like through a network 200 such as the Internet. The vehicle 1000 is a physical system that is represented by differential equations including differential operators of m-order (m is an integer that is equal to or greater than 1) as illustrated in
The information processing apparatus 300 has a communication unit 310, an input/output data storage unit 320, a learning processing unit 330 and a prediction processing unit 340.
The communication unit 310 receives measurement data from the detection apparatus 100 in the vehicle 1000, and stores the received measurement data in the input/output data storage unit 320. The learning processing unit 330 performs a processing to identify the differential equations representing the vehicle 1000 from the digital inputs and digital outputs, and has a first fitting curve generator 331, a first data storage unit 332, a first operation unit 333 and a second data storage unit 334.
The first fitting curve generator 331 performs a Discrete Fourier Transformation (DFT) to generate a fitting curve for the digital inputs that are stored in the input/output data storage unit 320 and a fitting curve for the digital outputs that are stored in the input/output data storage unit 320, and stores data of those curves in the first data storage unit 332.
The first operation unit 333 has a first coefficient calculation unit 3331 and a linear regression processing unit 3332. The first coefficient calculation unit 3331 generates data used in the linear regression processing unit 3332 from data of the fitting curves, which is stored in the first data storage unit 332, and stores the generated data in the first data storage unit 332. The linear regression processing unit 3332 performs a linear regression processing by using data stored in the first data storage unit 332, and stores processing results in the second data storage unit 334. The processing results include the differential coefficients of the m-order differential operators. When the differential coefficients of the m-order differential operators are obtained, the differential equations that represent the vehicle 1000 will be obtained.
Moreover, the prediction processing unit 340 performs a processing to predict the digital outputs from new digital inputs and the identified differential equations, and has a second fitting curve generator 341, a third data storage unit 342, a second operation unit 343 and a fourth data storage unit 344.
The second fitting curve generator 341 performs a similar processing to the first fitting curve generator 331 to generate a fitting curve for the digital inputs stored in the input/output data storage unit 320, and stores data of that curve in the third data storage unit 342.
The second operation unit 343 has a second coefficient calculation unit 3431 and an output data calculation unit 3432. The second coefficient calculation unit 3431 calculates coefficients of an output function from the coefficients of the differential operators, which are stored in the second data storage unit 334, and data of the fitting curves, which is stored in the third data storage unit 342. The output data calculation unit 3432 calculates output data by the output function identified with the coefficients calculated by the second coefficient calculation unit 3431, and stores the output data in the fourth data storage unit 344.
Next, processing contents of the information processing apparatus 300 will be explained. The learning processing unit 330 of the information processing apparatus 300 performs a learning processing that will be explained later (
Next, the learning processing will be explained by using
More specifically, as illustrated in
Uj=(uj,0,uj,1, . . . ,uj,2n−1,uj,2n)j=1,2 . . . l
Yj=(yj,0,yj,1, . . . ,yj,2n−1,yj,2n)j=1,2 . . . l
As described above, this system is represented by the differential equation P(d/dt)yj (t)=uj(t) including the m-order differential operators P(d/dt).
Then, the first fitting curve generator 331 of the learning processing unit 330 reads out Uj and Yj from the input/output data storage unit 320 (
This fitting processing will be explained by using the digital outputs Yj. However, the similar processing will be performed for the digital inputs Uj. Moreover, in order to make it easy to understand the explanation, “j” is omitted.
More specifically, the DFT is performed for real values y0, y1, . . . , y2n of the discrete points to calculate n+1 frequencies. In other words, q=0, 1, . . . , n.
Each frequency Y0, Y1, . . . , Yn is complex number, and a real part aq and an imaginary part bq are represented as follows:
Y0=a0(b0=0)
Yq=aq−√{square root over (−1)}bqq=0,1, . . . ,n
Because the discrete points are real values, please note b0=0 from the characteristic of the DFT.
By using aq and bq obtained as described above, finite (i.e. n-order) Fourier series are generated as described below.
The Fourier series obtained here are the fitting curve of the discrete points y0, y1, . . . , yn. This fitting curve passes through these discrete points as will be explained later.
When 2n+1 discrete points y0, y1, . . . , y2n are obtained, it is possible to obtain 2n+1 frequencies by the DFT.
When the discrete points are real values, following relations are obtained.
Yq=
Y with a bar represents the complex conjugation of Y. According to this, following relations are also obtained.
aq=a2n+1−qbq=−b2n+1−qq=0,1, . . . ,2n
Here, when an Inverse Discrete Fourier Transformation (IDFT) is performed in order to recover data of original discrete points from the frequencies Y0, Y1, . . . , Y2n, the IDFT is represented like a first line in the following expression.
This second line represents that the right side of the first line is divided according to the aforementioned relationship between Y and its complex conjugation. In third and subsequent lines, a parameter q is adjusted and arrangement is advanced by representing the expression with the real part aq and imaginary part bq of the frequencies, and then, the last line is obtained.
On the other hand, when n-order Fourier series y(t), which are represented by the expression (1), are sampled at t=0, 1, . . . , 2n, a following expression is obtained.
Because the right side of this expression (2) is equal to the last line of the expression of the Inverse Discrete Fourier Transformation, it is understood that yi=y(i) (i=0, 1, . . . , 2n) holds. In other words, it is understood that the n-order Fourier series y(t) in the expression (1) pass through each of the original discrete points.
Moreover, when arbitrary n-order Fourier series g(t) are given and sampled at t=0, 1, . . . , 2n to obtain discrete points gi=g(i) (i=0, 1, . . . , 2n), the fitting curve of the discrete points gi (i=0, 1, . . . , 2n) is calculated, and the original g(t) is obtained again. This can be proved when a similar method to the aforementioned method is used, however, the detailed explanation is omitted here. As described above, this fitting method realizes one-to-one correspondence between the discrete points and finite Fourier series.
Therefore, the fitting curve yj(t) for the digital outputs and the fitting curve uj(t) for the digital inputs are obtained as described below.
Moreover, this fitting curve yj(t) and uj(t) can be represented by a sum of exponential functions whose base is the Napier's constant e. When the fitting curves can be represented by the sum of the exponential functions, it is possible to easily obtain the m-order differential.
cj,q and dj,q are represented as follows:
In this embodiment, the first fitting curve generator 331 generates a fitting curve by calculating coefficients cj,q and dj,q for each j (j=1 to 1) and each q (q=−n to +n) according to the expressions (3) and (4). Those cj,q and dj,q are stored in the first data storage unit 332, for example.
Then, the first coefficient calculation unit 3331 of the first operation unit 333 generates plural points (C, D) on an αβ plane for calculating each differential coefficient of the m-th differential operator from the coefficients cj,q and dj,q (step S15).
As described above, because of P(d/dt)yj(t)=uj (t), P(d/dt)yj (t) on the left side is represented as follows:
As described above, yj is a sum of the exponential functions. Therefore, in case of the first-order differentiation, its coefficient becomes a coefficient of the exponent of the exponential function, in case of the second-order differential, its coefficient becomes (the coefficient of the exponent of the exponential function)2, in case of the third-order differential, its coefficient becomes (the coefficient of the exponent of the exponential function)3, and in case of the m-order differential, its coefficient becomes (the coefficient of the exponent of the exponential function)m. Thus, the differential operation becomes very easy.
In other words, the expression is represented as follows:
Therefore, the aforementioned expression (5) is obtained.
Then, P(d/dt)yj(t)=uj(t) is represented as follows:
Because each exponential function in the expression (6) is orthogonal, when the coefficient of each exponential function on the left side is identical to the coefficient of the same exponential function on the right side, the entire of the left side is identical to the entire of the right side. In other words, following relations are obtained.
Here, because dj,q and cj,q(2√(−1)qπ/(2n+1))m are constant, they are moved to the right side, and terms of unknown differential coefficients P1 to Pm are moved to the left side. Therefore, a following expression is obtained.
At the step S15, coefficients that are multiplied to unknown differential coefficients in this expression (8) are represented as a m-dimensional vector Cj,q, and a value of the constant term in the expression (8) is represented as Dj,q as follows:
Then, the linear regression processing unit 3332 calculates the differential coefficients P1 to Pm by performing the linear regression by the method of least squares for such points (Cj,q, Dj,q), and stores the differential coefficients in the second data storage unit 334 (step S17).
At this step, the unknown coefficients P1 to Pm of the regression line β=P(α)=α1P1+α2P2+ . . . +αm-1Pm-1+αmPm are calculated. In other words, as schematically in
By performing the aforementioned processing, the differential coefficients of the differential operators are calculated so that the error is minimized and P(d/dt)yj(t)≈uj(t) is obtained.
As described above, the fitting curve is represented by the sum of the exponential functions. Therefore, it is possible to easily perform the higher-order differential, and it is also possible to perform the aforementioned processing at high speed.
Next, by using
After the learning processing is performed, the detection apparatus 100 of the vehicle 1000 transmits only measurement data of the accelerometer 101, in other words, data of the digital inputs from the communication unit 103 to the information processing apparatus 300. Accordingly, a transmission data amount to the information processing apparatus 300 is reduced. Here, instead of the digital inputs used in the learning processing, the measurement data of the accelerometer 101 as other digital inputs is newly obtained.
Therefore, when the communication unit 310 of the information processing apparatus 300 receives data of the digital inputs from the vehicle 1000, the communication unit 310 stores the received data in the input/output data storage unit 320.
Then, the second fitting curve generator 341 of the prediction processing unit 340 reads out the data of the digital inputs U (=(u0, u1, . . . , u2n)) from the input/output data storage unit 320 (
Then, the second coefficient calculation unit 3431 of the second operation unit 343 uses the results dq of the fitting processing and the differential coefficients P1 to Pm of the differential operators, which are stored in the second data storage unit 334, to calculate coefficients cq (q is −n to +n) of the output function y(t) (step S25).
Specifically, cq is calculated by a following expression.
Then, the output function y(t) is represented from the coefficients cq as follows:
Therefore, the output data calculation unit 3432 calculates output data Y=(y0, y1, . . . , y2n) for predetermined t (=0, 1, . . . , 2n) according to the expression (9), and stores the output data in the fourth data storage unit 344 (step S27).
Thus, it is possible to estimate a running distance by using the coefficients of the differential operators, which are obtained by the learning processing, and to output the estimated running distance.
For example, as illustrated in
Here, u(t) is a fitting curve for the digital inputs u0, u1, . . . , u2m. v(t) is a fitting curve for the digital outputs v0, v1, . . . , v2m. In the second embodiment, in order to make it easy to understand the explanation, the suffix j of uj(t), vj(t) and yj(t) is omitted.
However, in the first embodiment, it is presumed that the number of discrete points included in the digital inputs and the number of discrete points included in the digital outputs are identical. In other words, it is presumed that the sampling intervals of the digital inputs and the sampling intervals of the digital outputs are identical in a section from t=0 to t=2m.
On the other hand, in this embodiment, a conversion system 1101 as illustrated in
Moreover, the conversion system 1101 is a system that not only can change the sampling intervals (i.e. change the number of discrete points) but also can change a type of data by the differential and integral (e.g. data of the speed is changed to data of the acceleration or data of the distance.). Then, in the second embodiment, the conversion system 1101 is defined by a following expression.
y(t) is a fitting curve for the digital inputs y0, y1, . . . , y2n. In this matter, the conversion system 1101 is a system to generate a curve u(t) by the differential and integral of the fitting curve y(t). When the fitting curve y(t) is generated by the method explained in the first embodiment, the differential and integral can be performed, easily. Specifically, the higher-order differential is possible, on the other hand, it is impossible when using the spline method. In case of p=0, u(t)=y(t) holds.
A system configuration to realize the conversion system 1101 is the same as that of the first embodiment. In the following, processing contents of the information processing apparatus 300 in the second embodiment will be explained by using
The communication unit 103 of the detection apparatus 100 in the vehicle 1000 transmits data of digital inputs (e.g. measurement data of the accelerometer 101) and digital outputs (e.g. measurement data of the distance sensor 102) to the information processing apparatus 300 at arbitrary timings. The communication unit 310 of the information processing apparatus 300 stores received data from the vehicle 1000 in the input/output data storage unit 320.
In the second embodiment, it is assumed that y0, y1, . . . , y2n are received as the digital inputs, and v0, v1, . . . , v2m are received as the digital outputs. Here, a case of n≠m may occur instead of n=m.
Then, the first fitting curve generator 331 in the learning processing unit 330 reads out the digital inputs y0, y1, . . . , y2n from the input/output data storage unit 320 (
The first fitting curve generator 331 generates a fitting curve y(t) for the digital inputs y0 y1, . . . , y2n by performing the fitting processing by the DFT (step S33), and stores data of the fitting curve y(t) in the first data storage unit 332. At the step S33, the first fitting curve generator 331 performs the fitting processing by the DFT for each j, similarly to the first embodiment. However, as also described above, the description for j is omitted in order to simplify the explanation.
The processing of the step S33 is similar to the processing of the step S13 in the first embodiment. Therefore, the fitting curve y(t) is represented as follows:
The meanings of the variables and coefficients in the expression (11) are same as those in the first embodiment. And, as explained in the first embodiment, the right side of the expression (11) is represented by a sum of the exponential functions as follows:
Then, the first fitting curve generator 331 performs differential or integral of the fitting curve y(t), which is represented by the sum of the exponential functions, to generate a curve u(t) (step S35). When the type of data is not changed, the differential is performed while assuming p=0.
Although the curve u(t) is represented like the expression (10), the curve u(t) is represented as follows when considering the expression (12).
As described above, y(t) is the sum of the exponential functions. Therefore, in case of the first-order differential, its coefficient becomes a coefficient of the exponent of the exponential function, in case of the second-order differential, its coefficient becomes (the coefficient of the exponent of the exponential function)2, in case of the third-order differential, its coefficient becomes (the coefficient of the exponent of the exponential function)3, and in case of the m-order differential, its coefficient becomes (the coefficient of the exponent of the exponential function)m. Thus, the differential operation becomes very easy. Moreover, the higher-order differential is possible, although it is impossible in case of the spline method. Furthermore, typically, the integration of the exponential function ekx becomes ekx/k+C (k is a coefficient of the exponent and C is an integral constant), and the calculation is very easy. Therefore, it is also possible to perform the integral of the y(t) plural times.
For example, when y(t) is a fitting curve for the velocity, a curve u(t) for the acceleration is obtained by performing the first-order differential, and a curve u(t) for the distance is obtained by performing the integral. Moreover, when y(t) is the fitting curve for the distance, a curve u(t) for the velocity is obtained by performing the first-order differential, and a curve u(t) for the acceleration is obtained by performing the second-order differential.
Then, the first fitting curve generator 331 calculates data of 2m+1 discrete points u0, u1, . . . , u2m for the curve u(t) generated at the step S35 (step S37), and stores the calculated data in the input/output data storage unit 320. Then, the processing ends.
Because 2m+1 discrete points are disposed in a section from t=0 to t=2n, data of the 2m+1 discrete points u0, u1, . . . , u2m are as follows:
The first fitting curve generator 331 can perform the system identification, which was explained in the first embodiment, by using the data of the 2m+1 discrete points u0, u1, . . . , u2m, which are stored in the input/output data storage unit 320, and data of the 2m+1 discrete points v0, v1, . . . , v2m.
When the aforementioned processing is performed, y(t) and u(t) are continuous functions. Therefore, it becomes possible to equate the sampling intervals for the digital inputs with the sampling intervals for the digital outputs. Moreover, because the differentiation (however, p≠0) and integration of the fitting curve y(t) can be easily performed, it becomes possible to perform the system identification, analysis for data having a different type.
Although the embodiments of this invention were explained, this invention is not limited to those. For example, the explanation was made in which the accelerometer 101 and the distance sensor 102, which are provided in the vehicle 1000, are presumed, however, data measured by other sensors that correspond to inputs and outputs of a system to be identified may be employed.
Moreover, functional block diagrams illustrated in
Furthermore, in
Furthermore, the embodiments can be applied not only to the system identification, but also to a learning problem of the artificial intelligence.
In addition, the aforementioned information processing apparatus 300 is a computer device as shown in
The aforementioned embodiments are outlined as follows:
An information processing method relating to the embodiments includes (A) generating a fitting curve represented by a sum of exponential functions for each of a set of digital inputs and a set of digital outputs for a physical system that is represented by one or plural equations including m-order differential operators (m is an integer equal to or greater than 1. The set of the digital inputs and the set of the digital outputs are stored in a data storage unit.); and (B) calculating coefficients of the differential operators, which are included in first coefficients, so that a first coefficient of each exponential function included in an expression obtained by a product of the differential operators and the fitting curve for the set of the digital inputs is equal to a second coefficient of the same exponential function, which is included in the fitting curve for the set of the digital outputs.
When the fitting curve is represented by a sum of exponential functions as described above, it is possible to easily differentiate the fitting curve even if m is higher-order, and it is also possible to easily obtain the coefficients of the differential operators. In other words, a calculation amount can be reduced as a whole, and it is possible to perform the system identification.
The aforementioned calculating may include: (b1) generating plural combinations of a third coefficient and a difference between the second coefficient and a constant term, for which a coefficient of the differential operators is not multiplied, among the first coefficients, wherein the third coefficient is a coefficient, for which a coefficient of the differential operators is multiplied, among the first coefficients; and (b2) performing linear regression calculation for the plural combinations to calculate the coefficients of the differential operators.
Accordingly, even when a lot of digital inputs and digital outputs are obtained, it is possible to obtain the coefficients of the differential operators with much less error.
Moreover, the aforementioned first coefficient may be a product of a value of the differential operator for a coefficient in an exponent of a first exponential function corresponding to the first coefficient and a coefficient of the same exponential function as the first exponential function, which is included in the fitting curve for the set of the digital inputs. The differential can be represented by such simple operations.
Furthermore, the aforementioned information processing method may further include: (C) generating a second fitting curve represented by a sum of exponential functions for a second set of digital inputs of the physical system; (D) calculating, for each exponential function of the second fitting curve, coefficients of an output function, which are obtained from a coefficient of the exponential function and a value of a differential operator, which includes the calculated coefficient of the differential operator for a coefficient in an exponent of the exponential function; and (E) calculating digital output values from the output function including the calculated coefficient of the output function. By performing the aforementioned processing, it becomes possible to predict the outputs of the identified system from the digital inputs.
Moreover, the aforementioned generating may include: (a1) generating the fitting curve for the set of the digital inputs by calculating n+1 frequencies by performing discrete Fourier transformation for 2n+1 digital inputs and generating n-order Fourier series from the n+1 frequencies, wherein n is an integer; and (a2) generating the fitting curve for the set of the digital outputs by calculating n+1 frequencies by performing discrete Fourier transformation for 2n+1 digital outputs and generating n-order Fourier series from the n+1 frequencies. By performing the aforementioned processing, it becomes possible to generate the fitting curve that can recover the original digital inputs and outputs, securely.
Moreover, the aforementioned generating may further include: (a3) calculating l+1 frequencies (l is an integer.) by performing discrete Fourier transformation for 2l+1 third digital inputs that are stored in the data storage unit, and generating l-order Fourier series from the l+1 frequencies to generate a third fitting curve represented by a sum of exponential functions for the third digital inputs; and (a4) calculating 2n+1 digital inputs from the generated third fitting curve, and storing the 2n+1 digital inputs into the data storage unit. When the aforementioned processing is performed, it is possible to perform the system identification even if the number of digital inputs stored in the data storage unit and the number of digital outputs are different each other.
Moreover, the aforementioned generating may include: (a5) generating a first curve by performing differential or integral for the fitting curve for the set of the digital inputs; and (a6) generating fourth digital inputs by using the generated first curve, and storing the fourth digital inputs into the data storage unit. Because the fitting curve for the set of digital inputs are represented by the sum of the exponential functions, it is possible to easily calculate the differential and integral. Then, when performing the aforementioned processing, it becomes possible to perform the system identification for data obtained by the differential or integral.
Incidentally, it is possible to create a program causing a computer to execute the aforementioned processing, and such a program is stored in a computer readable storage medium or storage device such as a flexible disk, CD-ROM, DVD-ROM, magneto-optic disk, a semiconductor memory such as ROM (Read Only Memory), and hard disk. In addition, the intermediate processing result is temporarily stored in a storage device such as a main memory or the like.
All examples and conditional language recited herein are intended for pedagogical purposes to aid the reader in understanding the invention and the concepts contributed by the inventor to furthering the art, and are to be construed as being without limitation to such specifically recited examples and conditions, nor does the organization of such examples in the specification relate to a showing of the superiority and inferiority of the invention. Although the embodiments of the present inventions have been described in detail, it should be understood that the various changes, substitutions, and alterations could be made hereto without departing from the spirit and scope of the invention.
Number | Date | Country | Kind |
---|---|---|---|
2013-264613 | Dec 2013 | JP | national |
2014-189103 | Sep 2014 | JP | national |
Number | Name | Date | Kind |
---|---|---|---|
9015095 | Ito | Apr 2015 | B2 |
20100198897 | Yarman | Aug 2010 | A1 |
20130268473 | Ito | Oct 2013 | A1 |
Number | Date | Country |
---|---|---|
2000-182552 | Jun 2000 | JP |
2001-208842 | Aug 2001 | JP |
2003-108542 | Apr 2003 | JP |
2007-286801 | Nov 2007 | JP |
2010-264499 | Nov 2010 | JP |
2013-175143 | Sep 2013 | JP |
10-2004-0092372 | Nov 2004 | KR |
10-2007-0108294 | Nov 2007 | KR |
Entry |
---|
B. Kaufmann, “Fitting a sum of exponentials to numerical data,” 2003. |
G. Hooker, “Functional Data Analysis: A Short Course”, handout from 2010 International Workshop on Statistical Modeling, Glasgow University, 2010, retrieved from http://faculty.bscb.cornell.edu/˜hooker/ShortCourseHandout.pdf. |
Extended European Search Report issued Nov. 10, 2015 in Patent Application No. 14191085.1. |
A. A. Poyton et al., “Parameter Estimation in Continuous-Time Dynamic Models Using Principal Differential Analysis”. Computers & Chemical Engineering, vol. 30, No. 4, XP027942814, Feb. 15, 2006, pp. 698-708. |
W. Y. Yang et al., “Chapter 3: Interpolation and Curve Fitting”, Applied Numerical Methods Using MATLAB, XP055225091, Jan. 27, 2005, pp. 117-177. |
Toshio Ito et al. “Analyzing Bilinear Neural Networks with New Curve Fitting for Application to Human Motion Analysis”, IEEE International Conference on Systems, Man, and Cybernetics, 2012, 8 pages. |
Office Action issued Oct. 16, 2015 in Korean Patent Application No. 10-2014-0166258 (with English language translation). |
Number | Date | Country | |
---|---|---|---|
20150178245 A1 | Jun 2015 | US |