Systems and methods for determining shooter locations with weak muzzle detection

Information

  • Patent Grant
  • 7710828
  • Patent Number
    7,710,828
  • Date Filed
    Friday, March 7, 2008
    16 years ago
  • Date Issued
    Tuesday, May 4, 2010
    14 years ago
Abstract
Systems and methods for locating the shooter of supersonic projectiles are described. The system uses at least five, preferably seven, spaced acoustic sensors. Sensor signals are detected for shockwaves and muzzle blast, wherein muzzle blast detection can be either incomplete coming from less than 4 sensor channels, or inconclusive due to lack of signal strength. Shooter range can be determined by an iterative computation and/or a genetic algorithm by minimizing a cost function that includes timing information from both shockwave and muzzle signal channels. Disambiguation is significantly improved over shockwave-only measurements.
Description
BACKGROUND OF THE INVENTION

The present invention relates to law enforcement technologies and security, and more particularly to methods and systems for determining the origin and direction of travel of supersonic projectiles based on shockwave and muzzle sound information. The methods and systems are capable of determining and disambiguating shooter locations even for large distances between shooter and sensor and when the signal from the muzzle sound is weak.


Systems and methods are known that can determine the general direction and trajectory of supersonic projectiles, such as bullets and artillery shells by measuring parameters associated with the shockwave generated by a projectile. One such system, described in U.S. Pat. No. 5,241,518 includes at least three spaced-apart sensors, with each sensor incorporating three acoustic transducers arranged in a plane. The sensors generate signals in response to the shockwave which are related to the azimuth and elevation angle to the origin of the shockwave. However, shock-wave-only measurements are unable to determine the distance between the sensor(s) and the origin of the shockwave. With additional information from the muzzle blast, an accurate location of the origin of the projectile and a line of bearing to the origin of the projectile can be determined. However, when the muzzle blast is masked, shadowed or otherwise distorted, the signal from the muzzle blast may be difficult to discern from spurious signals and noise, so that the derived distance information may become inaccurate. Moreover, even if a clearly discernable muzzle blast signal were received from distant shooter locations, determining the range (distance) of the shooter can still remain a problem.


Conventional systems employ acoustic sensors, e.g., microphones, which can be relatively closely spaced (e.g., 1 meter apart) or widely dispersed (e.g., mounted on a vehicle or carried by soldiers on a battlefield), and measure shockwave pressure omni-directionally at their respective locations.


The azimuth angle, elevation angle, and range of a shooter with reference to the sensor location can be determined by measuring Time-of-Arrival (TOA) information of the muzzle signal and shockwave signal at each sensor. Each of the sensors encounters these signals at a different time and generates an electric signal in response to the shockwave pressure. The signals from the various sensors are processed, and a direction (azimuth and elevation) from the sensor(s) to the origin of the shockwave as well as the range, and hence the trajectory of the projectile can be determined.


Conventional algorithms require at least 4 shockwave and muzzle detections so that a 4×4 matrix can be inverted to map a plane wave on the shockwave TOA. Small errors in shock and muzzle TOA determination can produce substantial errors in the range estimations. Moreover, the conventional algorithms assume a constant bullet speed along the bullet trajectory, which gives inaccurate range estimates for long-range shots being fired from a distance of more than approximately 300 m.


Accordingly, there is a need for rapidly converging algorithms capable of accurately estimating a distant shooter range.


In addition, there is a need to disambiguate shock-wave only solutions for the shooter direction. This is typically accomplished by using the muzzle signal. Disadvantageously, however, less than 4 muzzle sounds may be detected in many situations, for example, due to extraneous noise, reflections, etc., that can mask the muzzle signal. It would therefore be desirable to provide a method for reliably disambiguating shock-wave only solutions even if muzzle blast signals are detected on less than 4, for example 2 or 3, acoustic sensors.


In some situations, an initially detected muzzle signal may be discarded as being unreliable, for example, because the detection level is too low to indicate a muzzle blast signal; or because the muzzle energy is not readily evident in the raw signal; or because echoes from the shockwave are stronger than the muzzle blast and arrive earlier than the actual muzzle blast, causing the detection system to falsely identify shock as muzzle. These uncertain muzzle blast signals, if properly identified and extracted, may still be useful for refining detection of the shooter position, in particular in conjunction with the detection of shock-wave signals.


It would therefore also be desirable to provide a method for extracting muzzle signals that may be obscured by acoustic signatures unrelated to the muzzle blast.


SUMMARY OF THE INVENTION

The invention addresses the deficiencies of the prior art by, in various embodiments, providing methods and systems for estimating shooter range for long-range shots, in particular, when muzzle signals are either weak or detected in an insufficient number of detection channels. The disclosed methods and systems also improve disambiguation of shockwave-only shooter trajectory solutions by including detected muzzle sound in the optimization process.


