EP3329380A1 - Systems and methods for interfacing a sensor and a processor - Google Patents
Systems and methods for interfacing a sensor and a processorInfo
- Publication number
- EP3329380A1 EP3329380A1 EP16748235.5A EP16748235A EP3329380A1 EP 3329380 A1 EP3329380 A1 EP 3329380A1 EP 16748235 A EP16748235 A EP 16748235A EP 3329380 A1 EP3329380 A1 EP 3329380A1
- Authority
- EP
- European Patent Office
- Prior art keywords
- data
- sensor
- data source
- processor
- source portion
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Granted
Links
- 238000000034 method Methods 0.000 title claims abstract description 53
- 238000004891 communication Methods 0.000 claims abstract description 41
- 230000001419 dependent effect Effects 0.000 claims abstract description 23
- 239000000872 buffer Substances 0.000 claims description 29
- 230000033001 locomotion Effects 0.000 claims description 19
- 238000012545 processing Methods 0.000 claims description 19
- 230000008569 process Effects 0.000 claims description 16
- 230000004927 fusion Effects 0.000 claims description 10
- 230000008878 coupling Effects 0.000 claims description 6
- 238000010168 coupling process Methods 0.000 claims description 6
- 238000005859 coupling reaction Methods 0.000 claims description 6
- 230000003213 activating effect Effects 0.000 claims 2
- 230000015654 memory Effects 0.000 description 33
- 230000006870 function Effects 0.000 description 20
- 239000000758 substrate Substances 0.000 description 17
- 238000013461 design Methods 0.000 description 10
- 230000000694 effects Effects 0.000 description 5
- 230000001133 acceleration Effects 0.000 description 4
- 238000001514 detection method Methods 0.000 description 4
- 239000000463 material Substances 0.000 description 4
- 238000005259 measurement Methods 0.000 description 4
- 238000012546 transfer Methods 0.000 description 4
- 238000010586 diagram Methods 0.000 description 3
- 238000005516 engineering process Methods 0.000 description 3
- 230000003287 optical effect Effects 0.000 description 3
- 239000004065 semiconductor Substances 0.000 description 3
- 238000013519 translation Methods 0.000 description 3
- XUIMIQQOPSSXEZ-UHFFFAOYSA-N Silicon Chemical compound [Si] XUIMIQQOPSSXEZ-UHFFFAOYSA-N 0.000 description 2
- 230000005540 biological transmission Effects 0.000 description 2
- 238000004590 computer program Methods 0.000 description 2
- 230000003111 delayed effect Effects 0.000 description 2
- 230000007613 environmental effect Effects 0.000 description 2
- 230000010354 integration Effects 0.000 description 2
- 238000004519 manufacturing process Methods 0.000 description 2
- 238000012986 modification Methods 0.000 description 2
- 230000004048 modification Effects 0.000 description 2
- 238000012544 monitoring process Methods 0.000 description 2
- 230000002093 peripheral effect Effects 0.000 description 2
- 230000004044 response Effects 0.000 description 2
- 229910052710 silicon Inorganic materials 0.000 description 2
- 239000010703 silicon Substances 0.000 description 2
- 238000012935 Averaging Methods 0.000 description 1
- 230000003321 amplification Effects 0.000 description 1
- 238000013459 approach Methods 0.000 description 1
- 238000003491 array Methods 0.000 description 1
- 230000003190 augmentative effect Effects 0.000 description 1
- 230000008901 benefit Effects 0.000 description 1
- 230000001413 cellular effect Effects 0.000 description 1
- 238000013480 data collection Methods 0.000 description 1
- 238000013500 data storage Methods 0.000 description 1
- 239000011521 glass Substances 0.000 description 1
- 230000005484 gravity Effects 0.000 description 1
- 238000010348 incorporation Methods 0.000 description 1
- 239000002184 metal Substances 0.000 description 1
- 238000003199 nucleic acid amplification method Methods 0.000 description 1
- 239000005022 packaging material Substances 0.000 description 1
- 230000003071 parasitic effect Effects 0.000 description 1
- 230000008672 reprogramming Effects 0.000 description 1
- 230000006641 stabilisation Effects 0.000 description 1
- 238000011105 stabilization Methods 0.000 description 1
- 239000000126 substance Substances 0.000 description 1
- 230000001360 synchronised effect Effects 0.000 description 1
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/30—Arrangements for executing machine instructions, e.g. instruction decode
- G06F9/30003—Arrangements for executing specific machine instructions
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F13/00—Interconnection of, or transfer of information or other signals between, memories, input/output devices or central processing units
- G06F13/10—Program control for peripheral devices
- G06F13/102—Program control for peripheral devices where the programme performs an interfacing function, e.g. device driver
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F13/00—Interconnection of, or transfer of information or other signals between, memories, input/output devices or central processing units
- G06F13/38—Information transfer, e.g. on bus
- G06F13/382—Information transfer, e.g. on bus using universal interface adapter
- G06F13/385—Information transfer, e.g. on bus using universal interface adapter for adaptation of a particular data processing system to different peripheral devices
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/30—Arrangements for executing machine instructions, e.g. instruction decode
- G06F9/3017—Runtime instruction translation, e.g. macros
Definitions
- This disclosure generally relates to techniques for providing communications between a sensor and a processor and more specifically to providing an interface for relaying commands and/or data.
- the sensor may provide a measurement of the condition(s).
- an application processor In order to make use of the sensor measurements, an application processor must be able to communicate with the sensors of the portable device in order to send commands, such as for configuring the sensor, causing it to generate data or otherwise controlling it, as well as to receive data from the sensor in a useful format.
- aspects of the communication are typically specific to the particular design of the sensor being used which may vary considerably from vendor to vendor, or even within different versions of sensors provided by a single vendor.
- the application processor must have an awareness of the design of the sensor in order to communicate with it at the hardware level. As will be appreciated, this leads to complications in order to allow the application processor to accommodate different sensor designs. For example, it may be necessary to program the application processor with information covering all the potential sensor designs that may be encountered, increasing the cost and difficulty of implementation. Further, this approach may also require reprogramming the application processor when new sensor designs become available.
- HAL Hardware Abstraction Layer
- this disclosure includes a device employing a sensor system, which may have a data sink portion including a data sink processor, a data source portion including a data source processor to receive output from at least one sensor, an interface coupling the data sink portion and the data source portion and a hardware abstraction layer implemented by at least one interface manager to provide an abstraction of the data source portion by translating data sink processor communications from a hardware- independent format to a hardware-dependent format and by translating data source portion communications from a hardware-dependent format to a hardware-independent format.
- This disclosure also includes a method for communicating sensor information by providing a data sink portion including a data sink processor, providing a data source portion including a data source processor, receiving output from at least one sensor with the data source processor, coupling the data sink portion and the data source portion with an interface and abstracting the data source portion by translating data sink processor communications from a hardware-independent format to a hardware-dependent format and by translating data source portion communications from a hardware-dependent format to a hardware-independent format.
- FIG. 1 is a schematic diagram of communications between a data sink portion and a data source portion according to an embodiment.
- FIG. 2 is a schematic diagram of a device employing a hardware abstraction layer according to an embodiment.
- FIG. 3 is a flowchart showing a routine for requesting sensor data according to an embodiment.
- FIG. 4 is a flowchart showing a routine for supplying sensor data according to an embodiment.
- Embodiments described herein may be discussed in the general context of processor-executable instructions residing on some form of non-transitory processor- readable medium, such as program modules, executed by one or more computers or other devices.
- program modules include routines, programs, objects, components, data structures, etc., that perform particular tasks or implement particular abstract data types.
- the functionality of the program modules may be combined or distributed as desired in various embodiments.
- a single block may be described as performing a function or functions; however, in actual practice, the function or functions performed by that block may be performed in a single component or across multiple components, and/or may be performed using hardware, using software, or using a combination 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. Skilled artisans may implement the described functionality in varying ways for each particular application, but such implementation decisions should not be interpreted as causing a departure from the scope of the present disclosure.
- the exemplary wireless communications devices may include components other than those shown, including well-known components such as a processor, memory and the like.
- the techniques may be realized at least in part by a non-transitory processor-readable storage medium comprising instructions that, when executed, performs one or more of the methods described above.
- the non- transitory processor-readable data storage medium may form part of a computer program product, which may include packaging materials.
- the non-transitory processor-readable storage medium may comprise random access memory (RAM) such as synchronous dynamic random access memory (SDRAM), read only memory (ROM), non-volatile random access memory (NVRAM), electrically erasable programmable read-only memory (EEPROM), FLASH memory, other known storage media, and the like.
- RAM synchronous dynamic random access memory
- ROM read only memory
- NVRAM non-volatile random access memory
- EEPROM electrically erasable programmable read-only memory
- FLASH memory other known storage media, and the like.
- the techniques additionally, or alternatively, may be realized at least in part by a processor-readable communication medium that carries or
- a carrier wave may be employed to carry computer-readable electronic data such as those used in transmitting and receiving electronic mail or in accessing a network such as the Internet or a local area network (LAN).
- LAN local area network
- processors such as one or more motion processing units (MPUs), digital signal processors (DSPs), general purpose microprocessors, application specific integrated circuits (ASICs), application specific instruction set processors (ASIPs), field programmable gate arrays (FPGAs), or other equivalent integrated or discrete logic circuitry.
- MPUs motion processing units
- DSPs digital signal processors
- ASIPs application specific instruction set processors
- FPGAs field programmable gate arrays
- processor may refer to any of the foregoing structure or any other structure suitable for implementation of the techniques described herein.
- functionality described herein may be provided within dedicated software modules or hardware modules configured as described herein.
- the techniques could be fully implemented in one or more circuits or logic elements.
- a general purpose 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 an MPU and a microprocessor, a plurality of microprocessors, one or more microprocessors in conjunction with an MPU core, or any other such configuration.
- the techniques of this disclosure are directed to providing an interface between the application processor and one or more sensors by translating functions originating with the application processor from a hardware-independent format to a hardware-dependent format and by translating functions originating with the sensor from a hardware-dependent format to a hardware-independent format.
- this allows the application processor to communicate by means of high level functions with logical descriptions that are not dependent on the specific design of the sensor.
- the term application processor is used to indicate any processor that runs the application requesting the data or does any data processing of data intended for the application.
- the application processor may be, for example, the main processor of the host device, or a dedicated processor for the application(s).
- FIG. 1 schematically illustrates the flow of information involved in communications between an application processor and a sensor according to one embodiment of the disclosure. As shown, the communication may be conceptualized as occurring between a data sink portion 100 that ultimately uses the data provided by a data source 102 portion.
- an application layer 104 At the top of data sink portion 100 is an application layer 104, that may include one or more application processors configured to execute programs stored in memory.
- Application layer 104 provides the functionality of the device that is experienced by the user, typically in the form of programs (i.e., applications) that employ the sensor data.
- an operating system framework layer 106 manages the hardware and software resources of the portable device to create an environment in which programs at the application layer 104 may be run.
- a sensor service layer 108 may provide specific instances for each sensor being used by the higher layers.
- the term sensor may be used for hardware sensors or software sensors.
- a hardware sensor refers to an actual physical sensor, such as for example an accelerometer that measures the acceleration of the device.
- An example of a software sensor is an orientation sensor which determined the orientation of the device. Any software sensor is based on data from a hardware sensor, in this case the motion sensors used to determine the orientation.
- the term sensor refers to a hardware sensor, by the data from these sensors may be converted into a software sensor at any level.
- the data source portion 102 may include a sensor layer 110 featuring one or more sensors. Communications between data sink portion 100 and data source portion 102 are provided through a HAL layer 112. As will be described some or all aspects of HAL layer 112 may be implemented in data sink portion 100, in data source portion 102 or in both.
- a request may originate at application layer 104 and be passed to OS framework layer 106, which is then transferred to sensor service layer 108.
- OS framework layer 106 which is then transferred to sensor service layer 108.
- these hardware-independent commands are delivered to HAL layer 112 for translation to a hardware-dependent format and delivered to sensor layer 110.
- the request originating with application layer 104 may be translated by HAL layer 112 to configure the sensor at sensor layer 110 to produce the data requested by the application.
- data output at sensor layer 110 flows to HAL layer 112, where a translation may be performed from a hardware-dependent format to a hardware- independent format if required.
- the translated data may then be passed in sequence from sensor service layer 108 to OS framework layer 106 and finally to application layer 104.
- the commands flowing down, and the data flowing back up in FIG. 2 may contain different types of information.
- a command may be that the application layer 104 would like to know which sensors are present or supported in the data source 102. In this case, the data would contain a list of these sensors. Therefore, the term 'data' does not refer only to pure sensor data, but to all information flowing back up from the data source 102.
- the term 'command' may refer to all information flowing down from the data sink 100.
- the data sink 100 may want to load a certain program or algorithm into the data source 102. In this case, the program or algorithm code may be considered the 'command'.
- device 200 may be implemented as a device or apparatus, such as a handheld device that can be moved in space by a user and its motion, location and/or orientation in space therefore sensed.
- such a handheld device may be a mobile phone (e.g., cellular phone, a phone running on a local network, or any other telephone handset), tablet, personal digital assistant (PDA), video game player, video game controller, navigation device, wearable device (e.g., glasses, watch, belt clip), fitness tracker, virtual or augmented reality equipment, mobile internet device (MID), personal navigation device (P D), digital still camera, digital video camera, binoculars, telephoto lens, portable music, video or media player, remote control, or other handheld device, or a combination of one or more of these devices.
- PDA personal digital assistant
- video game player e.g., glasses, watch, belt clip
- navigation device e.g., glasses, watch, belt clip
- wearable device e.g., glasses, watch, belt clip
- fitness tracker e.g., virtual or augmented reality equipment
- MID mobile internet device
- P D personal navigation device
- digital still camera digital video camera
- binoculars telephoto lens
- device 200 has a data sink portion 202 and a data source portion 204 as described above. Although one data source portion 204 is depicted, any suitable number of data source portions may be provided depending on the capabilities and sensors of device 200. The different data source portions or modules can be connected in parallel to the data sink portion, and each data source portion may be specialized in a certain group of sensors, for example motion, video, or audio sensors.
- data sink portion 202 may include application processor block 206, which may represent one or more
- microprocessors central processing units (CPUs), or other processors to run software programs, which may be stored in memory 208, associated with the functions of device 200.
- application processor 206 may execute a program that employs data from one or more sensors of device 200.
- Multiple layers of software can be provided in memory 208, which may be any combination of computer readable medium such as electronic memory or other storage medium such as hard disk, optical disk, etc., for use with application processor 206.
- an operating system layer can be provided as described above for device 200 to control and manage system resources in real time, enable functions of application software and other layers, and interface application programs with other software and functions of device 200.
- data sink portion 202 may also include data sink processor block 210 representing processing being performed to generate commands corresponding to requests for sensor data from application processor 206, to pass received sensor data to application processor 206 and/or to perform any other operations associated with the HAL.
- data sink processor 210 may implement a sensor service layer.
- Data sink processor 210 may be separate from application processor 206 or may be the same processor, which may or may not be dedicated for these specific functions.
- the data sink processor 210 maybe a processor, such as a MCU, designed to offload some tasks from the main or application processor, so as to e.g. keep this processor asleep during some tasks.
- aspects implemented in software may include but are not limited to, application software, firmware, resident software, microcode, etc., and may take the form of a computer program product accessible from a computer-usable or computer-readable medium providing program code for use by or in connection with a computer or any instruction execution system, such as application processor 206, data sink processor 210, another dedicated processor or any other processing resources of device 200.
- Data sink portion 202 may be coupled to data source portion 204 through interface 214, which may be any suitable bus or interface, such as a peripheral component interconnect express (PCIe) bus, a universal serial bus (USB), a universal asynchronous receiver/transmitter (UART) serial bus, a suitable advanced microcontroller bus architecture (AMBA) interface, an Inter-Integrated Circuit (I2C) bus, a serial digital input output (SDIO) bus, a serial peripheral interface (SPI), interrupt line, dedicated data line, or other equivalent.
- PCIe peripheral component interconnect express
- USB universal serial bus
- UART universal asynchronous receiver/transmitter
- AMBA advanced microcontroller bus architecture
- I2C Inter-Integrated Circuit
- SDIO serial digital input output
- SPI serial peripheral interface
- interrupt line dedicated data line, or other equivalent.
- interface 214 may also be used to couple other components of device 200, such as application processor 206, memory 208 and others, or another dedicated bus may be employed.
- Data source portion 204 may include one or more sensors 216, or may otherwise be in communication with such sensors, data source processor 218 and memory 220.
- Memory 220 may store algorithms, routines or other instructions for processing data output by sensor 216 and/or other sensors as described below using logic or controllers of sensor processor 218, as well as storing raw data output by sensor 216 or other sensors.
- Data source processor 218 may be configured to execute commands from data sink portion 202 regarding requests for sensor data and correspondingly to provide the requested data. Accordingly, data source processor 218 may have one or more buffers, such as command first in first out (FIFO) buffer 222 and data FIFO buffer 224. Any suitable buffer architecture and queueing strategy may be employed.
- Data source portion 204 may be implemented as an integrated chip or as any number of separate components.
- the data sink portion 202 may also have one or more buffers as desired, such as a command FIFO (not shown in FIG. 2) to which commands are written that have to be transferred to the data source portion 204.
- data source portion 204 has a data source interface manager 226 configured to put commands and data being exchanged with data sink portion 202 in the correct format and to control the communication and transfer of data between the respective portions.
- Data source interface manager 226 may be incorporated in separate processors or chips, or may be part of any of the other components or processors.
- data source interface manager 226 may be implemented as software instructions stored in memory 220 and executed by data source processor 218.
- any suitable combination of processing and memory resources may be employed by data source interface manager 226, which may be any combination of hardware, software and firmware.
- the library of information used by data sink processor 210 and data sink interface manager 212 to understand the command and control any data source portions being employed may be stored using any suitable memory resources, such as memory 208.
- An interpreter or decoder may be used to convert the commands and information. This may be the general purpose or main/application memory, or may be a dedicated memory.
- data sink processor 210 and data sink interface manager 212 may be implemented as separate processors, and each processor may include a corresponding dedicated memory for this purpose if desired.
- data sink portion 202 may comprise any number of physical processors, from one to several, corresponding to application processor 206, data sink processor 210 and data sink interface manager 212. These may, or may not, be in a single chip or package. In one aspect, data sink processor 210 and data sink interface manager 212 may be combined into a single processor, which communicates with application processor 206. Alternatively, data sink processor 210 and data sink interface manager 212 may also be part of application processor 206, or any other processor in communication with the application processor. Application processor 206 may transfer any combination of physical processors, from one to several, corresponding to application processor 206, data sink processor 210 and data sink interface manager 212. These may, or may not, be in a single chip or package. In one aspect, data sink processor 210 and data sink interface manager 212 may be combined into a single processor, which communicates with application processor 206. Alternatively, data sink processor 210 and data sink interface manager 212 may also be part of application processor 206, or any other processor in communication with the application processor. Application processor
- Data sink processor 210 requests/commands related to sensor data to be used by a running application to data sink processor 210. Once data sink processor 210 has received the commands, the processing resources associated with this block may handle all the required actions, even if the command is complex and requires a plurality of actions, thus unloading such tasks from application processor 206. Data sink processor 210 then communicates with data source portion 204 through interface 214 and one or both of data sink interface manager 212 and data source interface manager 226. As shown, the HAL may include data sink interface manager 212 and data source interface manager 226, along with interface 214 in one embodiment. Any suitable division of functionality may be employed by the two interface managers. Alternatively, the functions of the interface managers may be provided by a single interface manager implemented either on the data sink side of interface 214 or the data source side.
- data sink interface manager 212 may be able to perform some high level operations associated with the data source portion(s). For example, data sink interface manager 212 may be able to stop and start (activate/deactivate) a data source portion. Data sink interface manager 212 may also be able to reset/initialize a module or control the power mode of a data module, e.g. setting the module in a low-power mode. To perform these functions, data sink interface manager 212 has access to the register addresses of the data source portions, such as the FIFO and/or other memory addresses of data source portion 204, so it can route sensor commands to the correct destination, such as command FIFO 222.
- data interface manager 212 may also know the pipe address of the data source portions(s) so as to use the correct communication channel. This aspect facilitates operations when more than one data source portion 204 is employed in parallel. For example, there may be a data source portion related to motion sensors, another related to image sensors, yet another related to environmental sensors and so on. By using the appropriate pipe address of the different data source portions, the interface manager may control the correct portion.
- data sink interface manager 212 supports a modular design, where a plurality of data source portions may be addressed and controlled in parallel, with data sink interface manager 212.
- data sink interface manager 212 may have access to the registry, FIFO addresses and other hardware- dependent parameters of the data source portions. When a new data source portion is to be accommodated, data sink interface manager 212 may be updated with the appropriate information if new hardware addresses are involved.
- data source interface manager 226 may be responsible for reception of commands issued by data sink processor 210 and placing them in the correct register, FIFO, or memory addresses, such as command FIFO 222. Further, data source interface manager 226 may perform an error check on the incoming command, or may check if the commands are known to the data source portion 204. In case of unknown commands, data source interface manager 226 may return a 'not acknowledged' message or otherwise indicate an error.
- Data source processor 218 may read any pending commands from command FIFO 222, and may be configured to complete each command before processing the next. Using this architecture, data sink portion 202 may queue a plurality of commands in command FIFO 222, allowing one or more aspects of data sink portion 202 to operate in a power saving mode while data source processor 218 executes the commands. Data source processor 218 reads the commands from command FIFO 222 and converts them to the necessary functions and steps indicated by the commands. Data source processor 218 may have all the information required, such as register and memory addresses and the like, to control the sensor or sensors in data source portion 204. This library of information may be stored in memory 220, which may be dedicated to this function or may be general purpose.
- sensor data output by sensor 216 may be put in one or more data FIFOs 224 in data source portion 204.
- an interrupt may be sent to data sink portion 202 indicated the data is ready for retrieval. This interrupt may be transmitted through interface 214 or may be a dedicated line.
- the data flows back to data sink portion 202 through interface 214, and one or both of data sink interface manager 212 and data source interface manager 226, depending on the architecture, and may be written to dedicated or general purpose memory resources, such as memory 208.
- the interrupt may be a 'wake-up' interrupt or a 'non-wake-up' interrupt.
- the wake-up interrupt means that as soon as the data is ready, the application processor, or any other processor that will receive the data, is woken up to indicate that the data is ready. This process may be referred to as a tightly coupled system or loop because the process that requested the data will retrieve the data and use it as soon as the data becomes available.
- the non-wake-up interrupt may be used for data that is less urgent. In this case, the interrupt is send when the data is ready, but if the processor is asleep it is not woken up.
- the processor will retrieve the data once it wakes up, may be due to some other process causing the wake up. This process may be referred to as a loosely coupled system or loop because the process that requested the data may not retrieve the data immediately, but at a later time at the convenience of the processor.
- Sensor 216 may be one or more components capable of measuring or detecting motion or orientation of device 200 or any environmental condition surrounding device 200.
- Data source portion 204 may implement one or any desired number of sensors and a plurality of data source portions may operate in parallel. Further, each sensor may directly output measurements that are sent to data sink portion 202 or data source processor 218 may implement a virtual sensor that generates a signal derived from one or more other sensors. For example, rotational motion sensors, such as gyroscopes, may measure angular velocity along one or more orthogonal axes and linear motion sensors, such as
- accelerometers may measure linear acceleration along one or more orthogonal axes and a sensor fusion operation may be performed to combine the data and provide a motion determination.
- a sensor fusion operation may be performed to combine the data and provide a motion determination.
- data from an air pressure sensor indicating altitude and/or data from a magnetometer indicated heading may be fused with the motion determination.
- sensor 216 may include any of an accelerometer, a temperature sensor, a gravity sensor, a gyroscope, an ambient light sensor, a linear acceleration sensor, a magnetometer, an orientation sensor, a pressure sensor, a proximity sensor, a hygrometer, a rotation vector sensor, an image sensor or an acoustic sensor.
- sensor 216 may be implemented using Micro Electro Mechanical System (MEMS) to be integrated with data source processor 218 to provide data source portion 204 in a single package.
- MEMS Micro Electro Mechanical System
- Exemplary details regarding suitable configurations of integrated sensors and processors may be found in co-pending, commonly owned U.S. Patent Application Serial Nos. 11/774,488, filed Jul. 6, 2007, and 12/106,921, filed April 21, 2008, which are hereby incorporated by reference in their entirety. Suitable implementations are available from InvenSense, Inc. of Sunnyvale, Calif.
- the type of processing performed by data source processor 218 may depend on the type of sensor data that is requested and/or the type of sensors available in data source portion 204.
- data sink processor 210 may issue a request for direct acceleration data at a certain rate
- sensor 216 may be an accelerometer, such that data source processor 218 sets the rate of the accelerometer output and places values output by sensor 216 in data FIFO 224.
- application processor 206 may need the orientation of device 200, and sensor 216 of data source portion 204 may include an accelerometer, a gyroscope, and/or a magnetometer.
- data source processor 218 may function as a sensor hub and collect the data from the different sensors and perform sensor fusion to implement a virtual orientation sensor that determines the orientation of device 200 and outputs the data to data FIFO 224.
- data source portion 204 may contain more than one data source processors that each control one or more sensors. These different processors may communicate in order to share data that may be required for some sort of data fusion in one of the processors. For example, one processor may control an accelerometer while another processor may control a gyroscope, with the sensor fusion using both sets of data being performed by one of the processors. Further, in some embodiments, sensor fusion may also require sensor data from a plurality of data source portions 204. As such, the respective interface managers may enable the communication between the different modules to exchange data and perform the sensor fusion in one of the data source processors.
- sensor fusion using data from different data source portions may be performed by data sink processor 210 or application processor 206.
- An example of this type of fusion may be a context determination to indicate how device 200 is currently being used with acoustic and motion sensors, with the acoustic and motion sensors in different data source portions.
- Different architectures may be employed to achieve desired performance characteristics.
- Application processor 206 and data sink processor 210 may provide more capabilities but represent a relatively greater expenditure of power, while data source processor 218 may have reduced computational resources but represent greater efficiency.
- the sensor system of device 200 may include one data sink portion 202 and one or more data source portions 204 as noted above. In another embodiment, the sensor system of device 200 may include more than one data sink portion 202 and only one data source portions 204. In this case, the data from sensor 216 is transferred to the plurality of data sink portions 202, where each data sink portion 202 may have its own data sink interface manager 212 to receive the data and its own data sink processor 210 to handle the data.
- An example of such a system may be a smartphone equipped with an Optical Image Stabilization (OIS) system.
- OIS Optical Image Stabilization
- the gyroscope sensor data is provided to a first data sink portion 202 represented by the OIS system which uses the gyroscope data to determine how to move the optical element to compensate for the movement of the device.
- a second data sink portion 202 may be represented by the operating system which may use the data for determining the motion, movement, or gestures of the phone.
- Another embodiment may be a distributed system or a system with more than one device, such that several data sink portions 202 may exist in different devices.
- the system may consist of a combination of a smart phone and a smart watch.
- Each may have a data sink portion, which may access its own data source portions as well as one or more data source portions of the other device.
- Data sink interface manager 214 may control communication with the data source portion in the other device, and may also communicate with the data sink portion of the other device, for example to coordinate tasks that may need sensor data from both devices, or simply to make the other data sink module aware of the processes.
- the communication between the devices may be done using any kind of wireless communication technique or protocol.
- the sensor data is put in data FIFO 224 and an interrupt is used to indicate availability of the data to data sink portion 202.
- an interrupt may be sent after each data sample.
- application processor 206 may request data samples for a certain amount of time and be notified when collection is complete.
- data source processor 218 may put all the data samples in data FIFO 224 and send an interrupt upon completion, allowing one or more processors or other resources of data sink portion 202 to operate in a power save mode while the collection is occurring.
- data source processor 218 may employ multiple output FIFOs to accommodate different classes of sensor data.
- device 200 may be configured to awaken application processor 206 upon detection of a predefined event, such as a shake of device 200.
- a predefined event such as a shake of device 200.
- dedicated FIFOs may be provided for data collection, event detection and/or other classes of sensor data. Accordingly, a shake event detection may be placed directly in a corresponding FIFO rather than behind other collected data so that an interrupt will be sent to data sink portion 202 without delay.
- the command and requested data may be attributed a certain level of priority.
- This priority may be attributed by any layer in the data sink 100, such as application layer 104, the operating system framework layer 106, or the sensor service layer 108.
- the priority may also be attributed by any part of the HAL layer 112, such as the data sink processor 210, the data source processor 218, the data sink interface manager 212, or the data source interface manager 226.
- the data source portion 204 may have a plurality of command FIFOs 222, each attributed to a certain priority to avoid that commands with a high priority are delayed behind command with a lower priority.
- a high priority command may be capable of interrupting a process started by a lower priority command, e.g.
- the data source portion 204 may also have a plurality of data FIFOs 224, each for storing data with a certain priority. This avoids data that has to be provided to the data sink portion 202 with a high priority to be stuck or delayed behind data with a lower priority.
- the commands and data with different priorities may be processed by different data source processors, each dedicated for a certain priority level. A low priority processor may process high priority data if no low priority data is requested (and vice versa).
- Communication involving data sink portion 202 and data source portion 204 may take place at a number of levels.
- communication within data sink portion 202 may include the exchange of information between application processor 206 and data sink processor 210, such as requests for sensor data from application processor 206 and delivery of sensor data by data sink processor 210. Suitable communications may include queries regarding what sensors/activities are supported, commands to activate or deactivate a certain sensor, requests to monitor activity at given intervals, directions to configure the sensor data rate, and other similar information.
- the exchange of information between application processor 206 and data sink processor 210 may represent high level commands or low level commands, such as data type, data rate, accuracy, and the like. As will be appreciated, the level of the command may dictate where the processing takes place.
- application processor 206 may request an activity update, such that data sink processor 210 or data source processor 218 performs the activity determination using data from sensor 216 and reports it, or may request motion sensor data, such that application processor 206 performs the routines to determine activity on its own.
- Communications may also occur between data sink portion 202 and data source portion 204.
- data sink processor 210 sends commands to the appropriate data source portion(s) 202, depending on the received request/command from application processor 206. While data sink processor 210 may be able to communicate using hardware-dependent parameters supplied by data sink interface manager 214 and/or data source interface manager 226 corresponding to existing data source portions or those added later, the hardware-dependent parameters are not required at the application or OS framework levels. For example, application processor 206 may send commands to activate a sensor and set an appropriate data output rate in a hardware-independent format while the HAL represented by data sink interface manager 214 and/or data source interface manager 226 may perform the translation to a hardware-dependent format.
- communications may also occur within data source portion 204, such as between data source processor 218 and sensor 216 depending on the request received from data sink processor 210. This communication is specific to sensor 216 and may only cover the appropriate sensor. At this level, the exact registry and memory addresses may be known to data source processor 218. Examples of such communications include commands to read a specific memory address corresponding to data FIFO 224 to access sensor data, to start sensor calibration and the like.
- each packet may include a logical destination field, a length field and a payload field.
- the logical destination may be used to indicate the location to which the packet is to be delivered, and may represent any of the described components of data sink portion 202 and data source portion 204.
- a packet may be addressed to a processor, such as application processor 206, data sink processor 210, or data source processor 218, a specific sensor, such as sensor 216, one of a plurality of data source portions 202, as well as other suitable locations.
- the use of a logical destination address allows use of interface 214 in the form of a bus that couples multiple components, so that packets received at destinations other than identified by the address may be ignored.
- the length field may be used to specify the total length of each packet, so that individual packets may be parsed correctly.
- the payload may include sensor data or one or more commands, which may be executed in order of receipt.
- the amount of sensor data included in each packet may vary as desired, depending on how the sensor data was requested by application processor 206 for example.
- data sink processor 210 may receive a data request from application processor 206 through a sensor service layer, and generate one or more packets with the corresponding commands.
- data source portion 204 may generate one or more packets with the sensor data.
- data sink processor 210 may then process and unpack the data for transfer to the sensor service layer, where it is made available to application processor.
- the packetizing at the data sink portion 202 and data source portion 204 may occur at different levels by different processors.
- any data generated by sensor 216 may be initially stored in data FIFO 224, and then packetized by data source processor 218 and/or data source interface manager 226 before transmission to the data sink portion 202.
- the data from sensor 216 may be packetized by the data source processor 218 before storing it in the data FIFO 224 as packet(s).
- the sensor data may be in package format or not. This applies also to the commands in the command FIFO 222 which may be in packet format or not.
- application processor 206 may request a particular type of data, and may further specify characteristics of the requested data, such as a particular data rate. For example, accelerometer data may be requested at a 50 Hz rate.
- the sensor service layer provides this request to data sink processor 210, which processes the request in 302. This may include generating one or more command packets as described above.
- Data sink processor 210 such as through data sink interface manager 212, may also include hardware-dependent parameters to translate the request from a hardware-independent format to a hardware- dependent format, thereby implementing the HAL. This may include determining the appropriate pipe, register, memory, FIFO or other addresses.
- Data sink interface manager 212 may then transmit the packet(s) to any data source portions(s) 204 present in device 200 over interface 214 in 304.
- data source processor 218 may process the request in 306.
- data sink interface manager 212 and/or data source interface manager 226 may queue the packets in data FIFO 222 corresponding to the appropriate data source processor 218.
- Data source processor 218 may execute the request by communicating with sensor 216 in 308. In this example, this may include setting the appropriate data rate as well as directing sensor 216 to begin outputting data to data FIFO 224.
- sensor 216 may output data to data FIFO 222.
- data source processor 218 may send an interrupt to data sink portion 202 when the sensor data is ready for retrieval.
- data source interface manager 226 may put the sensor data in a data packet addressed to data sink processor 212.
- data sink processor 212 unpacks the payload of each packet, which is supplied to the sensor service layer in 406 for use by application processor in 408.
- data source processor 218 and sensor(s) 216 may be integrated as a single chip or package. Any associated FIFOs and memory may also be integrated into the same chip or package. In such implementations, the chip or package may be provided with all the required information and knowledge to perform its designed functions representing a 'plug and play' solution. In other embodiments, the sensor may not be integrated with data source processor 218 and control of the sensor may be performed at a higher level. Any hardware-dependent parameters, such as register, FIFO, or other memory addresses, may be provided by one or both of data sink interface manager 214 and data source interface manager 226, depending on the embodiment. The information may also be provided as a driver used by data sink processor 210 to allow communication with sensor 216 using low level commands.
- any functionality missing in the data source portion 204 to control sensor 16 may be moved to the data sink portion 202, for example in the data sink processor 210 or the data sink interface manager 212.
- Such embodiments may be used to accommodate older sensor designs to provide backward compatibility.
- a chip is defined to include at least one substrate typically formed from a semiconductor material.
- a single chip may be formed from multiple substrates, where the substrates are mechanically bonded to preserve the functionality.
- a multiple chip includes at least two substrates, wherein the two substrates are electrically connected, but do not require mechanical bonding.
- a package provides electrical connection between the bond pads on the chip to a metal lead that can be soldered to a PCB.
- a package typically comprises a substrate and a cover.
- Integrated Circuit (IC) substrate may refer to a silicon substrate with electrical circuits, typically CMOS circuits.
- MEMS cap provides mechanical support for the MEMS structure. The MEMS structural layer is attached to the MEMS cap. The MEMS cap is also referred to as handle substrate or handle wafer.
- an MPU may incorporate the sensor.
- the sensor or sensors may be formed on a first substrate.
- Other embodiments may include solid-state sensors or any other type of sensors.
- the electronic circuits in the MPU receive measurement outputs from the one or more sensors.
- the electronic circuits process the sensor data.
- the electronic circuits may be implemented on a second silicon substrate.
- the first substrate may be vertically stacked, attached and electrically connected to the second substrate in a single semiconductor chip, while in other embodiments the first substrate may be disposed laterally and electrically connected to the second substrate in a single semiconductor package.
- the first substrate may be attached to the second substrate through wafer bonding, as described in commonly owned U.S. Patent No. 7, 104,129, which is incorporated herein by reference in its entirety, to simultaneously provide electrical connections and hermetically seal the MEMS devices.
- This fabrication technique advantageously enables technology that allows for the design and manufacture of high performance, multi-axis, inertial sensors in a very small and economical package.
- Integration at the wafer-level minimizes parasitic capacitances, allowing for improved signal-to-noise relative to a discrete solution.
- Such integration at the wafer-level also enables the incorporation of a rich feature set which minimizes the need for external amplification.
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Software Systems (AREA)
- Arrangements For Transmission Of Measured Signals (AREA)
Abstract
Description
Claims
Applications Claiming Priority (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US14/809,748 US10191738B1 (en) | 2015-07-27 | 2015-07-27 | Systems and methods for interfacing a sensor and a processor |
PCT/US2016/044192 WO2017019734A1 (en) | 2015-07-27 | 2016-07-27 | Systems and methods for interfacing a sensor and a processor |
Publications (2)
Publication Number | Publication Date |
---|---|
EP3329380A1 true EP3329380A1 (en) | 2018-06-06 |
EP3329380B1 EP3329380B1 (en) | 2021-12-08 |
Family
ID=56611610
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
EP16748235.5A Active EP3329380B1 (en) | 2015-07-27 | 2016-07-27 | Systems and methods for interfacing a sensor and a processor |
Country Status (4)
Country | Link |
---|---|
US (3) | US10191738B1 (en) |
EP (1) | EP3329380B1 (en) |
CN (1) | CN108027793B (en) |
WO (1) | WO2017019734A1 (en) |
Families Citing this family (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN107992197A (en) * | 2017-12-12 | 2018-05-04 | 上海闻泰电子科技有限公司 | Virtual reality device and system |
KR102586073B1 (en) * | 2019-04-19 | 2023-10-05 | 삼성전기주식회사 | Ois device and communication method thereof with improved spi communication efficiency |
US12102590B2 (en) | 2020-03-30 | 2024-10-01 | Zoll Medical Corporation | Medical device system and hardware for sensor data acquisition |
US11789110B2 (en) | 2020-09-03 | 2023-10-17 | Honeywell International Inc. | Fault detection, exclusion, isolation, and re-configuration of navigation sensors using an abstraction layer |
Family Cites Families (22)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US6345375B1 (en) * | 1999-02-24 | 2002-02-05 | California Amplifier, Inc. | Packet-based communication methods and systems having improved data throughput |
GB9930849D0 (en) * | 1999-12-24 | 2000-02-16 | Koninkl Philips Electronics Nv | Data communications |
US20030120841A1 (en) * | 2001-12-21 | 2003-06-26 | Chang Matthew C.T. | System and method of data logging |
US7630336B2 (en) * | 2004-10-27 | 2009-12-08 | Honeywell International Inc. | Event-based formalism for data management in a wireless sensor network |
US7549154B2 (en) * | 2004-11-23 | 2009-06-16 | Microsoft Corporation | Extensible architecture for auxiliary displays |
US7729887B2 (en) * | 2006-04-11 | 2010-06-01 | Invensys Systems, Inc. | System management user interface providing user access to status information for process control system equipment including a status monitor |
US8700823B2 (en) * | 2007-03-15 | 2014-04-15 | Broadcom Corporation | Software driver interconnect framework |
US20090019429A1 (en) * | 2007-07-14 | 2009-01-15 | Andreas Randow | Virtualization of data source components in subject-oriented graphical programming environments for test and measurement applications |
US7844724B2 (en) * | 2007-10-24 | 2010-11-30 | Social Communications Company | Automated real-time data stream switching in a shared virtual area communication environment |
EP2079176B1 (en) * | 2008-01-11 | 2010-06-16 | Micronas GmbH | Communication device and method of data transfer |
CN100586768C (en) * | 2008-06-11 | 2010-02-03 | 武汉光庭汽车电子有限公司 | Hardware system structure of intellectualized full-graphics automobile instrument |
DE112010005747T5 (en) * | 2010-07-16 | 2013-07-04 | M.S. Ramaiah School Of Advanced Studies | Data interface circuit |
CN202676932U (en) * | 2012-07-17 | 2013-01-16 | 南京信息工程大学 | Multi-channel meteorological observation device |
US20140111670A1 (en) * | 2012-10-23 | 2014-04-24 | Nvidia Corporation | System and method for enhanced image capture |
US20140122143A1 (en) * | 2012-10-30 | 2014-05-01 | Trimble Navigation Limited | Optimizing resource assignment |
WO2014096395A1 (en) * | 2012-12-21 | 2014-06-26 | Hirschmann Automation And Control Gmbh | Method for redundantly and securely transferring data from a data source to a data sink |
US20140366024A1 (en) * | 2013-06-07 | 2014-12-11 | American Megatrends, Inc. | Methods, Devices and Computer Readable Storage Devices for Emulating a Light Sensor in a Guest Operating System from a Host Operating System |
BR112015032084A2 (en) * | 2013-06-27 | 2017-07-25 | Koninklijke Philips Nv | monitoring device having a sensor interface, and method for verifying compatibility of a sensor type |
CN103777997A (en) * | 2013-12-25 | 2014-05-07 | 中软信息系统工程有限公司 | JAVA virtual machine hardware independency platform based on MIPS and independency improvement method thereof |
CN103926004B (en) * | 2014-03-14 | 2017-02-15 | 国电南瑞科技股份有限公司 | Temperature detection method based on wireless sensor network |
CN104267956B (en) * | 2014-09-28 | 2016-05-11 | 深圳光启智能光子技术有限公司 | The method and apparatus of control hardware equipment in a kind of operating system |
CN104598253B (en) * | 2015-02-17 | 2016-10-19 | 武汉大学 | A kind of method realizing GNSS/INS integrated navigation at Android inner nuclear layer |
-
2015
- 2015-07-27 US US14/809,748 patent/US10191738B1/en active Active
-
2016
- 2016-07-27 WO PCT/US2016/044192 patent/WO2017019734A1/en unknown
- 2016-07-27 CN CN201680054711.4A patent/CN108027793B/en active Active
- 2016-07-27 EP EP16748235.5A patent/EP3329380B1/en active Active
-
2019
- 2019-01-25 US US16/258,218 patent/US10503501B2/en active Active
- 2019-12-09 US US16/708,298 patent/US10936310B2/en active Active
Also Published As
Publication number | Publication date |
---|---|
CN108027793B (en) | 2021-12-07 |
US10191738B1 (en) | 2019-01-29 |
EP3329380B1 (en) | 2021-12-08 |
US10936310B2 (en) | 2021-03-02 |
US20190196815A1 (en) | 2019-06-27 |
CN108027793A (en) | 2018-05-11 |
US20200225949A1 (en) | 2020-07-16 |
WO2017019734A1 (en) | 2017-02-02 |
US10503501B2 (en) | 2019-12-10 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US10936310B2 (en) | Systems and methods for interfacing a sensor and a processor | |
US10534014B2 (en) | System and method for drop detection | |
US20210014177A1 (en) | Deterministic packet scheduling and dma for time sensitive networking | |
US9628713B2 (en) | Systems and methods for optical image stabilization using a digital interface | |
US10072956B2 (en) | Systems and methods for detecting and handling a magnetic anomaly | |
US10921208B2 (en) | Systems and methods differential pressure sensing | |
US9086730B2 (en) | Selectable communication interface configurations for motion sensing device | |
KR101695712B1 (en) | Leveraging an enumeration and/or configuration mechanism of one interconnect protocol for a different interconnect protocol | |
CN107005242B (en) | System and method for MEMS sensor system synchronization | |
US20160084937A1 (en) | Systems and methods for determining position information using acoustic sensing | |
WO2020001564A1 (en) | Method, apparatus, and system for processing tasks | |
US20150286279A1 (en) | Systems and methods for guiding a user during calibration of a sensor | |
US10506163B2 (en) | Systems and methods for synchronizing sensor data | |
US10823555B2 (en) | Trajectory estimation system | |
WO2019205735A1 (en) | Data transmission method and apparatus, and display screen and display apparatus | |
US20170234756A1 (en) | Systems and methods for differential pressure sensor calibration | |
JP6250842B2 (en) | Sharing non-USB sensor with another device using USB over IP | |
CN107765922B (en) | Card screen detection and solution method, mobile terminal and computer readable storage medium | |
US20200348134A1 (en) | Method and system for sensor configuration | |
US9170964B2 (en) | USB device interrupt signal | |
US20160131484A1 (en) | System and method for device position classification | |
US20150362315A1 (en) | Systems and methods for determining position information using environmental sensing | |
US20150193232A1 (en) | Systems and methods for processing sensor data with a state machine | |
CN106406540B (en) | Gesture sensing device and virtual reality system | |
US9921335B1 (en) | Systems and methods for determining linear acceleration |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
STAA | Information on the status of an ep patent application or granted ep patent |
Free format text: STATUS: THE INTERNATIONAL PUBLICATION HAS BEEN MADE |
|
PUAI | Public reference made under article 153(3) epc to a published international application that has entered the european phase |
Free format text: ORIGINAL CODE: 0009012 |
|
STAA | Information on the status of an ep patent application or granted ep patent |
Free format text: STATUS: REQUEST FOR EXAMINATION WAS MADE |
|
17P | Request for examination filed |
Effective date: 20180223 |
|
AK | Designated contracting states |
Kind code of ref document: A1 Designated state(s): AL AT BE BG CH CY CZ DE DK EE ES FI FR GB GR HR HU IE IS IT LI LT LU LV MC MK MT NL NO PL PT RO RS SE SI SK SM TR |
|
AX | Request for extension of the european patent |
Extension state: BA ME |
|
DAV | Request for validation of the european patent (deleted) | ||
DAX | Request for extension of the european patent (deleted) | ||
STAA | Information on the status of an ep patent application or granted ep patent |
Free format text: STATUS: EXAMINATION IS IN PROGRESS |
|
17Q | First examination report despatched |
Effective date: 20200310 |
|
STAA | Information on the status of an ep patent application or granted ep patent |
Free format text: STATUS: EXAMINATION IS IN PROGRESS |
|
GRAP | Despatch of communication of intention to grant a patent |
Free format text: ORIGINAL CODE: EPIDOSNIGR1 |
|
STAA | Information on the status of an ep patent application or granted ep patent |
Free format text: STATUS: GRANT OF PATENT IS INTENDED |
|
INTG | Intention to grant announced |
Effective date: 20210714 |
|
GRAS | Grant fee paid |
Free format text: ORIGINAL CODE: EPIDOSNIGR3 |
|
GRAA | (expected) grant |
Free format text: ORIGINAL CODE: 0009210 |
|
STAA | Information on the status of an ep patent application or granted ep patent |
Free format text: STATUS: THE PATENT HAS BEEN GRANTED |
|
AK | Designated contracting states |
Kind code of ref document: B1 Designated state(s): AL AT BE BG CH CY CZ DE DK EE ES FI FR GB GR HR HU IE IS IT LI LT LU LV MC MK MT NL NO PL PT RO RS SE SI SK SM TR |
|
REG | Reference to a national code |
Ref country code: GB Ref legal event code: FG4D |
|
REG | Reference to a national code |
Ref country code: AT Ref legal event code: REF Ref document number: 1454298 Country of ref document: AT Kind code of ref document: T Effective date: 20211215 Ref country code: CH Ref legal event code: EP |
|
REG | Reference to a national code |
Ref country code: DE Ref legal event code: R096 Ref document number: 602016067130 Country of ref document: DE |
|
REG | Reference to a national code |
Ref country code: IE Ref legal event code: FG4D |
|
REG | Reference to a national code |
Ref country code: LT Ref legal event code: MG9D |
|
REG | Reference to a national code |
Ref country code: NL Ref legal event code: MP Effective date: 20211208 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: RS Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20211208 Ref country code: LT Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20211208 Ref country code: FI Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20211208 Ref country code: BG Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20220308 |
|
REG | Reference to a national code |
Ref country code: AT Ref legal event code: MK05 Ref document number: 1454298 Country of ref document: AT Kind code of ref document: T Effective date: 20211208 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: SE Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20211208 Ref country code: NO Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20220308 Ref country code: LV Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20211208 Ref country code: HR Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20211208 Ref country code: GR Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20220309 Ref country code: ES Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20211208 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: NL Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20211208 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: SM Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20211208 Ref country code: SK Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20211208 Ref country code: RO Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20211208 Ref country code: PT Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20220408 Ref country code: EE Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20211208 Ref country code: CZ Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20211208 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: PL Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20211208 Ref country code: AT Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20211208 |
|
REG | Reference to a national code |
Ref country code: DE Ref legal event code: R097 Ref document number: 602016067130 Country of ref document: DE |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: IS Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20220408 |
|
PLBE | No opposition filed within time limit |
Free format text: ORIGINAL CODE: 0009261 |
|
STAA | Information on the status of an ep patent application or granted ep patent |
Free format text: STATUS: NO OPPOSITION FILED WITHIN TIME LIMIT |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: DK Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20211208 Ref country code: AL Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20211208 |
|
26N | No opposition filed |
Effective date: 20220909 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: SI Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20211208 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: MC Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20211208 |
|
REG | Reference to a national code |
Ref country code: CH Ref legal event code: PL |
|
GBPC | Gb: european patent ceased through non-payment of renewal fee |
Effective date: 20220727 |
|
REG | Reference to a national code |
Ref country code: BE Ref legal event code: MM Effective date: 20220731 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: LU Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES Effective date: 20220727 Ref country code: LI Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES Effective date: 20220731 Ref country code: FR Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES Effective date: 20220731 Ref country code: CH Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES Effective date: 20220731 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: IT Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20211208 Ref country code: GB Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES Effective date: 20220727 Ref country code: BE Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES Effective date: 20220731 |
|
P01 | Opt-out of the competence of the unified patent court (upc) registered |
Effective date: 20230524 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: IE Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES Effective date: 20220727 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: HU Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT; INVALID AB INITIO Effective date: 20160727 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: MK Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20211208 Ref country code: CY Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20211208 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: MT Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20211208 |
|
PGFP | Annual fee paid to national office [announced via postgrant information from national office to epo] |
Ref country code: DE Payment date: 20240604 Year of fee payment: 9 |