This application is generally related to wireless charging power transfer applications, and specifically to a method and apparatus for positioning a vehicle. More specifically the present disclosure relates to determining a position of the vehicle relative to a ground-based charging unit based on magnetic vector fields (magnetic vectoring).
Efficiency in wireless inductive charging power applications depends at least in part on achieving at least a minimum alignment threshold between a wireless power transmitter and a wireless power receiver. One method for aiding such alignment is the use of magnetic vectoring, where a position of the wireless power receiver relative to the wireless power transmitter is determined based on sensing one or more attributes of a magnetic field generated at or near either the wireless power transmitter or the wireless power receiver. A position may include at least one of a distance, direction, and orientation of the wireless power receiver relative to the wireless power transmitter. However, determining a position accurately and with a minimum of ambiguity utilizing magnetic vectoring may involve a large number of calculation steps. Accordingly, a method and apparatus for positioning a vehicle as described herein are desirable.
In some implementations, an apparatus for determining a position of vehicle is provided. The apparatus comprises a plurality of receive coils, each of the plurality of receive coils configured to generate a respective voltage signal from a wireless magnetic field generated by a field generator. The apparatus further comprise the processor. The processor is configured to reduce a first set of data indicative of the respective voltage signals generated by the plurality receive coils to a second set of data that is substantially constant regardless of relative rotation between the plurality of receive coils and the field generator. The processor is further configured to determine a plurality of candidate positions based on comparing the second set of data to a plurality of first sets of stored data mapped to stored positions of the vehicle relative to the field generator. The processor is further configured to identify a plurality of second sets of stored data using the determined plurality of candidate positions, wherein the plurality of second sets of stored data are mapped to stored positions and orientations of the vehicle relative to the field generator. The processor is further configured to determine a position and an orientation of the vehicle with respect to the field generator based on comparing the first set of data with the plurality of second sets of stored data.
In some other implementations, a method for determining a location of a vehicle relative to a reference point. The method comprises receiving, as an input, a first multi-dimensional vector having a first plurality of values indicative of respective electrical characteristics of a plurality of positioning coils, the electrical characteristics generated in response to a magnetic field generated by a field generator. The method further comprises generating a second multi-dimensional vector having a second plurality of values by performing a non-linear transformation on the first multi-dimensional vector, the total number of the second plurality of values being less than the total number of the first plurality of values. The method further comprises determining a plurality of candidate positions based on comparing the second multi-dimensional vector to a plurality of stored multi-dimensional vectors mapped with stored positions of the vehicle relative to the reference point. The method further comprises identifying a second set of stored multi-dimensional vectors corresponding to the determined plurality of candidate positions, each of the second set of stored multi-dimensional vectors mapped to a stored position and orientation of the vehicle relative to the reference point. The method further comprises determining a position and orientation based on comparing the first multi-dimensional vector with the second set of stored multi-dimensional vectors.
In some other implementations, an apparatus for determining a location of a vehicle relative to a reference point is provided. The apparatus comprises means for receiving, as an input, a first multi-dimensional vector having a first plurality of values indicative of respective electrical characteristics of a plurality of positioning coils, the electrical characteristics generated in response to a magnetic field generated by a field generator. The apparatus further comprises means for generating a second multi-dimensional vector having a second plurality of values by performing a non-linear transformation on the first multi-dimensional vector, the total number of the second plurality of values being less than the total number of the first plurality of values. The apparatus further comprises means for determining a plurality of candidate positions based on comparing the second multi-dimensional vector to a plurality of stored multi-dimensional vectors mapped with stored positions of the vehicle relative to the reference point. The apparatus further comprises means for identifying a second set of stored multi-dimensional vectors corresponding to the determined plurality of candidate positions, each of the second set of stored multi-dimensional vectors mapped to a stored position and orientation of the vehicle relative to the reference point. The apparatus further comprises means for determining a position and orientation based on comparing the first multi-dimensional vector with the second set of stored multi-dimensional vectors.
In some other implementations, a method for positioning a vehicle is provided. The method comprises generating, at a plurality of receive coils, respective voltage signals based upon a wireless magnetic field generated by a field generator. The method further comprises reducing a first set of data indicative of the respective voltage signals generated at the plurality receive coils to a second set of data that is substantially constant regardless of relative rotation between the plurality of receive coils and the field generator. The method further comprises determining a plurality of candidate positions based on comparing the second set of data to a plurality of first sets of stored data mapped to stored positions of the vehicle relative to the field generator. The method further comprises identifying a plurality of second sets of stored data using the determined plurality of candidate positions, wherein the plurality of second sets of stored data are mapped to stored positions and orientations of the vehicle relative to the field generator. The method further comprises determining a position and an orientation of the vehicle with respect to the field generator based on comparing the first set of data with the plurality of second sets of stored data.
The detailed description set forth below in connection with the appended drawings is intended as a description of exemplary implementations and is not intended to represent the only implementations in which the invention may be practiced. The term “exemplary” used throughout this description means “serving as an example, instance, or illustration,” and should not necessarily be construed as preferred or advantageous over other exemplary implementations. The detailed description includes specific details for the purpose of providing a thorough understanding of the exemplary implementations. In some instances, some devices are shown in block diagram form.
Wirelessly transferring power may refer to transferring any form of energy associated with electric fields, magnetic fields, electromagnetic fields, or otherwise from a transmitter to a receiver without the use of physical electrical conductors (e.g., power may be transferred through free space). The power output into a wireless field (e.g., a magnetic field) may be received, captured by, or coupled by a “receiving coil” to achieve power transfer.
An electric vehicle is used herein to describe a remote system, an example of which is a vehicle that includes, as part of its locomotion capabilities, electrical power derived from a chargeable energy storage device (e.g., one or more rechargeable electrochemical cells or other type of battery). As non-limiting examples, some electric vehicles may be hybrid electric vehicles that include, besides electric motors, a traditional combustion engine for direct locomotion or to charge the vehicle's battery. Other electric vehicles may draw all locomotion ability from electrical power. An electric vehicle is not limited to an automobile and may include motorcycles, carts, scooters, and the like. By way of example and not limitation, a remote system is described herein in the form of an electric vehicle (EV). Furthermore, other remote systems that may be at least partially powered using a chargeable energy storage device are also contemplated (e.g., electronic devices such as personal computing devices and the like).
The electric vehicle 112 may include a battery unit 118, an electric vehicle coupler 116, and an electric vehicle wireless charging unit 114. The electric vehicle wireless charging unit 114 and the electric vehicle coupler 116 constitute the electric vehicle wireless charging system. In some diagrams shown herein, the electric vehicle wireless charging unit 114 is also referred to as the vehicle charging unit (VCU). The electric vehicle coupler 116 may interact with the base coupler 104a for example, via a region of the electromagnetic field generated by the base coupler 104a.
In some exemplary implementations, the electric vehicle coupler 116 may receive power when the electric vehicle coupler 116 is located in an electromagnetic field produced by the base coupler 104a. The field may correspond to a region where energy output by the base coupler 104a may be captured by the electric vehicle coupler 116. For example, the energy output by the base coupler 104a may be at a level sufficient to charge or power the electric vehicle 112. In some cases, the field may correspond to a “near-field” of the base coupler 104a. The near-field may correspond to a region in which there are strong reactive fields resulting from the currents and charges in the base coupler 104a that do not radiate power away from the base coupler 104a. In some cases the near-field may correspond to a region that is within about ½π of a wavelength of the a frequency of the electromagnetic field produced by the base coupler 104a distant from the base coupler 104a, as will be further described below.
Local distribution center 130 may be configured to communicate with external sources (e.g., a power grid) via a communication backhaul 134, and with the base wireless charging system 102a via a communication link 108.
In some implementations the electric vehicle coupler 116 may be aligned with the base coupler 104a and, therefore, disposed within a near-field region simply by the electric vehicle operator positioning the electric vehicle 112 such that the electric vehicle coupler 116 is sufficiently aligned relative to the base coupler 104a. Alignment may be considered sufficient when an alignment error has fallen below a tolerable value. In other implementations, the operator may be given visual and/or auditory feedback to determine when the electric vehicle 112 is properly placed within a tolerance area for wireless power transfer. In yet other implementations, the electric vehicle 112 may be positioned by an autopilot system, which may move the electric vehicle 112 until the sufficient alignment is achieved. This may be performed automatically and autonomously by the electric vehicle 112 with or without driver intervention. This may be possible for an electric vehicle 112 that is equipped with a servo steering, radar sensors (e.g., ultrasonic sensors), and intelligence for safely maneuvering and adjusting the electric vehicle. In still other implementations, the electric vehicle 112 and/or the base wireless charging system 102a may have functionality for mechanically displacing and moving the couplers 116 and 104a, respectively, relative to each other to more accurately orient or align them and develop sufficient and/or otherwise more efficient coupling there between.
The base wireless charging system 102a may be located in a variety of locations. As non-limiting examples, some suitable locations include a parking area at a home of the electric vehicle 112 owner, parking areas reserved for electric vehicle wireless charging modeled after conventional petroleum-based filling stations, and parking lots at other locations such as shopping centers and places of employment.
Charging electric vehicles wirelessly may provide numerous benefits. For example, charging may be performed automatically, virtually without driver intervention or manipulation thereby improving convenience to a user. There may also be no exposed electrical contacts and no mechanical wear out, thereby improving reliability of the wireless power transfer system 100. Safety may be improved since manipulations with cables and connectors may not be needed and there may be no cables, plugs, or sockets to be exposed to moisture in an outdoor environment. In addition, there may also be no visible or accessible sockets, cables, or plugs, thereby reducing potential vandalism of power charging devices. Further, since the electric vehicle 112 may be used as distributed storage devices to stabilize a power grid, a convenient docking-to-grid solution may help to increase availability of vehicles for vehicle-to-grid (V2G) operation.
The wireless power transfer system 100 as described with reference to
As a further explanation of the vehicle-to-grid capability, the wireless power transmit and receive capabilities may be configured to be reciprocal such that either the base wireless charging system 102a can transmit power to the electric vehicle 112 or the electric vehicle 112 can transmit power to the base wireless charging system 102a. This capability may be useful to stabilize the power distribution grid by allowing electric vehicles 112 to contribute power to the overall distribution system in times of energy shortfall caused by over demand or shortfall in renewable energy production (e.g., wind or solar).
With reference to
The base resonant circuit 206 (including the base coupler 204 and tuning capacitor C1) and the electric vehicle resonant circuit 222 (including the electric vehicle coupler 216 and tuning capacitor C2) may be tuned to substantially the same frequency. The electric vehicle coupler 216 may be positioned within the near-field of the base coupler and vice versa, as further explained below. In this case, the base coupler 204 and the electric vehicle coupler 216 may become coupled to one another such that power may be transferred wirelessly from the base coupler 204 to the electric vehicle coupler 216. The series capacitor C2 may be provided to form a resonant circuit with the electric vehicle coupler 216 that resonates substantially at the operating frequency. The series-tuned resonant circuit 222 should be construed as being exemplary. In another implementation, the capacitor C2 may be coupled with the electric vehicle coupler 216 in parallel. In yet other implementations, the electric vehicle resonant circuit 222 may be formed of several reactive elements in any combination of parallel or series topology. Element k(d) represents the mutual coupling coefficient resulting at coil separation d. Equivalent resistances Req,1 and Req,2 represent the losses that may be inherent to the base and electric vehicle couplers 204 and 216 and the tuning (anti-reactance) capacitors C1 and C2, respectively. The electric vehicle resonant circuit 222, including the electric vehicle coupler 216 and capacitor C2, receives and provides the power P2 to an electric vehicle power converter 238 of an electric vehicle charging system 214.
The electric vehicle power converter 238 may include, among other things, a LF-to-DC converter configured to convert power at an operating frequency back to DC power at a voltage level of the load 218 that may represent the electric vehicle battery unit. The electric vehicle power converter 238 may provide the converted power PLDC to the load 218. The power supply 208, base power converter 236, and base coupler 204 may be stationary and located at a variety of locations as discussed above. The electric vehicle load 218 (e.g., the electric vehicle battery unit), electric vehicle power converter 238, and electric vehicle coupler 216 may be included in the electric vehicle charging system 214 that is part of the electric vehicle (e.g., electric vehicle 112) or part of its battery pack (not shown). The electric vehicle charging system 214 may also be configured to provide power wirelessly through the electric vehicle coupler 216 to the base wireless power charging system 202 to feed power back to the grid. Each of the electric vehicle coupler 216 and the base coupler 204 may act as transmit or receive couplers based on the mode of operation.
While not shown, the wireless power transfer system 200 may include a load disconnect unit (LDU) (not known) to safely disconnect the electric vehicle load 218 or the power supply 208 from the wireless power transfer system 200. For example, in case of an emergency or system failure, the LDU may be triggered to disconnect the load from the wireless power transfer system 200. The LDU may be provided in addition to a battery management system for managing charging to a battery, or it may be part of the battery management system.
Further, the electric vehicle charging system 214 may include switching circuitry (not shown) for selectively connecting and disconnecting the electric vehicle coupler 216 to the electric vehicle power converter 238. Disconnecting the electric vehicle coupler 216 may suspend charging and also may change the “load” as “seen” by the base wireless power charging system 202 (acting as a transmitter), which may be used to “cloak” the electric vehicle charging system 214 (acting as the receiver) from the base wireless charging system 202. The load changes may be detected if the transmitter includes a load sensing circuit. Accordingly, the transmitter, such as the base wireless charging system 202, may have a mechanism for determining when receivers, such as the electric vehicle charging system 214, are present in the near-field coupling mode region of the base coupler 204 as further explained below.
As described above, in operation, during energy transfer towards an electric vehicle (e.g., electric vehicle 112 of
As stated, an efficient energy transfer occurs by transferring energy via an magnetic near-field rather than via electromagnetic waves in the far field, which may involve substantial losses due to radiation into the space. When in the near-field, a coupling mode may be established between the transmit coupler and the receive coupler. The space around the couplers where this near-field coupling may occur is referred to herein as a near-field coupling mode region.
While not shown, the base power converter 236 and the electric vehicle power converter 238, if bidirectional, may both include, for the transmit mode, an oscillator, a driver circuit such as a power amplifier, a filter and matching circuit, and for the receive mode a rectifier circuit. The oscillator may be configured to generate a desired operating frequency, which may be adjusted in response to an adjustment signal. The oscillator signal may be amplified by a power amplifier with an amplification amount responsive to control signals. The filter and matching circuit may be included to filter out harmonics or other unwanted frequencies and match the impedance as presented by the resonant circuits 206 and 222 to the base and electric vehicle power converters 236 and 238, respectively. For the receive mode, the base and electric vehicle power converters 236 and 238 may also include a rectifier and switching circuitry.
The electric vehicle coupler 216 and base coupler 204 as described throughout the disclosed implementations may be referred to or configured as “conductor loops”, and more specifically, “multi-turn conductor loops” or coils. The base and electric vehicle couplers 204 and 216 may also be referred to herein or be configured as “magnetic” couplers. The term “coupler” is intended to refer to a component that may wirelessly output or receive energy for coupling to another “coupler.”
As discussed above, efficient transfer of energy between a transmitter and receiver occurs during matched or nearly matched resonance between a transmitter and a receiver. However, even when resonance between a transmitter and receiver are not matched, energy may be transferred at a lower efficiency.
A resonant frequency may be based on the inductance and capacitance of a resonant circuit (e.g. resonant circuit 206) including a coupler (e.g., the base coupler 204 and capacitor C2) as described above. As shown in
As described above, according to some implementations, coupling power between two couplers that are in the near-field of one another is disclosed. As described above, the near-field may correspond to a region around the coupler in which mainly reactive electromagnetic fields exist. If the physical size of the coupler is much smaller than the wavelength, inversely proportional to the frequency, there is no substantial loss of power due to waves propagating or radiating away from the coupler. Near-field coupling-mode regions may correspond to a volume that is near the physical volume of the coupler, typically within a small fraction of the wavelength. According to some implementations, magnetic couplers, such as single and multi-turn conductor loops, are preferably used for both transmitting and receiving since handling magnetic fields in practice is easier than electric fields because there is less interaction with foreign objects, e.g., dielectric objects and the human body. Nevertheless, “electric” couplers (e.g., dipoles and monopoles) or a combination of magnetic and electric couplers may be used.
The base wireless charging system 302 includes a base controller 342 and the electric vehicle charging system 314 includes an electric vehicle controller 344. The base controller 342 may provide a base charging system communication interface to other systems (not shown) such as, for example, a computer, a base common communication (BCC), a communications entity of the power distribution center, or a communications entity of a smart power grid. The electric vehicle controller 344 may provide an electric vehicle communication interface to other systems (not shown) such as, for example, an on-board computer on the vehicle, a battery management system, other systems within the vehicles, and remote systems.
The base communication subsystem 372 and electric vehicle communication subsystem 374 may include subsystems or modules for specific application with separate communication channels and also for wirelessly communicating with other communications entities not shown in the diagram of
The electric vehicle charging system 314 may further include an electric vehicle positioning subsystem 364 connected to a magnetic field generator 368. The electric vehicle positioning subsystem 364 may be configured to drive the magnetic field generator 368 with currents that generate an alternating magnetic field. The base wireless charging system 302 may include a magnetic field sensor 366 connected to a base positioning subsystem 362. The magnetic field sensor 366 may be configured to generate a plurality of voltage signals under influence of the alternating magnetic field generated by the magnetic field generator 368. The base positioning subsystem 362 may be configured to receive these voltage signals and output a signal indicative of a position estimate and an angle estimate between the magnetic field sensor 366 and the magnetic field generator 368, as will be described in more detail in connection with
Further, electric vehicle controller 344 may be configured to communicate with electric vehicle onboard systems. For example, electric vehicle controller 344 may provide, via the electric vehicle communication interface, position data, e.g., for a brake system configured to perform a semi-automatic parking operation, or for a steering servo system configured to assist with a largely automated parking (“park by wire”) that may provide more convenience and/or higher parking accuracy as may be needed in certain applications to provide sufficient alignment between base and electric vehicle couplers 304 and 316. Moreover, electric vehicle controller 344 may be configured to communicate with visual output devices (e.g., a dashboard display), acoustic/audio output devices (e.g., buzzer, speakers), mechanical input devices (e.g., keyboard, touch screen, and pointing devices such as joystick, trackball, etc.), and audio input devices (e.g., microphone with electronic voice recognition).
The wireless power transfer system 300 may also support plug-in charging via a wired connection, for example, by providing a wired charge port (not shown) at the electric vehicle charging system 314. The electric vehicle charging system 314 may integrate the outputs of the two different chargers prior to transferring power to or from the electric vehicle. Switching circuits may provide the functionality as needed to support both wireless charging and charging via a wired charge port.
To communicate between the base wireless charging system 302 and the electric vehicle charging system 314, the wireless power transfer system 300 may use in-band signaling via base and electric vehicle couplers 304, 316 and/or out-of-band signaling via communications systems (372, 374), e.g., via an RF data modem (e.g., Ethernet over radio in an unlicensed band). The out-of-band communication may provide sufficient bandwidth for the allocation of value-add services to the vehicle user/owner. A low depth amplitude or phase modulation of the wireless power carrier may serve as an in-band signaling system with minimal interference.
In some implementations, some communications (e.g., in-band signaling) may be performed via the wireless power link without using specific communications antennas. For example, the base and electric vehicle couplers 304 and 316 may also be configured to act as wireless communication antennas. Thus, some implementations of the base wireless charging system 302 may include a controller (not shown) for enabling keying type protocol on the wireless power path. By keying the transmit power level (amplitude shift keying) at predefined intervals with a predefined protocol, the receiver may detect a serial communication from the transmitter. The base power converter 336 may include a load sensing circuit (not shown) for detecting the presence or absence of active electric vehicle power receivers in the near-field coupling mode region of the base coupler 304. By way of example, a load sensing circuit monitors the current flowing to a power amplifier of the base power converter 336, which is affected by the presence or absence of active power receivers in the near-field coupling mode region of the base coupler 304. Detection of changes to the loading on the power amplifier may be monitored by the base controller 342 for use in determining whether to enable the base wireless charging system 302 for transmitting energy, to communicate with a receiver, or a combination thereof.
In some implementations, the ferrite structure 808 may be shared between the wireless power transfer base coupler 304 and the magnetic field sensor 366 as shown in
The magnetic field based positioning system 900 further includes the magnetic field sensor 366 of
In some implementations, the magnetic field based positioning system 900 is configured to include an optional synchronization link 930 configured to establish time or phase synchronization between the electric vehicle positioning subsystem 364 and the base positioning subsystem 362.
In some implementations, the magnetic field based positioning system 900 may comprise a 2-axis generator and a 3-axis sensor. In such implementations, one of the plurality of generator coils 902, 904, 906 may be omitted or alternatively driven with zero current. Similarly, in some implementations, the magnetic field based positioning system 900 may comprise a 3-axis generator and a 2-axis sensor. In such implementations, one of the plurality of sense coils 912, 914, 916 may be omitted or alternatively electrically disconnected from the base positioning subsystem 362. In some implementations, the magnetic field based positioning system 900 may comprise a 2-axis generator and a 2-axis sensor.
In some implementations, physical restrictions for the position of the sensor 366 with respect to the generator 368 may apply. For example, in an implementation in accordance with
r
z′<0, (1)
θ′≈ψ′≈0 (2)
holds.
In operation, the electric vehicle positioning subsystem drives 364 the generator coils 902, 904, 906 with respective coil currents Ix′, Iy′, Iz′, represented in vector form as:
Current vectors may be also combined to a 3×3 matrix:
In some implementations, the electric vehicle positioning subsystem 364 drives the generator coils 902, 904, 906 each with equal current levels so that
I
x′
=I
y′
=I
z′
=I (5)
holds. In some other implementations, the electric vehicle positioning subsystem 364 drives the generator coils 902, 904, 906 each with an alternating (sinusoidal) current with an amplitude so that
ωx′Ix′=ωy′Iy′=ωz′Iz′. (6)
holds, where ωx′, ωy′, ωz′ denote the angular frequencies of the coil driving currents.
Alternating coil currents Ix′, Iy′, Iz′ circulating in the generator coils 902, 904, 906 generate an alternating magnetic field. Magnetic flux from this alternating magnetic field flows through each of the sense coils 912, 914, 916 and induces respective voltages across the terminals of the sense coils 912, 914, 916. These voltages are detected by the base positioning subsystem 362 operationally coupled to the sense coils as shown in
The values of the voltage vectors Vx VyVz, may represent sampled voltage values output from detection and synchronization circuitry based on oscillating voltage signals at the sense coil terminals. These 3-dimensional vectors are referred to as 3D voltage vectors. Components of these voltage vectors are indicative of the voltages produced by the alternating magnetic field generated by each of the generator coils 902, 904, 906, respectively. Vector components Vx′x, Vy′x, Vz′x are indicative of the voltage components induced into the x-sense coil 912 by the generator coils 902, 904, 906, respectively. Vector components Vx′x, Vy′x, Vz′x are indicative of the voltage components induced into the y-sense coil 914 by the generator coils 902, 904, 906, respectively. Vector components Vx′z, Vy′z, Vz′z are indicative of the voltage components induced into the z-sense coil 916 by the generator coils 902, 904, 906, respectively. As shown in
3D voltage vectors Vx′, Vy′, Vz′ may also be combined to form a 3×3 voltage matrix:
They may be also combined to form a 9-dimensional (9D) voltage vector:
In some implementations, the base positioning subsystem 362 determines a position and orientation of the sensor 366 relative to the generator 368 based on the nine components of the 9D voltage vector.
For a sinusoidal current excitation of the generator coils 902, 904, 906, the magnetic field coupling relationship between the 3-axis generator 368 and the 3-axis sensor 366, indicated by the relationship between the three generator 368 coil currents Ix′, Iy′, Iz′ and the nine voltage components as detected by the base positioning subsystem 362 at the three terminals of the sensor 366, may be expressed in matrix form using definitions (4) and (8) as:
[V′]=j[ω][M′][I′], (10)
with j=√{square root over (−1)} and [M′] denoting the 3×3 mutual inductance matrix defined as:
and [ω′] denoting the 3×3 angular frequency matrix of the current excitation:
In some implementations using a sinusoidal current excitation of the generator coils 902, 904, 906, the base positioning subsystem 362 determines a position and orientation of the sensor 366 relative to the generator 368 based on the nine mutual inductances (elements) of the mutual inductance matrix (11). In such implementations, the electric vehicle positioning subsystem 364 may communicate excitation current levels Ix′, Iy′, Iz′ to the base positioning subsystem 362 via communications link 376, allowing the base positioning subsystem 362 to compute the mutual inductance matrix. If Equation (6) holds for the current excitation, elements of the voltage matrix of Equation (8) are proportional to elements of the mutual inductance matrix of Equation (11). Therefore, implementations relying on the mutual inductance matrix of Equation (11) may be equivalent to implementations relying on the voltage matrix of Equation (8).
The base positioning subsystem 362 may determine the absolute value of the dot product (i.e., the scalar product) of each unique combination of the 3D voltage vectors Vx′, Vy′, Vz′ that also form the 9D voltage vector V′ to generate a 6-dimensional (6D) absolute scalar (dot) product vector A′:
The 3D voltage vectors Vx′, Vy′, Vz′ are dependent upon the orientation of the sensor 366 with respect to the generator 368. As such, the 9D voltage vector V′, which comprises the components of each of the voltage vectors Vx′, Vy′, Vz′, is also dependent upon the orientation of the sensor 366 with respect to the generator 368. By contrast, since the components of A′ are determined from the dot product of components of V′, vector A′ is orientation-independent, if the magnetic sensor 366 is isotropic. A 3-axis magnetic field sensor 366 may be considered isotropic if the magnitude of the 9D voltage vector (9) remains constant or substantially constant for a rotation of the magnetic field sensor 366 about any axis by any angle. In some implementations, a 3-axis magnetic field sensor 366 may be considered isotropic if the 9D voltage vector (9) remains constant for any (azimuthal) rotation by an angle φ′ about its z-axis. If the magnetic field sensor 366 is substantially isotropic, the 6D absolute scalar product vector A′ may be substantially invariant to rotation of the sensor 366 with respect to the generator 368 (e.g., the vector A′ may be substantially constant regardless of relative rotation the sensor 366 with respect to the generator 368).
In some implementations, the sensor 366 may not constitute a physical arrangement of orthogonal sense coils. Instead, the sensor 366 may comprise a plurality of non-orthogonal sense coils, whereupon the base positioning subsystem 362 may perform an additional operation of orthogonalization, e.g., on the 3×3 voltage matrix (8), such that the 9D voltage vector V becomes equivalent to the 9D voltage vector as obtained from a sensor 366 that constitutes a physical arrangement of orthogonal sense coils e.g. as shown by
With this understanding, a positioning inquiry may be made as follows. Based on the nine detected voltage components Vx′x, Vx′y, Vx′z, Vy′x, Vy′3, Vy′z, Vz′x, Vz′y, Vz′z indicative of voltages induced into sense coils 912, 914, 916, a position r′=[rx′, ry′, rz′]T and rotation angles φ′,θ′,ψ′ in the sensor's 366 coordinate frame (e.g., x′, y′ and z′-axes) can be determined. This is a 6-dimensional (6D) inquiry, since there are 6 unknowns: the 3 position coordinates rx′, ry′, rz′ and the 3 rotation angles φ′,θ′,ψ′.
In some implementations, by imposing a set of physical restrictions and assumptions, this 6D inquiry may be reduced to a 3D inquiry that may be resolved with less computation. For example, in some implementations, it may be assumed that the magnetic field sensor 366 is located in a lower half-space as defined by Equation (1). Further, in some implementations, the vertical distance rz, between the sensor and generator may be disregarded. Moreover, in some implementations it may be assumed that the generator and the sensor are both substantially horizontally oriented (e.g., there is no relative pitch or roll so that Equation (2) holds). Thus, under these assumptions, knowing the generator coil driving currents Ix′, Iy′, Iz′, and the detected voltage components Vx′x, Vx′y, Vx′z, Vy′x, Vy′y, Vy′z, Vz′x, Vz′y, Vz′z indicative of the sense coil induced voltages, a position r′=[rx′, ry′]T and a rotation angle φ′ in the vehicle's coordinate frame may be determined. This modified inquiry becomes a 3D inquiry by virtue of the elimination of the position vector rz, and the rotation angles θ′ and ψ′.
In some implementations, multiplexing may be used in order to allow the base positioning subsystem 362 to differentiate between the contributions of each of the generator coils 902, 904, 906 to the voltages induced in each of the sense coils 912, 914, 916 of
As previously described in connection with
A potential consequence of a missing absolute phase synchronization is that the detected 3D voltage vectors Vx′, Vy′, Vz′ may be ambiguous with respect to their absolute polarity.
However, in some implementations, relative phase synchronization may ensure that individual vectors of vector triple Vx′, Vy′, Vz′ have no polarity ambiguity relative to each other, meaning that the angles α, β, γ between vectors Vx′, Vy′, Vz′ as indicated in
In some implementations, absolute polarity ambiguity may result in ambiguity of the position and/or orientation as determined by a magnetic field based positioning system 600. However, even in absence of absolute polarity ambiguity, magnetic field sensing may result in position and/or orientation ambiguity. The nature of position ambiguity, which is inherent to the structure of magnetic fields, is illustrated in more detail in connection with
As illustrated in
r′
1
=r′
2. (14)
holds.
A change in either the position or the orientation of the sensor 368 with respect to the generator 366 will result in a change in the 9D voltage vector V′. The nature of such variability is described in more detail in connection with
{circumflex over (V)}′=V′+
, (15)
where {circumflex over (V)}′ is the perturbed 9D voltage vector, V′ is the unperturbed voltage vector, and is the noise vector. The noise vector may be considered a vector random variable and may be statistically described by a multi-dimensional (multivariate) probability distribution e.g. a multivariate Gaussian distribution. For example,
=== . . . =. (16)
In this case, the 9D probability distribution may be considered hyperspherical with a radius .
Since the base positioning subsystem 362 determines the 6D absolute scalar product vector A′ as an absolute value of the dot product of components of the 9D vector V′, if V′ is perturbed, e.g., by additive noise , A′ will generally be similarly perturbed by noise according to the equation:
Â′=A′+
, (17)
where Â′ is the perturbed 6D vector, A′ is the unperturbed 6D vector, and is the 6D noise vector.
The perturbed vectors {circumflex over (V)}′ and Â′ may also be known as detection vectors, since any voltages detected by the base positioning subsystem 362 would be subjected to at least minimal noise and/or interference from the ambient environment and/or from the base position subsystem itself.
In some implementations, an unperturbed zero-rotated 9D voltage vector V′0 may be defined as the unperturbed 9D voltage vector V′ that results when all rotation angles φ′,θ′,ψ′ of the sensor 366 with respect to the generator 368 are zero. If the sensor 366 is isotropic as defined above, the unperturbed 9D voltage vector V′(φ′,θ′,ψ′) as obtained with a sensor 366 having arbitrary rotation angles φ′,θ′,ψ′ and the unperturbed zero-rotated 9D voltage vector V′0 may be related by the following matrix equation:
[V′(φ′,θ′,ψ′)]=[Rψ′][Rθ′][Rφ′][V′0], (18)
where [Rφ′], [Rθ′,], and [Rψ′] denote rotation matrices defined as
In some implementations, the base positioning subsystem 362 may determine an estimate {circumflex over (V)}′0 of the unperturbed zero-rotated 9D vector V′0 from a perturbed 9D detection vector {circumflex over (V)}′(φ′,θ′,ψ′) as obtained with a sensor 366 having arbitrary rotation angles φ′,θ′,ψ′ by utilizing the inverse of matrix equation (18) as follows:
[{circumflex over (V)}′0]=[Rφ′]T[Rθ′]T[Rψ′]T[{circumflex over (V)}′(φ′,θ′,ψ′)], (22)
where [•]T denotes the transposed matrix of the respective rotation matrices defined by Equations (19)-(21). The matrix operation as defined by Equation (22) may herein be referred to as de-rotation and the matrix [{circumflex over (V)}0] as a rotational transform of matrix [{circumflex over (V)}′]. This rotational transform of matrix [{circumflex over (V)}′] may be also denoted by [{circumflex over (V)}′(−φ′,−θ′,−ψ′)].
V′=ƒ′(r′,φ′,θ′,ψ′). (23)
Similarly,
[r′,φ′,θ′,ψ′]=ƒ′−1(V′). (24)
In some implementations, determining a valid unambiguous position may rely on the mapping function ƒ′(•) having a one-to-one relationship (i.e., an injective relationship). In other words, each 6D position and orientation vector [r′,φ′,θ′,ψ′] maps to a single 9D voltage vector V′ and, reciprocally, each 9D voltage vector V′ maps to a single 6D position and orientation vector [r′,φ′,θ′,ψ′]. For the 3-axis generator/3-axis sensor system of
Moreover, in some implementations, determining an accurate position and orientation may rely on the mapping function ƒ′(•) and/or its inverse ƒ′−1 being valid for a particular parking space and stable over time.
In some implementations, the mapping function ƒ′ and/or its inverse ƒ′−1 or portions thereof may be described by a mathematical (analytic) multidimensional function, e.g., based on magnetic monopole or dipole functions, polynomial functions, exponential functions, trigonometric functions, hypergeometric functions, Gaussian functions, etc.
In some other implementations, the mapping function ƒ′ and/or its inverse ƒ′−1 or portions thereof may be defined by a table function also referred to as a look-up table (LUT), an example of which is illustrated in
In some implementations, an output value string of the mapping function ƒ′ and the input value string of the inverse mapping function ƒ′−1 may be also referred to as a reference vector V′ regardless whether ƒ′ and/or its inverse ƒ′−1 is implemented as an analytic or tabulated function (LUT).
In some implementations, each combination of position r′ and rotation angles φ′,θ′,ψ′ associated to a reference vector V′ may correspond to a grid point in a limited position and orientation space 2000 as further described below. If the inverse mapping function is based on a LUT, the grid point spacing and the resulting number of reference vectors V′ may represent a trade-off between positioning accuracy and LUT size. If based on an analytic function, the grid point spacing and the resulting number of reference vectors V′ may relate to the numeric precision of the processor 3004 as described in connection with
The plurality of reference vectors V′ each associated to a position r′ and a rotation angle φ′ may be also referred to as a vector map regardless whether ƒ′ and/or its inverse ƒ′−1 is implemented as an analytic or tabulated function (LUT) or whether it is a finite or an infinite set.
In some implementations, the plurality of reference vectors V′ may be obtained in a previous process of system calibration. This process of system calibration may involve computer simulations, e.g., using a finite element method (FEM), interpolation, approximation, regression using analytic methods, measurements in a controlled environment, and/or in-situ in a particular parking space using a real implementation of a magnetic field positioning system 900.
In some implementations, the base positioning subsystem 362 may determine a position and/or an orientation of the sensor 366 with respect to the generator 368 based on the inverse mapping function ƒ′−1 according to Equation (24) using the detection vector V′ as an input, which may be expressed as
[r′,φ′,θ′,ψ′]=ƒ′−1({circumflex over (V)}′). (25)
If the inverse mapping function ƒ′−1 is analytically defined, the base positioning subsystem 362 may compute a position and/or orientation using Equation (25) and a suitable numerical method.
In some implementations, the set of reference vectors V′ related to positions r′ and rotation angles φ′,θ′,ψ′ by the mapping function ƒ′ may occupy only a subspace of the voltage vector space. This may be particularly true in cases where the dimensionality of the voltage vector space exceeds that of the position and rotation angle space (e.g., 9D vs. 6D) and if the position and rotation angle space itself is restricted. If the detection vector V′ is perturbed e.g. by additive noise as previously described, the detection vector V′ may not belong to the set of reference vectors V′=ƒ (r′,φ′,θ′,ψ′). In such event, the inverse function ƒ′−1 may not provide a solution at all or it may not provide a physically meaningful solution for r′,φ′,θ′,ψ′. The likelihood for such event may be high if the dimensionality of the voltage vector space 2050 exceeds that of the position and rotation space 2000 (e.g., 9D vs. 6D). However, even if the dimensionality of the two spaces is equal and the sensor's 366 true position and orientation is within the specified position and rotation angle space, the inverse function ƒ′−1 may not always provide a solution, depending on the properties and structure of ƒ′−1. In any case, if the detection vector V′ is perturbed, a solution of ƒ′−1({circumflex over (V)}′) must be considered an estimate of the sensor's 366 true position and orientation with respect to the generator 368 and may be expressed as:
[{circumflex over (r)}′,{circumflex over (φ)}′,{circumflex over (θ)}′,{circumflex over (ψ)}′]=ƒ−1({circumflex over (V)}′). (26)
In some implementations, the base positioning subsystem 362 deduces a position and/or an orientation of the sensor 366 with respect to the generator 368 by first performing some non-linear operations on the detection vector {circumflex over (V)}′ so that a physically meaningful solution for r′,φ′,θ′,ψ′ exists for any or at least for most perturbed detection vectors {circumflex over (V)}′. In some implementations using an isotropic sensor 366 as previously defined, such non-linear operation may include transforming the vector {circumflex over (V)}′ into a vector Â′, e.g., in analogy to Equation (13). However, such implementations may not perform optimally in the sense of a best estimate {circumflex over (r)}′,{circumflex over (φ)}′,{circumflex over (θ)}′,{circumflex over (ψ)}′ for the sensor's 366 true position and orientation, respectively, since such non-linear operation generally involves a loss of information.
Therefore, in some implementations, the base positioning subsystem 362 may deduce a position and/or orientation of the sensor 366 with respect to the generator 368, which may be equivalent to the position and/or orientation of the base 408 with respect to the vehicle 406, by determining a closest match between the detection vector {circumflex over (V)}′ and a plurality of reference vectors V′ previously calibrated to correspond to particular positions r′ and rotation angles φ′,θ′,ψ′ of sensor 366 with respect to the generator 368. This process of position and orientation finding may be also referred to as joint position and orientation finding. The plurality of reference vectors V′ associated with positions r′ and rotation angles q′,θ′,ψ′ may define the mapping function of Equation (23).
From a probabilistic perspective, if vector {circumflex over (V)}′ is perturbed, e.g., by additive noise as previously described, the reference vector of a plurality of reference vectors V′(r′) that is closest to a detection vector {circumflex over (V)}′ may represent the reference vector of highest probability (maximum likelihood). Therefore, the position r′ and rotation angles φ′,θ′,ψ′ associated to that reference vector may also represent the sensor's 366 position and orientation of highest probability. The position and orientation of highest probability may be also considered a best estimate {circumflex over (r)}′ and {circumflex over (φ)}′,{circumflex over (θ)}′,{circumflex over (ψ)}′ of the sensor's 366 true position and orientation, respectively.
If vector {circumflex over (V)}′ is perturbed by additive noise with standard deviations as defined by Equation (27), the base positioning subsystem 362 may use the Euclidean distance between two vectors for determining the vector pair having closest match.
∈=|d|=|a−b|=√{square root over (Σi=1N(ai−bi)2)}. (28)
where ai is the ith vector component of the vector a and bi is the ith vector component of the vector b. Vector a and vector b may refer to the reference vector V′ and the detection vector {circumflex over (V)}′, respectively.
If Equation (29) does not hold, meaning that standard deviations are unequal, the base positioning subsystem 362 may employ, instead of the Euclidean distance, a weighted distance metrics e.g.
where ai may refer to the ith component of the vector a (e.g., reference vector V′) and bi to the ith component of the vector b (e.g. detection vector {circumflex over (V)}′). In some implementations, the base positioning subsystem 362 may employ an alternative distance metric, e.g. the squared Euclidean distance, an approximation of the Euclidean distance, a weighted distance metric in accordance with Equation (33), or any other suitable distance metric. Descriptions of position and orientation finding processes below assume the standard Euclidean distance as defined by Equation (32) but should not be construed limited to that.
In some implementations based on a LUT, an example of which is illustrated in
In some implementations using an isotropic or substantially isotropic sensor 366 as previously defined, the base positioning subsystem 362 may deduce a position and/or orientation of the sensor 366 with respect to the generator 368 by determining a shortest Euclidean distance between a 9D detection vector V′ and a plurality of rotational transforms V′0(φ′, θ′, 0′) for each of a plurality of previously calibrated reference vectors V′0. The rotational transform may comprise a sequence of rotations of reference vector V′0, first by angle φ′, then by angle θ′, and finally by angle ψ′, e.g., as given by Equation (18).
In some implementations using an isotropic or substantially isotropic sensor 366 as previously defined, the base positioning subsystem 362 may deduce a position and/or orientation of the sensor 366 with respect to the generator 368 by determining a shortest Euclidean distance between a plurality of rotational transforms {circumflex over (V)}′(−φ′,−θ′,−ψ′) of the detection vector
In some implementations, the zero-rotated reference vectors V′0(r′) may be stored in a look-up table (LUT) 2300, an example of which is illustrated in
In mathematical terms, a position of a plurality of discrete positions r′ may be expressed by position vector r′i,j,k=[rx′,i, ry′,j, rz′,k]T, where indices i,j,k are integer numbers. Likewise, a respective angle of a plurality of discrete angles φ′, θ′, and ψ′ may be expressed by φ′l, θ′m, and ψ′n, where indices l, m, n are integer numbers. Using these definitions, the process of determining a position and rotation angle jointly based on the shortest (minimum) Euclidean distance ∈ may be expressed as
where |•| denotes the norm of a vector in the Euclidean space. The term “all” shall be understood as all iterations (combinations) of i,j,k,l,m,n,p over the number ranges as specified for a particular implementation. The position and rotation angles as output by the process of Equation (31) may represent a position estimate {circumflex over (r)}′ and rotation angle estimates {circumflex over (φ)}′,{circumflex over (θ)}′,{circumflex over (ψ)}′, respectively. In some implementations, these estimates may include position and/or orientation ambiguity. The rotational transform (also known as de-rotation) of the 9D detection vector {circumflex over (V)}′ is given by matrix equation (18) and may be expressed in the context of Equation (31) as
[{circumflex over (V)}′(−φ′l,−θ′m,−ψ′n)]=[Rψ′
In some implementations, the discrete positions r′i,j,k may correspond to grid points in a limited 3D position space, which is referred to as the search space. The search space may be defined by the following ranges:
x′
min
<r
x′,i
<x′
max,
y′
min
<r
y′,j
<y′
max,
z′
min
<r
z′,k
<z′
max (33)
where x′min and x′max denote the lower and upper limit of the x′-dimension of the 3D position space, y′min and y′max the lower and upper limit of its y′-dimension, etc. The grid points of the search space may have a tight enough spacing so that it does not noticeably impair the accuracy of the position and orientation estimates as determined by the base positioning subsystem 362 regardless of the sensor's 366 position. In some implementation, grid points are equally spaced. In some other implementations, grid points are unequally spaced, e.g., a spacing increasing with distance from the origin of the 3D position space according to some rule. In an exemplary implementation, e.g., where physical restrictions for the sensor's 366 position as defined by Equation (1) applies, the ranges may be limited to x′min=500 cm, x′max=500 cm, y′min=300 cm, y′max=300 cm, z′min=15 cm, z′max=10 cm, and an equal grid point along each axis may apply.
In some implementations, the discrete angles φ′l, θ′m, and ψ′n correspond to grid points in a 3D orientation angle space defined by the following ranges:
φ′min≦φ′l<φ′max,
θ′min≦θ′m<θ′max,
ψ′min≦ψ′n<ψ′max, (34)
where φ′min and φ′max denote the lower and upper limit of the φ′-dimension of the 3D orientation space, θ′min and θ′max the lower and upper limit of the θ′-dimension, etc. The grid points may have a tight enough spacing so that it does not noticeably impair the accuracy of the position and orientation estimates as determined by the base positioning subsystem 362 regardless of the sensor's 366 position and orientation. For example, in an exemplary implementation, the following limits φ′min=−180°, φ′max=180°, θ′min=−180°, θ′max=180°, ψ′min=180°, ψ′max=180°, and an equal grid point spacing of 1° may apply. If physical restrictions for the sensor's 366 pitch and roll angle as defined by Equation (2) apply, the limits for the θ′- and ψ′-ranges may be set to θ′min=θ′max=ψ′min=ψ′max=0°.
In some other implementations, the limits x′min, x′max, y′min, y′max, z′min, z′max, φ′min, φ′max, θ′min, θ′max, ψ′min, ψ′max, of the search space and the grid spacing are variable parameters may depend on previously found position and orientation angle estimates, respectively.
In further implementations, the plurality of discrete positions r′i,j,k may correspond to grid points in a search space that is determined by a function of the 9D detection vector. In some implementations, the base positioning subsystem 362 determines a 3D cylindrical search space centered in the origin of the generator's 368 coordinate frame that is limited by an inner radius ρ′x′,y′,min and outer radius ρ′x′,y′,max and by a z′-height range. This cylindrical search space may be defined as:
ρ′x′,y′,min<√{square root over (rx′,i
z′
min
<r
z′,k
<z′
max. (35)
In some implementations, the base positioning subsystem 362 may determine the inner radius ρ′x′,y′,min and the outer radius ρ′x′,y′,max based on a value that is derived from the 9D detection vector {circumflex over (V)}′, e.g., on its magnitude |{circumflex over (V)}′|.
Depending on the number of grid points in the search space, the process of joint position and orientation finding may be extremely computationally intensive. In some implementations, to reduce computational load, this process of position and orientation finding may be divided into a first operation process that is an orientation-independent position finding process and a second operation process that is an orientation finding process based on the position found in the first operation process.
The orientation-independent position finding process is described below and applies to a base positioning subsystem 362 using a sensor 366 that is isotropic or substantially isotropic as previously defined. The base positioning subsystem 362 may first determine a position estimate {circumflex over (r)}′ based on a detection vector Â′ (e.g., the 6D detection vector as defined by Equation (13)). Detection vector Â′ is a non-linear transform of detection vector {circumflex over (V)}′, has lower dimensionality than {circumflex over (V)}′, and is invariant to the sensor's 366 rotation and to polarity ambiguity. The base positioning subsystem 362 may determine a position estimate {circumflex over (r)}′ by finding a shortest Euclidean distance between the detection vector Â′ and a plurality of previously-calibrated reference vectors A′(r′i,j,k). These reference vectors A′(r′i,j,k) may be stored in a look up table (LUT) 2300, as described in connection with
where |•| denotes the norm of a vector in the Euclidean space. The term “all” may be understood as all iterations (combinations) of i,j,k over the number ranges as specified by a particular implementation. In some implementations, these ranges correspond to grid points in one octant of the 3D position subspace of the 6D position and orientation space.
In some implementations, if the vector map A′(r′i,j,k) is symmetric with respect to at least one of an x′-, y′-, and z′-axis, the position estimate {circumflex over (r)}′ as determined by an orientation-independent process (Equation (36)) may be considered ambiguous. If a physical restriction for the sensor's 366 position apply, e.g. rz′<0, an ambiguous position may comprise one position in each of the 5th, 6th, 7th, and 8th octant of the lower half space at symmetry points. These positions may be expressed as
Once a position estimate r is known, the sensor's 366 orientation may be determined in a second operation orientation finding process based on the 9D detection vector {circumflex over (V)}′. This may be accomplished by determining a shortest Euclidean distance ∈ between a rotational transform {circumflex over (V)}′(−φ′l,−θ′m,−ψ′n) of detection vector {circumflex over (V)}′ and a zero-rotated reference vector V′0 associated to the position {circumflex over (r)}′ found in the first operation process, iteratively for every angle of a plurality of discrete angles φ′l, for every angle of a plurality of discrete angles θ′m, and for every angle of a plurality of discrete angles ψ′n, and, if required, for both polarity hypothesis p=[+1, −1]. If the position estimate {circumflex over (r)}′ as obtained from the first operation position finding process is ambiguous, e.g., comprising positions {circumflex over (r)}′5, {circumflex over (r)}′6, {circumflex over (r)}′7, and {circumflex over (r)}′8 as given by Equation (37), the orientation finding process may also include iterations over these ambiguities. If the vector data in the LUT 2300 covers the 5th, 6th, 7th, and 8th octant, the zero-rotated reference vectors V′0 associated to these positions can be obtained from the LUT 2300. However, if the LUT 2300 covers only one octant e.g. the 1st octant, reference vectors for other octants may be obtained by using an octant transform, which may be expressed using matrix notation as
[V′0({circumflex over (r)}′q)]=[Q′q][V′0({circumflex over (r)}1)][Q′q], (38)
where [V′0({circumflex over (r)}′q)] denotes the matrix notation of the new reference vector transformed from the 1st to the qth octant, and [Q′q] the matrix transforming a reference vector V′0({circumflex over (r)}′1) from the 1st to the qth octant. In some implementations, transformation matrices [Q′q] may be given by,
for q=1:
for q=2:
for q=3:
for q=4:
for q=5:
for q=6:
for q=7:
and for q=8:
Above matrices as defined by Equations (39)-(47) may also apply to an inverse octant transform from the qth octant back to the 1st octant.
In mathematical terms, the second operation process of determining rotation angle estimates {circumflex over (φ)}′, {circumflex over (θ)}′, {circumflex over (ψ)}′ at position {circumflex over (r)}′ found by the preceding orientation-independent process may be expressed as
where |•| denotes the norm of a vector in the Euclidean space. The term “all” shall be understood as all iterations (combinations) of l, m, n, p, q over the number ranges as specified by a particular implementation. The rotational transform (also known as de-rotation) of the detection vector {circumflex over (V)}′ may be given by matrix equation (32). If the position estimate {circumflex over (r)}′ exhibits ambiguity, e.g., at symmetry positions in the 5th, 6th, 7th, and 8th octant as given by (37), iterations may be performed for q=5, 6, 7, and 8. Otherwise q=1 may be assumed.
In some implementations, the base positioning subsystem 362 applies an octant transformation to the rotational transform {circumflex over (V)}′(−φ′l, −θ′m, −ψ′n) of the detection vector {circumflex over (V)}′ rather than to the reference vector V′0({circumflex over (r)}′) in order to determine the shortest Euclidean distance ∈ and the LUT 2300 contains reference vector data e.g. only for the first octant. Using matrix equation (38), the octant transform of {circumflex over (V)}′(−φ′l, −θ′m, −ψ′n) may be expressed as
[{circumflex over (V)}′q(−φ′1,−θ′m,−ψ′n)]=[Q′q][{circumflex over (V)}′(−φ′l,−θ′m,−ψ′n)][Q′q], (49)
Equation ( ) may refer to an inverse octant transform of a 9D detection vector as obtained with the sensor 366 at a position in the qth octant to a symmetry position in the 1st octant. The inverse octant and rotational transform of vector {circumflex over (V)}′ may be denoted by {circumflex over (V)}′q(−φ′l,−θ′m,−ψ′n). Using this denotation, this second operation process of determining rotation angle estimates {circumflex over (φ)}′, {circumflex over (θ)}′, {circumflex over (ψ)}′ based on the shortest (minimum) Euclidean distance E may be expressed as
This process may be equivalent to the process defined by Equation ( ).
In some implementations, if detection vectors are perturbed e.g. by noise as previously discussed, position and rotation angle estimates as obtained from the two-operation (sequential) position and orientation finding process as described above may be less accurate compared to estimates obtained from the computationally intensive joint position and orientation finding process as previously described.
An alternative process in accordance with some implementations, which may represent a trade-off between computational burden and positioning accuracy is described below. This process may be again a two-operation process comprised of a first operation process that is an orientation-independent position finding process and a second operation process that is a joint position and orientation finding process. In the first operation process, the base positioning subsystem 362 may find a number Nc of candidate positions r′1, r′2, . . . , r′N, for which Euclidean distances ∈1, ∈2, . . . ∈N
In some implementations, the number of candidates Nc may be in the range from 10 to 100. If the LUT 2300 of
where |•| denotes the norm of a vector in the Euclidean space. The term “all” shall be understood as all iterations (combinations) of i,j,k over the number ranges as specified by a particular implementation. In some implementations, these ranges correspond to grid points in one octant of the 3D position subspace of the 6D position and orientation space. In some implementations, the number Nc of candidate positions r′1, r′2, . . . , r′N, may be a predetermined value. In some implementations, the Nc of candidate positions r′1, r′2, . . . , r′N
In a subsequent (second operation) process, the base positioning subsystem 362 may determine, amongst the set of Nc candidate positions r′1, r′2, . . . , r′N
If candidate positions have ambiguity at symmetry points in different octants, the second operation may include iterations over all inverse octant transforms as required by a particular implementation as previously discussed. If the detection vector {circumflex over (V)}′ is also subject to a polarity ambiguity, iterations may include both polarity hypothesis p=+1 and p=−1. The process of joint position and orientation finding amongst Nc candidate positions r′1, r′2, . . . , r′N
where |•| denotes the norm of a vector in the Euclidean space. The term “all” shall be understood as all iterations (combinations) of p and q over the number ranges as specified by a particular implementation.
In some implementations, the above-described positioning processes may rely on the magnetic field sensor 366 being isotropic or at least substantially isotropic. In some implementations only the magnetic field generator 368 may be considered isotropic. In such implementations, the position and orientation finding processes described above may be performed by relying on the concept of a fictitious reverse transmitting system. In this fictitious system, position and orientation as determined may refer to the generator's 368 position and orientation in the sensor's 366 coordinate frame that may be equivalent to the base's 408 coordinate frame.
The law of reciprocity of linear electrical networks states that the coupling between the generator coils 902, 904, 906 and the sense coils 912, 914, 916 and thus the mutual inductances between all coil combinations in the system 1000 shown in
where e.g. matrix element Mxy′ denotes the mutual inductance between the x-sense coil 912 and the y′-generator coil 904 and matrix element Mx′y between the mutual inductance between the x′-generator coil 902 and the y-sense coil 914 in connection with
Since, magnetic field position and orientation finding may rely on the magnetic field coupling relationship (e.g. the mutual inductances) as previously discussed, the direction of transmission may be irrelevant. Thus, the above-described position and orientation finding processes may be performed using the concept of the fictitious reverse transmitting system 2700. In this fictitious system, position and rotation angles refer to the generator's 368 (vehicle's) position and orientation, respectively, in the sensor's (base 408) coordinate frame having x-, y-, and z-axis.
In analogy to the definitions (3) to (12), vectors and matrices of the fictitious reverse transmitting system 2700 may be defined, for the current vectors:
for the 3×3 current matrix:
for the 3D voltage vectors:
for the 3×3 voltage matrix:
for the 9D voltage vector:
and for the 3×3 angular frequency matrix of the fictitious current excitation:
In the fictitious reverse transmitting system 2700, for a sinusoidal current excitation of the sense coils 912, 914, 916, the relationship between the three sense coil currents Ix, Iy, Iz and the resulting nine voltage components of voltage vector V may be expressed in matrix form using definitions ( ), (, and (as
[V]=[ω][M][I]. (56)
Exciting the sense coils 912, 914, 916 of the fictitious reverse transmitting system 2700 with the same currents and frequencies as the generator coils 902, 904, 906 in the real forward transmitting system 1000, so that
[I]=[I′] (59)
and
[ω]=[ω′] (57)
holds, would result in the same induced voltage components, and the voltage matrices are related as follows:
[V]=[ω][M][I]=[ω′][M′]T[I′]=[V′]T. (58)
Hence, the induced voltage components are related as follows:
V
xx′
=V
x′x,
V
xy′
=V
y′x,
V
xz′
=V
z′x,
etc. (59)
Analogously to definition (13), the base positioning subsystem 364 may determine the absolute value of the scalar product of each unique combination of the 3D vectors Vx, Vy, Vz that also form the 9D voltage vector V to generate a 6D vector A for the fictitious reverse transmitting system 2700 as follows:
As opposed to the 6D vector A′ defined by (13), the vector A may become invariant to rotations of the generator 368 with respect to the sensor 366 in implementations where only the magnetic field generator 368 may be considered isotropic.
In analogy to Equation (31), a process for determining a position and orientation jointly in the fictitious reverse transmitting system 2700 of
where V0(ri,j,k) denotes the 9D zero-rotated reference vector associated to position ri,j,k and {circumflex over (V)}(−φl, −θm, −ψn) the rotational transform of the 9D detection vector {circumflex over (V)} (as defined by ( )) of the fictitious reverse transmitting system 2700. The rotational transform {circumflex over (V)}(−φl, −θm, −ψn) may be defined in analogy to Equation (32) by
{circumflex over (V)}(−φl,−θm,−ψn)=[Rφ
where matrices [Rφ
Position and rotation angle estimates {circumflex over (r)}, {circumflex over (φ)}, {circumflex over (θ)}, {circumflex over (ψ)} as output by the process of Equation ( ) refer to the generator's 368 position and orientation in the sensor's 366 coordinate frame.
In some implementations, position estimate {circumflex over (r)} and rotation angle estimates {circumflex over (φ)}, {circumflex over (θ)}, {circumflex over (ψ)} as determined in the sensor's 366 coordinate frame may be transformed back to the generator's 366 coordinate frame using standard coordinate transformation given by the following Equations ( )-( ):
{circumflex over (r)}′=[R
{circumflex over (ψ)}
][R
{circumflex over (θ)}
][R
{circumflex over (φ)}](−{circumflex over (r)}), (63)
{circumflex over (φ)}′=−{circumflex over (φ)}, (64)
{circumflex over (θ)}′=−{circumflex over (θ)}, (65)
{circumflex over (ψ)}′=−{circumflex over (ψ)}. (69)
Matrices [R{circumflex over (ψ)},], [R{circumflex over (θ)}], and [R{circumflex over (ψ)}] represent rotation matrices and are defined analogously to definitions (19)-(21).
Accordingly, the base positioning subsystem 362 may determine a position of the generator 368 with respect to the sensor 366 in the fictitious reverse transmitting system 2700 of
where A (ri,j,k) may denote the 6D reference vectors as stored in a LUT analogous to the LUT 2300 of
Accordingly, once position {circumflex over (r)} is known, e.g., from a first operation orientation-independent positioning process, the base positioning subsystem 362 may determine rotation angles {circumflex over (φ)}, {circumflex over (θ)}, {circumflex over (ψ)} of the generator 368 with respect to the sensor 366 in the fictitious reverse transmitting system 2700 of
Moreover, in some implementations, the base positioning subsystem 362 may determine a position estimate {circumflex over (r)} and rotation angle estimates {circumflex over (φ)}, {circumflex over (θ)}, {circumflex over (ψ)} of the generator 368 with respect to the sensor 366 in the fictitious reverse transmitting system 2700 of
In a subsequent (second operation) process, the base positioning subsystem 362 may determine, amongst the set of Nc candidate positions r1, r2, . . . , rN
The memory 3010 may be configured to store information for use by either or both of the phase synchronization circuitry 3002 and the processor 3004. For example, the LUT 2300 of
The processor 3004 may be configured to receive the signals indicative for {circumflex over (V)}x′x, {circumflex over (V)}x′y, {circumflex over (V)}x′z, {circumflex over (V)}y′x, {circumflex over (V)}y′y, {circumflex over (V)}y′z, {circumflex over (V)}z′x, {circumflex over (V)}z′y, {circumflex over (V)}z′z, and output signals indicative of the position estimate {circumflex over (r)}′ and angle estimates φ′,θ′,ψ′ as previously described in connection with
For example, the phase synchronization circuitry 3002 may be configured to determine a first detection vector {circumflex over (V)}′ having a first number of dimensions (e.g., 9D) based on the respective voltage signals vx(t), vy(t), vz(t) generated by the plurality of sense coils 912, 914, 916 (see
The processor 3004 may further be configured to determine, using the first set of (voltage) data, a second set of data, which may comprise components of a second detection vector Â′ having a second number of dimensions (e.g., 6D) less than the first number of dimensions (see
The processor 3004 may further be configured to select a plurality of stored first reference vectors A′(r′1), A′(r′2), . . . , A′(r′N
The processor 3004 may further be configured to select a plurality of stored second reference vectors V′0 (r′1), V′0(r′2), . . . , V′0(r′N
The processor 3004 may further be configured to rotationally transform the determined first detection vector {circumflex over (V)}′ by at least one predetermined rotation angle, e.g., φ′ (see
The processor 3004 may further be configured to increment the at least predetermined rotation angle e.g. φ′ by a predefined angle step and rotationally transform the determined first detection vector {circumflex over (V)}′ by the incremented rotation angle φ′ a plurality of times until a limit of a predetermined rotation angle range is reached (see Equation (34)).
The processor 3004 may further be configured to, for each of the rotationally transformed first detection vectors, determine a Euclidean distance ∈ between the rotationally transformed first detection vector {circumflex over (V)}′(−φ′,−θ′,−ψ′) and each of the selected stored second reference vectors V′0 (r′1), V′0(r′2), . . . , V′0(r′N
The processor 3004 may further be configured to determine a position with respect to the magnetic field generator 368 based on the selected stored second reference vector {circumflex over (V)}0 (r′) for which the determined Euclidean distance ∈ between the selected stored second reference vector V′0(r′) and any of the rotationally transformed first detection vectors {circumflex over (V)}′(−φ′,−θ′,−ψ′) is a minimum (see
In the second operation, a final position estimate {circumflex over (r)}′ and orientation estimate {circumflex over (φ)}′,{circumflex over (θ)}′,{circumflex over (ψ)}′ is determined using the joint positioning process as previously described (e.g., in
At block 3402, a processor (e.g., processor 3004) determines a first set of (voltage) data based on respective voltage signals generated by a plurality of receive coils, wherein each of the plurality of receive coils is configured to generate a respective voltage signal in response to a wireless magnetic field generated by a field generator. In some implementations, the first set of (voltage) data corresponds to a multi-dimensional vector (e.g., a 9-dimensional vector).
At block 3404, the first set of (voltage) data is reduced to a second set of data, wherein the second set of data is substantially constant regardless of relative rotation between the plurality of receive coils and the field generator. In some implementations, the second set of data may correspond to a multi-dimensional vector, such as a 6-dimensional vector. In some implementations, reducing the first set of voltage data to the second set of data comprises performing a non-linear transformation on the first set of voltage data.
At block 3406, a plurality of stored positions (e.g., candidate positions) may be determined. This may comprise comparing the second set of data to a plurality of a first set of stored data each corresponding to a position with respect to the field generator to determine a subset of the plurality of the first set of stored data. In some implementations, the plurality of stored positions may correspond to first sets of stored data having a smaller distance to the determined second set of data than all other first sets of stored data of the plurality of first sets of stored data. In some implementations, the number of stored positions in the subset may be a predetermined number, or may comprise all stored positions in which the comparison to the second set of data satisfies one or more criteria (e.g., Euclidean distance less than a threshold amount), or some combination thereof.
At block 3408, a position and an orientation with respect to the field generator is determined, based on the first set of data and the plurality of stored positions (e.g., as determined at block 3406). The positions corresponding to the subset of the plurality of the first set of stored data may be used to determine a subset of a second set of stored (voltage) data, which may be compared to at least one rotational transforms of a first set of (voltage) data to determine the position and orientation.
The various operations of methods described above may be performed by any suitable means capable of performing the operations, such as various hardware and/or software component(s), circuits, and/or module(s). Generally, any operations illustrated in the figures may be performed by corresponding functional means capable of performing the operations.
Information and signals may be represented using any of a variety of different technologies and techniques. For example, data, instructions, commands, information, signals, bits, symbols, and chips that may be referenced throughout the above description may be represented by voltages, currents, electromagnetic waves, magnetic fields or particles, optical fields or particles, or any combination thereof.
The various illustrative logical blocks, modules, circuits, and algorithm steps described in connection with the implementations disclosed herein may be implemented as electronic hardware, computer software, or combinations of both. To clearly illustrate this interchangeability of hardware and software, various illustrative components, blocks, modules, circuits, and steps have been described above generally in terms of their functionality. Whether such functionality is implemented as hardware or software depends upon the particular application and design constraints imposed on the overall system. The described functionality may be implemented in varying ways for each particular application, but such implementation decisions should not be interpreted as causing a departure from the scope of the implementations.
The various illustrative blocks, modules, and circuits described in connection with the implementations disclosed herein may be implemented or performed with a general purpose processor, a Digital Signal Processor (DSP), an Application Specific Integrated Circuit (ASIC), a Field Programmable Gate Array (FPGA) or other programmable logic device, discrete gate or transistor logic, discrete hardware components, or any combination thereof designed to perform the functions described herein. A processor may be a microprocessor, but in the alternative, the processor may be any conventional processor, controller, microcontroller, or state machine. A processor may also be implemented as a combination of computing devices, e.g., a combination of a DSP and a microprocessor, a plurality of microprocessors, one or more microprocessors in conjunction with a DSP core, or any other such configuration.
The steps of a method or algorithm and functions described in connection with the implementations disclosed herein may be embodied directly in hardware, in a software module executed by a processor, or in a combination of the two. If implemented in software, the functions may be stored on or transmitted as one or more instructions or code on a tangible, non-transitory, computer-readable medium. A software module may reside in Random Access Memory (RAM), flash memory, Read Only Memory (ROM), Electrically Programmable ROM (EPROM), Electrically Erasable Programmable ROM (EEPROM), registers, hard disk, a removable disk, a CD ROM, or any other form of storage medium known in the art. A storage medium is coupled to the processor such that the processor can read information from, and write information to, the storage medium. In the alternative, the storage medium may be integral to the processor. Disk and disc, as used herein, includes compact disc (CD), laser disc, optical disc, digital versatile disc (DVD), floppy disk and Blu-ray disc where disks usually reproduce data magnetically, while discs reproduce data optically with lasers. Combinations of the above should also be included within the scope of computer readable media. The processor and the storage medium may reside in an ASIC.
For purposes of summarizing the disclosure, certain aspects, advantages and novel features have been described herein. It is to be understood that not necessarily all such advantages may be achieved in accordance with any particular implementation. Thus, one or more implementations achieves or optimizes one advantage or group of advantages as taught herein without necessarily achieving other advantages as may be taught or suggested herein.
Various modifications of the above described implementations will be readily apparent, and the generic principles defined herein may be applied to other implementations without departing from the spirit or scope of the application. Thus, the present application is not intended to be limited to the implementations shown herein but is to be accorded the widest scope consistent with the principles and novel features disclosed herein.
This application claims the benefit of U.S. Provisional Application No. 62/305,411, filed Mar. 8, 2016, and U.S. Provisional Application No. 62/343,736, filed May 31, 2016, both of which are hereby incorporated by reference under 37 CFR 1.57.
Number | Date | Country | |
---|---|---|---|
62305411 | Mar 2016 | US | |
62343736 | May 2016 | US |