According to one aspect of the invention, in a method for estimating a shooter range by detecting shock wave and muzzle blast, shockwave-only signals as well as muzzle blast signals are measured at a plurality of spaced acoustic sensors forming an antenna. An initial shooter range is estimated from the measured shock wave and muzzle blast signals, assuming an initial bullet velocity and a bullet drag coefficient. The instantaneous bullet velocity along a bullet trajectory is iteratively computed to obtain an updated shooter range. The number of muzzle blast detection channels is usually less than the number of shockwave detection channels.


Advantageous embodiments may include one or more of the following features. A time-difference-of-arrival (TDOA) between the shockwave-only signals and the muzzle blast signals and an arrival angle are computed for determining the initial shooter range. A certain number of iterations may be performed, or the updated shooter range will be considered to be the final shooter range if a relationship between successively determined updated shooter ranges satisfies the convergence criterion. For example, the convergence criterion may be selected so that the difference between the successively determined updated shooter ranges or a percentage change between the successively determined updated shooter ranges is smaller than a predetermined value. To obtain real solutions, the computed bullet velocity is set to always be at least the speed of sound. The solutions are checked for consistency. For example, the updated shooter range is considered invalid if a bullet trajectory angle and an arrival angle are determined to be greater than a predetermined value.


Even if the computed shooter range is determined to be invalid, a solution may still be obtained by applying a genetic algorithm (GA). For example, an initial population of the GA with a predetermined number of individuals can be defined, where each individual is represented by a 3-tupel which includes an assumed shooter range, a missed azimuth (MA) and a missed elevation (ME) of the bullet trajectory. The GA is performed for a predefined number of generations, and residuals for the individuals in each generation are computed. In each generation the solution with the smallest residual is selected as the individual which survives unmutated. The solution having the smallest residual is selected as the updated shooter range. The solution can be refined by performing for each 3-tupel in a generation a predetermined number of iterations to compute a revised shooter range, wherein the residuals for the individuals in each generation are computed with the revised shooter range.


The GA includes crossover and mutation operators. The crossover operator exchanges at least one of missed azimuth and missed elevation between two individuals from the population in a generation, whereas the mutation operator comprises field-mutation (replacing a value of the 3-tupel with a randomly selected value), incremental mutation (inducing a small mutation in all fields of the 3-tupel), and no mutation (leaving the individuals in a generation unaltered).


According to yet another aspect of the invention, a method for disambiguating a projectile trajectory from shockwave signals and from a limited number of muzzle blast signals includes measuring shockwave-only signals at five or more spaced acoustic sensors forming an antenna, measuring muzzle blast signals on at most 4 of the sensors, and determining from the shockwave-only signals Time-Differences-Of-Arrival (TDOA) information for sensor pairs. The method further includes performing for a predefined number of generations a genetic algorithm with an initial population that includes a predetermined number of individuals, each individual represented by a 4-tupel which includes shooter azimuth, shooter elevation, missed azimuth and missed elevation, and computing residuals for the individuals in each generation, with the residuals including a least-square fit of a combination of TDOA shockwave and muzzle blast signals. If a ratio of the solution having the smallest residual and its ambiguous alternate solution is greater than a predefined value, the solution having the smallest computed residual is designated as the disambiguated projectile trajectory.


According to another aspect of the invention, a method for extracting a signal from a muzzle wave in the presence of a shockwave signal includes defining a time window having a width corresponding to a time required for a muzzle wave to traverse a sensor array and detecting the shockwave signal. Following detection of the shockwave signal, the window is advanced in time and the total energy received in the window is measured as a function of advance time. The maximum of the measured total energy is associated with the muzzle signal.


In advantageous embodiments, the total energy can be determined by integrating the measured energy over the window, preferably disregarding portions in the detected signal caused by shockwave echoes. Advantageously, the peak signal value can be determined in the window producing the maximum total energy and if the peak signal value is greater than the measured total energy in the window by a predefined ratio factor, the peak signal value can be identified as being related to the muzzle signal.


Further features and advantages of the invention will be apparent from the following description of illustrative embodiments and from the claims.





BRIEF DESCRIPTION OF THE DRAWINGS

These and other features and advantages of the invention will be more fully understood by the following illustrative description with reference to the appended drawings, in which elements are labeled with like reference designations and which may not be to scale.



FIG. 1 is a schematic diagram of a shockwave Time-of-Arrival (TOA) model;



FIG. 2 shows a schematic process flow diagram for range estimation;



FIG. 3 shows a schematic process flow diagram of a genetic algorithm for range estimation; and



FIG. 4 shows a schematic process flow diagram of a genetic algorithm for disambiguating between shooter trajectories.





DESCRIPTION OF ILLUSTRATIVE EMBODIMENTS

As described above in summary, the invention provides, in various embodiments, methods and systems for shooter range estimation and disambiguation of projectile trajectories. These systems and method are particularly useful and advantageous, when an insufficient number of parameters required for an accurate solution are detected or when such parameters cannot be detected reliably.



FIG. 1 shows schematically a diagram of a Time of Arrival (TOA) model, which is described in more detail in U.S. Pat. No. 6,178,141 (incorporated herein by reference in its entirety). The TOA model can be used to estimate the trajectory of the projectile and the shooter direction relative to the sensor location. The TOA model is based on a ballistic model taking into account certain physical characteristics relating to the projectile's flight path, such as the air density (which is related to temperature); the position {right arrow over (P)} (Px, Py, Pz) of a shooter; the azimuth and elevation angles of the rifle muzzle; the muzzle velocity of the projectile (or equivalent Mach number); and the speed of sound (which varies with temperature/air density). With this ballistic model, it is possible to accurately calculate the time at which the shockwave and muzzle blast reach a particular point in space.


As depicted in the diagram of FIG. 1, the shooter is located at point {right arrow over (P)} (PX, PY, PZ) relative to an origin (0, 0, 0), the various sensors are located at points {right arrow over (S)}j (Sxj, Syj, Szj) and the bullet trajectory is shown as emanating from the shooter in the direction of {right arrow over (A)}. The vector from the shooter to the jth sensor is {right arrow over (D)}, the closest point of approach (CPA) of the bullet to the jth sensor is |{right arrow over (R)}|=|{right arrow over (D)}|sin (β), and the path followed from the point where the shockwave is radiated from the trajectory to the jth sensor is {right arrow over (S)} (the index j of the sensors has been omitted). The Mach angle of the bullet is θ=sin−1 (1/M), M=V/c0. M is the Mach number of the projectile, V is the supersonic velocity of the projectile, and c0 is the (pressure- and temperature-dependent) speed of sound. The ‘miss-angle’ between trajectory and the jth sensor is β. The trajectory is characterized by its azimuth angle measured counter-clockwise from the x-axis in the x-y plane and by its elevation angle measured upward from the x-y plane. The equations that define the shockwave arrival time tj and unit vector at the jth sensor are written in terms of these geometrical quantities.


The time of arrival is equal to the time









A




V





it takes for the projectile to travel the distance |{right arrow over (A)}| to the point were sound is radiated toward the jth sensor, plus the time it takes the shockwave to travel the distance |{right arrow over (S)}| from the radiation point to the jth sensor,










S





c
0


.













t
j

=



t
0

+



A


V

+



S



c
0



=


t
0

+




D



c
0




sin


(

β
+
θ

)






,




(
1
)







wherein t0 is a time reference (firing time) and c0 is the speed of sound. The Mach angle Θ is also indicated in FIG. 1.


It can be safely assumed that the velocity V of the projectile remains constant over a distance corresponding to the sensor spacing, so that there is insignificant loss of speed between the times the projectile radiates to the different sensors. However, over longer distances projectiles are known to slow down due to air resistance. The air resistance can be expressed by a drag coefficient Cb which depends on the bullet shape and bullet caliber. A mathematical ballistics model derived from physical principles can predict the arrival time of a shockwave at any general point in space as a function of a full set of parameters describing the projectile (e.g., by its drag coefficient Cb), its initial velocity, and the density of the surrounding air are known in advance.


The parameters required for an exact calculation are typically not known in a realistic setting, such as a battlefield. However, range estimation can be significant improved by an iterative process shown in form of a process flow diagram 20 in FIG. 2, which takes into account deceleration of the projectile velocity along the trajectory. The process 20 begins at step 202 with the following assumptions:


c0 speed of sound modified for outside temperature/air pressure (≈340 m/s)


Cb=nominal drag coefficient averaged over anticipated weapons


V0=initial velocity of the projectile, when fired, averaged over anticipated weapons


M0=V0/c=initial Mach number of projectile


A first estimate of the shooter distance D0 is computed in step 204 using the measured time-difference-of-arrival (TDOA) τms and an arrival angle α between shock and muzzle sound at the sensor array and by assuming an initial, constant speed V0 and Mach number M0, according to the equation










D
0

=



τ

m





s


·

c
0



1
-

cos


(
α
)








(
2
)







With these assumptions, the projectile's speed at a distance a from the shooter position {right arrow over (P)} can be computed in step 206 from the equation










M
a

=



M
0

(

1
-

a


C
b




V
0





)

2





(
3
)







so that the time the projectile travels the distance a along the trajectory becomes, step 208,










T
a

=

a


V
0

-


a
·


V
0




C
b








(
4
)







The angle Θ is related to the Mach number Ma by the equation










sin


(
Θ
)


=

1

M
a






(
5
)







wherein the Mach number Ma is initially set to M0. It should be noted that the instantaneous bullet velocity is set to the speed of sound (i.e., Ma=1) if the computed bullet velocity becomes less than the speed of sound. The revised distance a=|{right arrow over (A)}| in step 210 then becomes









a
=


D
0

·

cos


(
β
)


·


(

1
-


tan


(
β
)





M
a
2

-
1




)

.






(
6
)







The angles α, β, and Θ are related by the equation (α+β+Θ))=90°. The process 20 then loops back to step 206 by inserting the computed value for the distance a in equations (3) and (4), yielding an updated Mach number Ma and an updated bullet travel time Ta, respectively, for the traveled distance a. The measured TDOA τms and the computed updated values for Ta and a are then used to successively update the value D for the shooter range:

D=c0·(τms+Ta)+s  (7)


This process is repeated until either a maximum number of iterations has been reached or the range values D converge, as determined in step 212.


The process 20 also checks in step 214, if the revised range value D=|{right arrow over (D)}| for the distance between the shooter and the sensor array is a “reasonable” value, in which case the process 20 terminates at step 216. For example, the value for D can be considered valid if the distance a traveled by the projectile and the distance






s
=

a
·


sin


(
β
)



sin


(
α
)









between the sensor and the point where the sound wave is radiated from the projectile to the sensor are valid number values, i.e., not a NAN. A NAN is a special floating point value representing the result of a numerical operation which cannot return a valid number value and is typically used to prevent errors from propagating through a calculation. In addition, α and β should both be less than a predetermined threshold value, indicating that the projectile was indeed fired toward the sensor array.


As mentioned above, the number pair (τms, α) is initially used to compute the shooter range D0 in zeroth approximation, neglecting change in the projectile's speed along the trajectory. If the iterative process 20 described above does not return a consistent geometry supporting the number pair (τms, α), then the solution is discarded.


Even if an exact solution may not be obtainable, it is a goal to find values for the shooter range D and the missed azimuth and elevation angles (which are related to β) that most closely match a measured shock TDOA and a measured muzzle TDOA. As already mentioned, the shockwave-only TDOA's between the various sensors can in most situations be reliably measured. The shooter azimuth and shooter elevation, but not the shooter range, can be determined from the shockwave-only TDOA's using the known sensor array coordinates (Sxj, Syj, Szj). It will be assumed that the TDOA τms between the detected shockwave and the muzzle sound can also be measured, whereby the muzzle sound may not be detected by all the sensors.


If it is determined in step 214 that the iterative process 20 does not return a valid result, then the process 20 attempts to compute the shooter range by invoking an evolutionary genetic algorithm (GA) 30. GA's mimic natural evolutionary principles and apply these to search and optimization procedures. A GA begins its search with a random set of solutions, instead of just one solution. Once a random population of solutions is created, each is evaluated in the context of the nonlinear programming problem and a fitness (relative merit) is assigned to each solution. In one embodiment, the fitness can be represented by the Euclidean distance between a calculated solution and the measured solution, for example, by










Δ






τ
min


=







j
=
1

N








(


τ

Shock
,
calc

j

-

τ

Shock
,
meas

j


)

2


N


+

abs
(





i
=
1

N







(


τ


m





s

,
calc

i

M

)


-

τ


m





s

,
meas



)






(
8
)







Intuitively, an algorithm producing a smaller value of Δτmin is better.


A schematic flow diagram of the GA process 30 is shown in FIG. 3. The process 30 uses the time-difference-of-arrival (TDOA) τms and the arrival angle α measured previously for process 20, step 302. An exemplary number of 3-tupes having the values {RANGE, MA, ME} is defined as an initial population, step 304, wherein RANGE is the shooter range D=|{right arrow over (D)}| shown in FIG. 1, MA is the missed azimuth, and ME is the missed elevation. The MA and ME values indicate by how much the bullet missed the target in azimuth and elevation space. The target in the illustrate example is assumed to be the sensor array. The initial population in step 304 is created by random selection of the 3-tupel spanning a meaningful and reasonable range of values:


RangeShooter={1000, . . . , 3000} [meter],


AzimuthMissed={−20, . . . , 20} [degrees], and


ElevationMissed={−20, . . . , 20} [degrees].


The computation essentially follows the same process as outlined above. Initially, for generation Gen=0, step 306, the shooter position vector {right arrow over (P)} (Px, Py, Pz) is computed for each 3-tupel with the previously determined shooter azimuth and elevation, and an assumed RANGE for the particular 3-tupel. Assuming an initial Mach number M0, the vector {right arrow over (A)} (Ax, Ay, Az), i.e. the position from where the shock sound is radiated, is computed with the MA and ME values for each 3-tupel, step 308. The distances {right arrow over (D)}={right arrow over (S)}j−{right arrow over (P)} between the shooter and each sensor j that detects a shockwave are also computed.


For each 3-tupel, the angle β is computed from the equation cos







β
=



A


·

(


P


-

S



)






A




·




P


-

S








,





wherein the symbol “●” indicates the scalar product between the two vectors. Updated values for the distance a, the travel time Ta of the projectile over the distance a, and the Mach number Ma are computed by inserting the computed value for β and the initially assumed values for Ma=M0 and a into equations (3), (4), (6), and (7), step 312. This process is iterated several times for each of the 3-tupels, for example 3 times, as determined in step 312, whereafter the residual defined in equation (8) is computed for each 3-tupel, step 314.


It is checked in step 316 if a maximum number of iterations for the GA, for example 25 iterations, have been reached. If the maximum number of iterations has been reached, then the process 30 stops at step 320, returning the 3-tupel with the smallest residual. Otherwise, the process 30 creates a new population through a crossover and mutation operation, step 318, and the generation counter is incremented by one, step 322


In each generation, the “best” individual is allowed to survive unmutated, whereas the top 100 individuals, as judged by their fitness, also survive, but are used to create the next 100 individuals from pairs of these survivors with the crossover/mutation operators listed in Table 1 below.


The following exemplary crossover and mutation operators were used to demonstrate the process 30:












TABLE 1






Operator




Operator Name
Type
Probability
Description







Missed Azimuth-
Crossover
0.5
Exchange missed azimuth between two


Crossover


chromosomes


Missed- elevation
Crossover
0.5
Exchange missed elevation between


Crossover


two chromosomes


Missed- range
Crossover
0.5
Exchange range between two


Crossover


chromosomes


Field-Mutation
Mutation
0.3
Replace a given field (with a probability





of 0.25 per field) with a randomly





selected new value within range


Incremental-Mutation
Mutation
0.4
Introduce small perturbations in all





fields of a chromosome (within ±2





meter for shooter range; within ±0.1°





for missed azimuth and elevation)









The GA process 30 is executed with an initial population of 200 different 3-tupels, with a refill rate of 50, for a total of 25 generations. The GA is run 5 times in parallel with different sets of initial 3-tupels, and the solution with the smallest residual is selected as the final solution for the RANGE, missed azimuth, and missed elevation of the shooter, which allows computation of vector {right arrow over (D)}.


Calculations that do not take into consideration the deceleration of the projectile along its path due to air resistance tend to overestimate range. For certain geometries and sufficiently distant shots, this overestimation may exceed 20%. The aforedescribed process removes this bias from range estimation for long-range shot detections.


Although shock-wave only solutions may be ambiguous, they can frequently be disambiguated by comparing the residuals from two different trajectories and selecting the trajectory with the smaller residual.


The residual of the shockwave-only solution can be defined as










Δτ
min

=




j




(


Δτ

Shock
,
calc

j

-

Δτ

Shock
,
meas

j


)

2







(
9
)







summed over all sensors j. The solution with the smallest value for Δτmin is selected as the most likely solution for the shooter direction. The precision of disambiguation can be improved, for example, by employing a genetic algorithm GA of the type disclosed, for example, in commonly assigned U.S. patent application Ser. No. 10/925,875.


If the muzzle blast signals are detected on 4 or more sensor channels, then the aforedescribed shock-muzzle algorithms can be used to unambiguously determine the shooter location, regardless of the number of shock channels. If the muzzle blast signals are detected in fewer than 4 sensors, but shockwave signals are detected in 5 or more shockwave channels, then the aforementioned GA can be used with a modified cost function or residual, whereby whatever muzzle signals are available are “mixed” into the optimization function to disambiguate the shockwave-only solution and/or refine the estimation of the shooter range. However, if fewer than 3 muzzle channels AND fewer than 5 shockwave channels are detected, then an alert can be activated without attempting to localize the shooter.


The muzzle signal may not be reliably detected on all channels, because:

    • 1. The detection level on one or more channels is too low to detect with confidence.
    • 2. The muzzle energy is not discernable in the raw signal, causing the system to correlate with ‘noise’, giving unreliable TDOA estimates.
    • 3. Echoes from the shockwave can be stronger than the muzzle blast and can arrive earlier than the muzzle blast, causing the system to falsely detect shock as muzzle.


With a muzzle blast signal only detected on some channels, the residual in this situation can be defined as











Δτ
min

=








i




(


Δτ

muzzle
,
calc

i

-

Δτ

muzzle
,
meas

i


)

2


+








j




(


Δτ

Shock
,
calc

j

-

Δτ

Shock
,
meas


j







)

2







,




(
10
)







wherein the first term for the muzzle blast is summed over the reduced number of sensors (<4) that detect the muzzle blast, and j is summed over the sensors detecting the shockwave (typically all sensors).


When applying the GA to disambiguate the shooter direction and projectile trajectory under these circumstances, the exemplary GA uses as a chromosome an initial population of 200 4-tupels, with each 4-tupel containing the following values:


[AzimuthShooter, ElevationShooter, AzimuthMissed, ElevationMissed].


The values [AzimuthShooter, ElevationShooter] are defined by the angle (90°−(Θ+β)), while the values [AzimuthMissed, ElevationMissed] are defined by the angle β (see FIG. 1). An initial range of, for example, 1000 m can be assumed for the shooter range.


The initial population is created by random selection of the 4-tupels spanning a meaningful and reasonable range of values (all values are in degrees):


AzimuthShooter={0, . . . , 360},


ElevationShooter={−10, . . . , 30},


AzimuthMissed={−20, . . . , 20}, and


ElevationMissed={−20, . . . , 20}.


A schematic flow diagram of the GA process 40 is shown in FIG. 4. The GA process 40 begins its search by initializing a random population of solutions, step 402, and sets a generation counter to zero indicating the initial solution set, step 404. Once a random population of solutions is created, each is evaluated in the context of the nonlinear programming problem, step 406, and a fitness (relative merit) is assigned to each solution, step 408. The fitness can be represented by the residual Δτmin in between a calculated solution and the measured solution, as described above. It is checked in step 410 if a maximum number of iterations for the GA, which can be set, for example, to 25, has been reached. If the maximum number of iterations has been reached, the process 40 stops at step 420, and the result can be either accepted or further evaluated. Otherwise, step 412 checks if preset fitness criteria have been satisfied.


Fitness criteria can be, for example, a computed missed azimuth of <15° and/or a ratio of the residuals of two ambiguous solutions. If the fitness criteria are satisfied, the process 40 stops at step 420; otherwise, a new population is created through crossover/mutations, step 414, and the generation counter is incremented by one, step 416.


In each generation, the “best” individual is allowed to survive unmutated, whereas the top 100 individuals, as judged by their fitness, also survive, but are used to create the next 100 individuals from pairs of these survivors with the crossover/mutation operators listed in Table 2.


The following exemplary crossover and mutation operators were used to demonstrate the process 40:












TABLE 2






Operator




Operator Name
Type
Probability
Description







Azimuth-Crossover
Crossover
0.5
Exchange shooter/trajectory azimuth





between two chromosomes


Missed-Crossover
Crossover
0.5
Exchange missed azimuth/elevation





between two chromosomes


Field-Mutation
Mutation
0.3
Replace a given field (with a probability





of 0.25 per field) with a randomly





selected new value within range


Incremental-Mutation
Mutation
0.4
Introduce small mutations in all fields





of a chromosome (within ≦2° for





shooter information; within ≦0.5° for





missed information


Flip-Mutation
Mutation
0.1
Change the solution into the ambiguous





alternate solution


No-Mutation
Mutation
0.2
Chromosome remains intact









Recent experimental trials indicated a decrease of ambiguous shots from 95% to 8% on the same data set by using at least one muzzle signal channel in addition to 5 or more shockwave channels.


As demonstrated by the examples described above, the muzzle blast signal provides important information about the shooter azimuth and hence the projectile's trajectory as compared to a shockwave-only solution, so that the computed trajectory solution aligns more closely with one of the ambiguous solutions, i.e., thus disambiguating the solutions.


Without at least some reliable muzzle signals, a significant number of ambiguous shockwave-only solutions may be generated in particular at long shooter distances, which are less desirable than a smaller number of unambiguous, but less precise solutions.


In the event of potentially unreliable muzzle detection, an attempt can still initially be made to detect muzzle signals, e.g., to find a muzzle blast signature in a noisy signal, and to compute the resulting TDOA's. The muzzle detection will be deemed to be reliable if muzzle signals are found on a sufficient number of sensor with sufficient cross-correlation between the channels, and if there is a sufficiently strong correlation between the muzzle signal and the corresponding raw band on each channel (offset by a number of bins to account for filter delays).


Otherwise, at least the muzzle signals that show insufficient correlation are erased, and the following ‘coarse muzzle detection’ logic is invoked:

    • Look for peaks in the shock energy following a shock. Flag these peaks as likely ‘shock echoes’, thereby excluding them as muzzle blasts.
    • Determine a maximum time it would take the muzzle wave to traverse the sensor array and define a “window” having the corresponding duration. Search for muzzle energy peaks by moving this window across substantially all detector channels following the detected shockwave, skipping sections in the detected signal which have been identified as shock echoes. Integrate the energy over the window, i.e., seek the maximum of:










f


(
i
)


=




n
=
0

N










j
=
0

W








(

mb

i
+
j

n

)

2







(
11
)







wherein the square of mbi+jn represents a measure of energy, e.g., energy of the muzzle blast, measured by the nth sensor. (i+j) indicates the detection channel, with i denoting a discrete time interval between the time the shockwave was detected and the beginning of the window, and j represents a time interval measured from the start of the window.


To discriminate against noise, the peak energy in the window producing the maximum of function ƒmax(i) in equation 11 is checked to determine if the energy peak at that maximum is greater than the energy across the window by a given ratio factor. If this is the case, then the signal in the window is identified as a muzzle detection, and cross-correlation is performed on all channels in the muzzle blast band mb to determine muzzle TDOA's.


The detected muzzle blast signal can then be used to determine the shooter range and/or disambiguate the shockwave signal, as described above.


While the invention has been disclosed in connection with the preferred embodiments shown and described in detail, various modifications and improvements thereon may be made thereto without departing from the spirit and scope of the invention. By way of example, although the illustrative embodiments are depicted as having acoustic sensors, such as microphones, this need not be the case. Instead, other types of pressure-sensitive mechanical or electrical sensors may be used. Moreover, the values given in Tables 1 and 2 for the various operators are intended to be examples only, and other values may be selected depending on the actual conditions in the field. Accordingly, the spirit and scope of the present invention is to be limited only by the following claims.

Claims
  • 1. A method for determining an unambiguous projectile trajectory using an array of spaced acoustic sensors when a shockwave associated with a projectile is detected by at least five of the sensors but a muzzle blast associated with the projectile is detected by fewer than four of the sensors, comprising: obtaining four or more shockwave TDOA measurements from the sensors detecting the shockwave, wherein the shockwave TDOA measurements are insufficient to compute the unambiguous projectile trajectory;obtaining fewer than three muzzle blast TDOA measurements from the sensors detecting the muzzle blast; anditeratively computing solutions to a ballistic model using the shockwave TDOA measurements and the muzzle blast TDOA measurements to obtain the unambiguous projectile trajectory.
  • 2. The method of claim 1, wherein one or two muzzle blast TDOA measurements are obtained from the sensors detecting the muzzle blast.
  • 3. The method of claim 2, wherein the unambiguous projectile trajectory is computed using a genetic algorithm.
  • 4. The method of claim 3, wherein performing the genetic algorithm comprises using a predefined number of generations with an initial population that includes a predetermined number of individuals, wherein each individual represented by a 4-tupel which includes shooter azimuth, shooter elevation, missed azimuth and missed elevation.
  • 5. The method of claim 4, wherein residuals are computed for the individuals in each generation, said residuals including a least-square fit of a combination of the shockwave TDOA measurements and the muzzle blast TDOA measurements.
  • 6. The method of claim 5, wherein if a ratio of the solution having the smallest residual and its ambiguous alternate solution is greater than a predefined value, designating the solution having the smallest computed residual as the unambiguous projectile trajectory.
  • 7. The method of claim 6, wherein performing the genetic algorithm comprises applying crossover and mutation operators to the initial population in a generation.
  • 8. The method of claim 7, wherein applying the crossover operator includes exchanging at least one of missed azimuth and missed elevation between two individuals from the population in a generation.
  • 9. The method of claim 7, wherein applying the crossover operator includes exchanging at least one of shooter azimuth and trajectory azimuth between two individuals from the population in a generation.
  • 10. The method of claim 7, wherein the mutation operator comprises field-mutation, incremental mutation, flip-mutation and no mutation.
  • 11. The method of claim 10, wherein the field-mutation operator replaces a value of the 4-tupel with a randomly selected value.
  • 12. The method of claim 10, wherein the incremental mutation operator induces a small mutation in all fields of the 4-tupel.
  • 13. The method of claim 10, wherein the flip-mutation operator changes the solution in a generation to its ambiguous alternate solution in the generation.
  • 14. The method of claim 10, wherein the no-mutation operator leaves the individuals in a generation unaltered.
  • 15. The method of claim 1, wherein iteratively computing solutions to a ballistic model is based at least in part on a value of a residual for the TDOA measurements obtained from the sensors detecting the shockwave and from the sensors detecting the muzzle blast.
  • 16. The method of claim 15, wherein the residual is a function of the differences between the calculated and measured TDOA measurements.
CROSS-REFERENCE TO RELATED APPLICATIONS

This application is a divisional application of U.S. patent application Ser. No. 11/210,295, filed Aug. 23, 2005, the entire contents of which are incorporated herein by reference.

GOVERNMENT CONTRACT

The U.S. Government has a paid-up license in this invention and the right in limited circumstances to require the patent owner to license others on reasonable terms as provided for by the terms of Contract No. HR0011-04-C-0035 awarded by DARPA ATO.

US Referenced Citations (66)
Number Name Date Kind
2435231 McPherson Feb 1948 A
2963696 Snyder Nov 1960 A
4283989 Toulios et al. Aug 1981 A
4813877 Sanctuary et al. Mar 1989 A
4970698 Dumestre, III Nov 1990 A
5241518 McNelis et al. Aug 1993 A
5280457 Figueroa et al. Jan 1994 A
5346210 Utke et al. Sep 1994 A
5392258 Gabrielson et al. Feb 1995 A
5544129 McNelis Aug 1996 A
5617371 Williams Apr 1997 A
5703321 Feierlein et al. Dec 1997 A
5777948 Ferkinhoff et al. Jul 1998 A
5781505 Rowland Jul 1998 A
5878000 Dubois Mar 1999 A
5912862 Gustavsen et al. Jun 1999 A
5920522 Levanon Jul 1999 A
5930202 Duckworth et al. Jul 1999 A
5970024 Smith Oct 1999 A
5973998 Showen et al. Oct 1999 A
6055523 Hillis Apr 2000 A
6178141 Duckworth et al. Jan 2001 B1
6198694 Kroling et al. Mar 2001 B1
6223458 Schwinkendorf et al. May 2001 B1
6370084 Cray Apr 2002 B1
6487516 Amorai-Moriya Nov 2002 B1
6563763 McNelis May 2003 B2
6621764 Smith Sep 2003 B1
6847587 Patterson et al. Jan 2005 B2
6965312 Lerg Nov 2005 B2
6965541 Lapin et al. Nov 2005 B2
7054228 Hickling May 2006 B1
7126877 Barger et al. Oct 2006 B2
7139222 Baxter et al. Nov 2006 B1
7162043 Sugiyama et al. Jan 2007 B2
7190633 Brinn et al. Mar 2007 B2
7203132 Berger Apr 2007 B2
7266045 Baxter et al. Sep 2007 B2
7292501 Barger Nov 2007 B2
7362654 Bitton Apr 2008 B2
7372772 Brinn et al. May 2008 B2
7372773 Horak May 2008 B2
7372774 Uzes May 2008 B1
7408840 Barger et al. Aug 2008 B2
7411865 Calhoun Aug 2008 B2
7420878 Holmes et al. Sep 2008 B2
7433266 Ledeczi et al. Oct 2008 B2
7474589 Showen et al. Jan 2009 B2
7495998 Deligeorges et al. Feb 2009 B1
7502279 Wignall et al. Mar 2009 B2
7532542 Baxter et al. May 2009 B2
20020003470 Auerbach Jan 2002 A1
20020029214 Yianilos et al. Mar 2002 A1
20040100868 Patterson et al. May 2004 A1
20050237186 Fisher et al. Oct 2005 A1
20060044941 Barger Mar 2006 A1
20060256660 Berger Nov 2006 A1
20070030763 Barger et al. Feb 2007 A1
20070171769 Brinn et al. Jul 2007 A1
20070230269 Ledeczi et al. Oct 2007 A1
20070237030 Barger et al. Oct 2007 A1
20080008044 Patterson et al. Jan 2008 A1
20080084473 Romanowich Apr 2008 A1
20080162089 Barger et al. Jul 2008 A1
20080298176 Fisher et al. Dec 2008 A1
20090086577 Ledeczi et al. Apr 2009 A1
Foreign Referenced Citations (8)
Number Date Country
0447725 Sep 1991 EP
2015127 Sep 1979 GB
2181239 Apr 1987 GB
2181240 Apr 1987 GB
WO-0137483 May 2001 WO
WO-02082097 Oct 2002 WO
WO-2009046367 Apr 2009 WO
WO-2009053702 Apr 2009 WO
Related Publications (1)
Number Date Country
20080159078 A1 Jul 2008 US
Divisions (1)
Number Date Country
Parent 11210295 Aug 2005 US
Child 12075051 US