This disclosure relates to a method and apparatus for controlling audio signal generation for prevention of motion sickness.
Motion sickness is caused by movement and its relationship to the inner ear and balance. Depending on the cause, it is typically referred to as car sickness, sea sickness, or air sickness. When travelling by car, drivers are less likely to be affected by motion sickness compared to passengers. Anyone can develop motion sickness, but people vary in their sensitivity to motion. Symptoms of motion sickness are: nausea, vomiting, dizziness, sweating, and a sense of feeling unwell. These symptoms arise from the inner ear due to changes in a person's sense of balance and equilibrium. Virtual Reality (VR) sickness occurs when exposure to a virtual environment causes symptoms similar to motion sickness symptoms. VR sickness is different from motion sickness in that it can be caused by the visually-induced perception of self-motion; real self-motion is not needed. This can be a problem in particular with any games which create a significant perceived mismatch between actual and virtual body position.
It is known that infrasonic sounds may have adverse effects such as nausea, dizziness and headaches. Other audio tones having certain frequencies which may be audible or inaudible and pulse rates may desensitize the Vestibular system providing a therapeutic effect which may alleviate or prevent motion sickness symptoms. An example of such a system is described in U.S. Pat. No. 6,228,021B1.
Various aspects of the disclosure are defined in the accompanying claims. In a first aspect there is provided an audio controller for generating a signal for alleviating motion sickness, the audio controller comprising: a sensor input module; a user control input; a processor comprising a machine learning model corresponding to a desired audio stimulation profile, the machine learning model being coupled to the sensor input module and the user control input and configured to receive a sensor signal comprising at least one user attribute and at least one context attribute from the sensor input module; a stimulus generator coupled to the machine learning model; and wherein the machine learning model is configured to control the stimulus generator to generate a reference signal for alleviating motion sickness, the reference signal being adapted dependent on at least one of the user control input, and the sensor signal.
In one or more embodiments, the machine learning model may comprise a neural network and the processor is configured to adapt the machine learning model by modifying the activation threshold of layers of the neural network dependent on the sensor signal.
In one or more embodiments, the machine learning model may comprise a first neural network configured to control the period between bursts of the audio stimulus, a second neural network configured to control the gain of the audio stimulus, and a third neural network configured to control the offset of the audio stimulus.
In one or more embodiments, the processor may be configured to compile additional training data dependent on the external user input and the sensor signal; to adapt the machine learning model in a training cycle using training data comprising the additional training data and to generate an audio stimulation profile comprising the adapted machine learning model.
In one or more embodiments, the audio controller may further comprise a memory coupled to the processor and configured to update the audio stimulation profiles in the memory with the adapted machine learning models.
In one or more embodiments, the audio controller may further comprise an audio input configured to receive an audio signal; a mixer coupled to the audio input and the stimulus generator output; wherein the processor comprises a further machine learning model corresponding to the desired audio stimulation profile coupled to the audio input and a filter.
The further machine learning model may be configured to control the filter to adapt the audio signal to at least attenuate infrasound signals dependent on at least one of an external user input and the sensor signal; and the mixer may be further configured to mix the adapted audio signal and the reference signal and to output the mixed adapted audio signal and the reference signal.
In one or more embodiments, the desired audio stimulation profile may be determined from at least one of a user control input and the sensor signal.
In one or more embodiments, the sensor input module may be configured to receive a video frame rate from a video device and wherein the at least one context attribute comprises the video frame rate.
In one or more embodiments, the sensor input module may be configured to receive at least one of a tilt value and a user seating position value, and wherein the at least one context attribute comprises at least one of the speed of a vehicle, the tilt of a vehicle, and the user seating position and the at least one user attribute comprises at least one of head motion and head tilt.
Embodiments of the audio controller may be included in a wearable device. The wearable device may further comprise a wireless receiver coupled to the sensor input, wherein the wearable device is configured to receive context attributes via the wireless receiver.
In a second aspect there is provided a method of generating an audio signal for alleviating motion sickness, the method comprising: receiving a sensor signal comprising at least one user attribute and at least one context attribute from the sensor input module; providing the sensor signal and the at least one context attribute to a machine learning model; controlling a stimulus generator using the machine learning model to generate a reference signal dependent on at least one of the adapted audio stimulation profile and the user input.
In one or more embodiments, the machine learning model comprises a neural network and the method may further comprise adapting the machine learning model by modifying the activation threshold of layers of the neural network dependent on the sensor signal.
In one or more embodiments, the method may further comprise controlling the period between bursts of the audio stimulus with a first neural network of the machine learning model, controlling the gain of the audio stimulus with a second neural network of the machine learning model, and controlling the offset of the audio stimulus with a third neural network of the machine learning model.
In one or more embodiments, the method may further comprise compiling additional training data dependent on the external user input and the sensor signal; adapting the machine learning model in a training cycle using training data comprising the additional training data; and storing the adapted machine learning model.
In one or more embodiments, the method may further comprise: receiving an audio signal; using a further machine learning model corresponding to the desired audio stimulation profile to control the filtering of the audio signal to at least attenuate infrasound signals dependent on at least one of the external user input and the sensor signal; mixing the filtered audio signal and the reference signal.
In a third aspect there is provided a computer program product comprising instructions which, when being executed by a processing unit, cause said processing unit to perform the steps of receiving a sensor signal comprising at least one user attribute and at least one context attribute from the sensor input module; providing the sensor signal and the at least one context attribute to a machine learning model; controlling a stimulus generator using the machine learning model to generate a reference signal dependent on at least one of the adapted audio stimulation profile and the user input.
In one or more embodiments, the machine learning model comprises a neural network and the processing unit may perform the steps of adapting the machine learning model by modifying the activation threshold of layers of the neural network dependent on the sensor signal.
In one or more embodiments, the processing unit may perform the steps of controlling the period between bursts of the audio stimulus with a first neural network of the machine learning model, controlling the gain of the audio stimulus with a second neural network of the machine learning model, and controlling the offset of the audio stimulus with a third neural network of the machine learning model.
In one or more embodiments, the processing unit may perform the steps of compiling additional training data dependent on the external user input and the sensor signal; adapting the machine learning model in a training cycle using training data comprising the additional training data; and storing the adapted machine learning model.
In one or more embodiments, the processing unit may perform the steps of: receiving an audio signal; using a further machine learning model corresponding to the desired audio stimulation profile to control the filtering of the audio signal to at least attenuate infrasound signals dependent on at least one of the external user input and the sensor signal; mixing the filtered audio signal and the reference signal.
In the figures and description like reference numerals refer to like features. Embodiments of are now described in detail, by way of example only, illustrated by the accompanying drawings in which:
In operation the sensor input 102, may be connected to one or more sensors. The connection to the sensors may vary dependent on the context of the audio controller 102. For example, in some examples the audio controller 100 may be integrated into a hearable device or other wearable device. If the user is in the car, the hearable device may communicate wirelessly with the sensor data via a communication link between the hearable device and the car by using an
RF connection such as Bluetooth or Near Field Magnetic Induction (NFMI). Alternatively, or in addition, in other examples the sensor input 102 may have a wired connection to one or more sensors included in the hearable device. This sensor data may include context attribute data such as the speed of the vehicle, the tilt of the vehicle, and the altitude. In other examples, if the user is using a VR headset, the VR headset may communicate with a hearable and provide sensor data such as video frame rate and scene information from. In other examples, the audio controller 100 may be included for example in a car infotainment system and VR headset. In addition, the sensor input 102 may be connected to sensors that provide user attribute data. This user attribute data may include information such as head motion, head tilt, other body motion such as jumping and physiological measurements such as heart rate and body temperature. The sensor module 110 may receive sensor inputs combine the data and output the sensor data on the sensor module output 108 to the machine learning model 120.
The memory 122 may include one or more profiles each corresponding to a configuration of the machine learning model 120. The term machine learning model 120 in this application may be considered as a model typically implemented as a neural network which has been configured or trained using some training data. The machine learning model may be implemented in software executable by for example a microprocessor, graphics processor, or digital signal processor. In other examples the processor may be a dedicated Artificial Intelligence (AI) processor which includes hardware circuits configurable as a neural network. In examples where the machine learning model is implemented in hardware in the processor, the processor may be considered to be an inference engine. The memory 122 may also include additional training data or a history which may be used to further adapt the machine learning model 120.
This training data typically includes context attribute data, user attribute data and a label of the desired response of the machine learning model to the context attribute data and user attribute data. The desired response may be control values for stimulus amplitude, burst period, burst frequency, combination of tones used. In some examples the memory may be considered to be part of the processor. In this case, the separate memory 122 may be omitted.
In operation, on initialization, a user of the audio controller 100 may select the profile for the machine learning model to use via the user selection input 104. This selection may be determined from one or more context attributes such as whether the user us in a car, aeroplane, train, boat or whether the user is using a VR headset. Alternatively, the machine learning model 120 may request a profile based on sensor inputs received from the sensor module 110.
The machine learning model 120 may control the stimulus generator 124 to generate an audio signal for alleviating motion sickness dependent on the sensor inputs received from the sensor module 108. The machine learning model 120 may generate control signals sent to the stimulus generator 124 which adapt characteristics of the generated reference signal such as burst frequency, period and a strength or amplitude. The user may apply an additional control signal via user control input 112 to adjust the characteristics of the audio stimulus while the audio controller 100 is in operation. These characteristics may include a gain, a period between each stimulus burst, or duration of each stimulus burst of the stimulus generation. This may be done for example by overriding the output of the machine learning model 120. In other examples, the weights applied to one or more layers of the neural network of the machine learning model 120 may be adjusted by using the additional input as training data to further adapt the machine learning model 120. In either case the user input may be captured along with the inputs of the sensor module to provide additional training data which may subsequently be stored in the memory 122.
In other examples, the machine learning model 120 may be directly adapted if the sensor module indicates conditions that are known to be highly likely to cause motion sickness, for example in the case of a car, if the sensors indicate frequent changes of direction above a certain threshold, the threshold of the activation function of one or more layers of the neural network of the machine learning model 120 may be adjusted to indicate an increase in the strength of the stimulus to the stimulus generator 124.
The inventors of the present disclosure have appreciated that by applying machine learning to the auditory stimulus, the audio controller 100 may automatically adapt the generated stimulus dependent on the specific preferences of the user and so implement an intelligently controlled auditory device. Further, in scenarios where the user wishes to adjust the automatically generated stimulus, the audio controller 100 may use the captured additional user preferences together with the sensor inputs at the time to initiate one or more further training cycles to further adapt the machine learning model 120. These additional training cycles may be initiated during a standby mode of the audio controller 100, on initialization or power up, or during some other suitable time. The profiles corresponding to the modified machine learning model configurations may be stored in memory for subsequent use by the audio controller 100.
The sensor output 208 may be connected to a first input of an audio mixer machine learning model 236. The audio mixer machine learning model 236 may have a second input connected to a user control input 212. The audio mixer machine learning model 236 may have a third input connected to an output 206 of a memory or storage element 222. The audio mixer machine learning model 236 may have a first output 226 connected to a third input of the audio mixer 232. The audio mixer machine learning model 236 may have a second output 216 connected to a first input 216 of the memory 222.
The memory 222 may have a second input connected to a user selection input 204. The stimulus generator 224 may have a stimulus generator output 218 connected to first input of an audio mixer 232. An audio input 228 may be connected to a second input of audio mixer 232. The audio mixer 232 may have a first audio output 234. The audio mixer 232 may have a second audio output 238.
In operation the sensor input 202, may be connected to one or more sensors. The connection to the sensors may vary dependent on the context of the audio controller 200. For example, in some examples the audio controller 200 may be integrated into a hearable device, other wearable device or mobile device. The sensor data received on the sensor input 202 may include context attribute data such as the speed of the vehicle, the tilt of the vehicle, and the altitude. In other examples, if the user is using a VR headset, the VR headset may communicate with a hearable and provide sensor data such as video frame rate and scene information from a video game. In other examples, the audio controller 200 may be included for example in a car infotainment system or other vehicle electronic system, or a VR headset. In addition, the sensor input 202 may be connected to sensors that provide user attribute data. This user attribute data may include information such as head motion, head tilt, other body motion such as jumping and physiological measurements such as heart rate and body temperature. The sensor module 210 may receive sensor inputs and combine the received sensor data. The sensor module 210 may output the sensor data on the sensor module output 208 to the motion sickness adaptor machine learning model 220 and the audio mixer machine learning model 236.
The memory 222 may include one or more profiles each corresponding to a configuration of each of the motion sickness adaptation machine learning model 220 and the audio mixer machine learning model 236. The term machine learning model as used in the present disclosure may be considered as a neural network which has been configured or trained using some training data. The machine learning model may be implemented as software running on a microprocessor, graphics processor or using a more dedicated Artificial Intelligence (AI) processor which has an architecture to support the implementation of neural networks. The memory 222 may also include additional training data or a history which may be used to further adapt each of the motion sickness adaptation machine learning model 220 and the audio mixer machine learning model 236. For the motion sickness adaptation machine learning model 220, this training data typically includes context attribute data, user attribute data and the desired response of the machine learning model to the context attribute data and user attribute data. The desired response may include control values for stimulus amplitude, burst period, burst frequency, combination of tones used. For the audio mixer machine learning model 236, this training data typically includes context attribute data, user attribute data and the desired response of the machine learning model to the context attribute data and user attribute data. The desired response may be for example control values for the audio mixer 232.
In operation, on initialization, a user of the audio controller 200 may select the profile for each machine learning model 220, 236 to use via the user selection input 204. This selection may be determined from one or more context attributes such as whether the user is in a car, aeroplane, train, boat or whether the user is using a VR headset. Alternatively, the machine learning model 220 may request a profile based on sensor inputs received from the sensor module 210.
The motion sickness adaptation machine learning model 220 may control the stimulus generator 224 to generate an audio signal for alleviating motion sickness dependent on the sensor inputs received from the sensor module 210. The machine learning model 220 may generate control signals sent to the stimulus generator 224 which adapt characteristics of the generated signal such as burst frequency, period and a strength or amplitude. The user may apply an additional control signal via user control input 212 to adjust the characteristics of the audio stimulus while the audio controller 200 is in operation.
This may be done for example by overriding the output of the motion sickness adaptation machine learning model 220. In other examples, the weights applied to one or more layers of the neural network of the motion sickness adaptation machine learning model 220 may be adjusted by using the additional input as training data to further adapt the machine learning model 220. In either case the user input may be captured along with the inputs of the sensor module to provide additional training data which may subsequently be stored in the memory 222.
In other examples, the motion sickness adaptation machine learning model 220 may be directly adapted by adjusting the threshold of the activation function, if the sensor module indicates conditions that are known to be highly likely to cause motion sickness. For example, in the case of a car, if the sensors indicate frequent changes of direction above a certain threshold, the threshold applied to the activation function of the neural network of the motion sickness adaptation machine learning model 220 may be adjusted to indicate an increase in the strength of the stimulus to the stimulus generator 224. The activation function used may be a ReLu (rectified linear units) activation function. It can be described as follows: R(x)=max (0, x) i.e. if x<0, R(x)=0 and if x>=0, R(x)=x. Such function may be implemented very efficiently. Other examples may use other activation functions such as Sigmoid or Tanh.
The audio mixer machine learning model 236 may control the audio mixer 232 to adapt the audio signal received on the audio input 228. The audio mixer machine learning model 236 may control the mixing of an audio signal received on the audio input 228 together with the output of the stimulus generator for alleviating motion sickness dependent on the sensor inputs received from the sensor module 210.
The audio mixer machine learning model 236 may receive an audio signal from the audio mixer 232 on the audio mixer machine learning model output 238. The audio mixer machine learning model 236 may generate control signals sent to the audio mixer 232 by first machine learning model output 226 which adapt characteristics of the received audio signal such as filter settings and gain strength to filter out infrasound and other frequencies known to have adverse effects such as nausea, dizziness and headaches. The user may apply an additional control signal via user control input 212 to adjust the characteristics of the audio input signal while the audio controller 200 is in operation.
This may be done for example be overriding the output of the audio mixer machine learning model 236. In other examples, the weights applied to one or more layers of the neural network of the audio mixer machine learning model 236 may be adjusted by using the additional input as training data to further adapt audio mixer machine learning model 236. In either case the user input may be captured along with the inputs of the sensor module to provide additional training data which may subsequently be stored in the memory 222.
The audio controller 200 may automatically adapt the generated stimulus for reducing motion sickness together with any other audio input stimulus dependent on the specific preferences of the user and so implement an intelligently controlled auditory device. By generating an audio input stimulus which may reduce motion sickness and filtering out audio frequencies, for example infrasound frequencies which potentially cause nausea and dizziness and headaches, the audio controller 200 may improve the well-being of a user. Further, in scenarios where the user wishes to adjust the automatically generated stimulus, the audio controller 200 may use the captured additional user preferences together with the sensor inputs at the time to initiate one or more further training cycles to further adapt the machine learning models 220,236.
These additional training cycles may be initiated during a standby mode of the audio controller 200, on initialization or power up, or during some other suitable time. The profiles corresponding to the modified machine learning model configurations may be stored in memory for subsequent use by the audio controller 200. The machine learning models 220, 236 may be trained independently from each other.
Returning to step 410, if the audio controller is in training mode, the method moves to step 412. The anti-motion sickness stimulus generation is controlled using one or more machine learning models as previously described for audio controller 100 and audio controller 200. In step 414 the context attribute data, the user attribute data received from one or more sensors and a user control input may be captured. In step 416, the captured data may be added to the training data 416. In step 418 a training cycle may be executed using the training data. The training cycle typically applies the training data to the neural network of the machine learning model over a number of epochs and may result in a new configuration of the machine learning model or machine learning models. In step 422 the method may determine whether or not machine learning model configurations or profiles may be updated. If the audio controller has received a deactivation signal, the method proceeds to step 424 in which any training data or updated profiles may be stored. Following step 424 the method 400 terminates at step 432. Returning to step 422, if the audio controller has not received a deactivation signal, the method returns to step 410.
Each machine learning model 510a, 510b, 510c may be implemented as a neural network having a respective input layer 504a, 504b, 504c, a respective number of hidden layers 506a, 506b, 506c and an output layer 508a, 508b, 508c. The number of hidden layers 506a, 506b, 506c may be different in each of the machine learning models 510a, 510b, 510c. the AI processor 500 may have a processor input 502 (node A) which may be a bus connected to each of the input layers 504a, 504b, 504c. The output 512a of the first machine learning model 510a may be connected to a gain controller 514. The output 512b of the second machine learning model 510b may be connected to a frequency controller 516. The output 512c of the third machine learning model 510c may be connected to an offset controller 518.
The gain controller output 522 may be connected to a first input of the stimulus generator 520.
The frequency controller output 524 may be connected to a second input of the stimulus generator 520. The offset controller output 526 may be connected to a third input of the stimulus generator 520. The stimulus generator 520 may have a user input 532 and a mode select input 534. The stimulus generator 520 may have a stimulus output 528 and a user control output 536 (node B) connected to a first input of a training data compiler 540. A second input of the training data compiler 540 may be connected to the processor input 502. Training data compiler 540 may have a training data output 538.
A sensor statistics calculator 530 may have an input connected to the processor input 502. The sensor statistics calculator 530 may have a sensor statistics calculator output 542 (node C) connected to the respective layers of the machine learning models 510a, 510b, 510c.
In this example the AI processor 500 has a machine learning model 510a, 510b, 510c for each of the control parameters. An initial profile may be configured from a learning cycle using off-line data consisting of a test set of sensor data and expected responses for each of the control parameters. The expected responses are the required amplitude setting, the required burst frequency, that is to say the period between each burst and the required offset which may be used to increase or decrease the amplitude of each burst by a fixed amount. Each machine learning model may have multiple outputs, each output corresponding to a specific setting for each control parameter. As will be understood, the neural network may be trained to classify which control parameter setting is the most desirable i.e. has the highest probability from the training data by minimising the loss function using the training data. This initial training is done off line and the resulting trained neural networks may implement the machine learning models 510a, 510b and 510c.
In operation, the initial profile or machine learning model configurations may be selected either based on sensor input information received on the processor input 502 or by user selection. The sensor input 502 may be connected to sensors that provide user attribute data or context attribute data. This user attribute data may include information such as head motion, head tilt, other body motion such as jumping and physiological measurements such as heart rate and body temperature. The context attribute data may include data such as the speed of the vehicle, the tilt of the vehicle, and the altitude.
Each machine learning model 510a, 510b and 510c may receive sensor input data and output respectively a required amplitude control, frequency control and offset control. In this example three machine learning models are shown, but it will be appreciated that the number of inference engines may vary depend on the number of different features from the sensor input data.
The gain controller 514 may generate a control signal for the stimulus generator 520 corresponding to the required amplitude of the auditory stimulus. The frequency controller 516 may generate a control signal for the stimulus generator 520 corresponding to the required burst frequency of the auditory stimulus. The offset controller 518 may generate a control signal for the stimulus generator 520 corresponding to the required offset of the auditory stimulus. The stimulus generator 520 may generate an auditory stimulus determined from the amplitude, frequency and offset.
The machine learning models 510a, 510b, 510c may be further adapted by the sensor statistics calculator 530. This may adapt the activation thresholds of the layers from a-priori rules on characteristics which may increase or reduce the likelihood of motion sickness. For example, if the sensor data indicates frequent change of direction or variation of tilt of a vehicle above a predetermined threshold.
Alternatively, or in addition, a user may override the machine learning model output via user input 532 when manual mode is selected on mode input 534. In this case the stimulus generator 520 is controlled directly by the user and the user input data is combined with the sensor data received on the processor input 502 by the training data compiler 540. This additional data may be used to run a further training cycle on the machine learning models 510a, 510b, 510c to generate a further adapted machine learning model which may be stored in memory (not shown) for use when the audio controller is subsequently activated. In this way the audio controller 500 may be adapted to automatically adjust the auditory signal characteristics for a specific user to alleviate motion sickness dependent on the context.
The enable module 602 may enable or disable the audio controller 600 determined from a control signal from the enable input 688. In some examples the enable input may be directly controlled by the user. The enable module 602 may have an output 676 connected to the memory 608 and a sensor input interface 672. The sensor input module 604 which may also be referred to as a sensor fusion module may have a speed sensor data module 678, angular tilt data module 682, and seating position data module 684.
The sensor input interface 672 may have a sensor input 690 connected to one or more different sensors (not shown). The connection to the sensors may be wired and/or wireless. The sensor input interface 672 may have an output 674 connected to a speed sensor data module 678, angular tilt data module 682, and seating position data module 684. The sensor input module 604 may have an output 628 connected to an output of the speed sensor data module 678, angular tilt data module 682, and seating position data module 684. In other examples different sensor input data modules may be used.
The audio input module 630 may include a mixer 664 and an audio player 662. The audio input module may have an audio stream input 666 connected to a first input of the mixer 664 and a microphone input 668 connected to the second input of the mixer 664. The mixer output 658 may be connected to an input of the audio player 662. The output of the audio player may be connected to the audio input module output 656.
The user input module 640 may include a user tuning stage 644 having an input connected to the input 646 of the user input module 640. The user tuning stage output 642 may be connected to the input of a gain stage 638. The gain stage output 636 may be connected to an input of the user input data module 634. The output of the user input data module 634 may be connected to the user input module output 632. The user input module output 632 may be connected to an input of the memory 608.
The AI processor 680 may include a burst period adaptor 610, a stimulus strength adaptor 610′, an offset adaptor 610″, and an audio mixing adaptor 620. Each of the burst period adaptor 610, stimulus strength adaptor 610′, offset adaptor 610″, and audio mixing adaptor 620 may include a machine learning model. Each of the burst period adaptor 610, stimulus strength adaptor 610′, offset adaptor 610″, and audio mixing adaptor 620 may have a first input connected to an output 616 of the memory 608. Each of the burst period adaptor 610, stimulus strength adaptor 610′, offset adaptor 610″, and audio mixing adaptor 620 may have a second input connected to the sensor input module output 628. Each of the burst period adaptor 610, stimulus strength adaptor 610′, offset adaptor 610″, and audio mixing adaptor 620 may have a third input connected to the user input module output 632. The audio mixing adaptor 620 may have a fourth input connected to the audio input module output 656. The audio mixing adaptor 620 may have a fifth input connected to the stimulus generator output 661.
The audio mixing adaptor 620 may have an output 648 connected to an input of the audio processor 650. The audio processor output may be connected to an acoustic transducer such as a loudspeaker 652. Each of the burst period adaptor 610, stimulus strength adaptor 610′, offset adaptor 610″, and audio mixing adaptor 620 may have a first output connected to a second input 618 of the memory 608. The burst period adaptor 610 may have burst control output 622 connected to a first input of the stimulus generator 660. The stimulus strength adaptor 610 may have stimulus strength control output 624 connected to second input of the stimulus generator 660. The offset adaptor 610 may have an offset control output 626 connected to a third input of the stimulus generator 660.
The audio controller 600 makes use of three types of sensor data from the sensor input module 604 to adapt a stimulus generated to alleviate motion sickness and optionally mix with a further adapted audio input signal. The types of sensor data may provide information on 1) Increase or Decrease in Speed of the vehicle, 2) Angular tilt of the car based on the road conditions (hilly or straight roads), and 3) Seating Position inside the car (i.e. if the person is seated facing to the direction of driving, seated in front or behind, seating in the direction opposite to the driving direction). In other examples, other types of sensor data may also be used. In some examples fewer or more than three types of sensor data may be used.
The operation of the audio controller 600 is now described assuming the audio controller 600 and the user is located in a vehicle such as a car. The audio controller 600 may be part of an in-car infotainment system or may be incorporated into a wearable device such as a hearable or smart watch.
The audio controller 600 may be enabled by the enable module 602. This may be enabled directly by the user on entering the car or indirectly by detecting that the user is in a vehicle. The enable module 602 may enable the sensors directly (not shown). The enable module 602 may enable the sensor input interface 672 and the sensor input 690 to allow sensor information to be received for example from a wireless communication link. The AI processor 680 may retrieve the stored predefined profiles 614 from the memory 608 and history to be read as initial training data for configuring the machine learning models in each of the burst period adaptor 610, stimulus strength adaptor 610′ and offset adaptor 610″. The selection of the profile from memory 608 may be determined directly by a user 654 controlling the user input module 640 or from initial sensor data received via the sensor input interface 672 and output on the sensor input module output 628.
Once configured, the AI processor 680 may control the stimulus generator 660 based on the sensor input data received from the sensor input module 604 for generating the auditory stimulation.
Extracted information from the sensor input module 604 may be provided to the AI processor 680 for machine learning and training the parameters to control the stimulus generator in a similar way to that described for audio controller 500. In the AI processor 680 the sensor data may be stored to provide statistical information and to adapt the response of the burst period adaptor 610, the stimulus strength adaptor 610′ and the offset adaptor 610″. The auditory stimulation generated by the stimulus generator 660 may be adapted by adapting the burst period of tones in response to increase or decrease in speed. The auditory stimulation generated by the stimulus generator 660 may be adapted by strengthening the stimulation frequency dependent on the angular tilt of the car. The auditory stimulation generated by the stimulus generator 660 may be adapted by strengthening the stimulation frequency dependent on the angular tilt of the car. The auditory stimulation generated by the stimulus generator 660 may be adapted by adding an offset, corresponding to a minimum signal level to the stimulation dependent on seating position in the vehicle.
The user 654 may override the default control be each of the burst period adaptor, the stimulus strength adaptor and the offset adaptor. In this case, the desired response corresponding to the user input value may be captured together with the sensor input data to provide additional training data. The burst period adaptor 610, stimulus strength adaptor 610′ and the offset adaptor 610″ may switch to a further training cycle using the updated training data to further adapt the response so that in future, the auditory stimulation generated by the stimulus generator 660 more closely matches that desired by a particular user 654.
When the audio controller 600 is deactivated which may be for example in response to the vehicle being turned off, the enable module 602 may enable the memory 608 to receive the additional trained configuration data or updated profiles 612 from each of the burst period adaptor 610, the stimulus strength adaptor 610′ and offset adaptor 610″. These updated profiles 612 may be subsequently used when the audio controller is next activated.
The auditory stimuli which may be in the inaudible frequency range is provided as first input to the audio mixing adaptor 620.
An audio stream received on audio stream input 666 may be mixed by mixer 664 with a microphone signal received on microphone input 668. The mixed audio signal may be output on mixer output 658. The audio player 662 may format the signal and provide it to the audio mixing adaptor 620. The with the auditory stimulation which is generated by the stimulus generator 660 which may typically be in the inaudible frequency range. The audio mixing adaptor 620 may adapt the received audio signal to alter the frequency spectrum of the audio signal in addition to the stimulus generation in order to remove infrasound and other frequencies that may cause nausea, headaches or dizziness in some people.
In some examples the audio mixing adaptor 620 and the audio input module 630 may be removed.
The stimulus parameter adaptor 700 has a machine learning model 710, a statistics calculator 708 and stimulus parameter adaptor memory 706. A user input 722 may be connected to the machine learning model 710. A sensor input 720 may be connected to the machine learning model 710 and the statistics calculator 708. The stimulus parameter adaptor memory 706 may have a first input 704 and first output 702 for communication with a further memory. Referring to the audio controller 600, this further memory may for example be the memory 608. The stimulus parameter adaptor memory 706 may have a second input 712 and second output 714 connected to the machine learning model 710. In operation the stimulus parameter adaptor 700 may receive initial configuration information from a further memory which is loaded into the stimulus parameter adaptor memory 706 via first input 704. This configuration information may be used to configure the machine learning model 710 via second output 714.
The machine learning model 710 may output a control signal for a stimulus generator via stimulus control output 724 dependent on the input data received. A user may override the default behaviour of the machine learning model 710 via user input 722. In this case the user input data and the sensor input data may be transferred to the stimulus parameter adaptor memory 706 via second input 712 and used as training data. The training data may subsequently be used to further train or adapt the machine learning model 710. Alternatively, or in addition, the machine learning model 710 may be directly adapted based on the output of the statistics calculator 708.
The statistics output 716 may adapt the threshold for the activation function in the layers of the neural network implementing the machine learning model 710 from a-priori rules on characteristics which may increase or reduce the likelihood of motion sickness. These may include rules for example to increase the stimulus level if the sensor data indicates frequent change of direction or variation of tilt of a vehicle above a predetermined threshold. If, for example, a change of direction happens more than X times in a given time period Y, then the threshold to stimulate may be reduced versus a default threshold setting. The default threshold setting may be the threshold which is used by the training data. If the change of direction happens much less than V times in a given time period W, the default threshold setting as stored in the memory is used.
In this way, the collected statistics may sensitise the neural network to increase the likelihood of stimulation.
The machine learning model 810 may have an output 826 connected to a control input of the filter 824. The output 826 may be connected to an input of the adaptation module 812. The adaptation module 812 may have a control input connected to the user input 814. An output 808 of the adaptation module 812 may be connected to an audio mixer memory 802. A first input 806 of the machine learning model 810 may be connected to an output of the audio mixer memory 802. A second input 804 of the audio mixer memory may be connected to a further memory (not shown).
In operation of the audio mixing adaptor 800, the audio mixer memory 802 may initially receive the environmental context setting from predefined profiles which may vary dependent for example on whether the user is in a car, a plane, or using a VR headset for gaming. These predefined profiles may be used to initially configure the machine learning model 810. An audio stream may be received on audio input 830. This audio stream may include a combination of audio data and microphone input data. The user may control the first gain stage 828 via user input 814 to add or reduce the gain strength for certain conditions.
The machine learning model 810 may receive the audio stream for feature extraction to determine environmental context. The machine learning model 810 may output a control signal for the filter 824 which may modify the audio stream based on the identified environmental context (e.g. filter settings, gain strengths). The machine learning model 810 may include one or more trained neural networks or machine learning models which select the most appropriate gain, and filter coefficients by classification in a similar way to described for the audio controller 500. The mixer 820 may overlay generated stimulus for alleviating motion sickness received on stimulus input 818 on top of the input audio stream received from the second gain stage output 822.
The adaptation module 812 may combine user feedback with the output of the machine learning model to provide additional training data for incremental learning. This training data may be transferred back to the audio mixer memory 802 and used to further adapt the machine learning model 810.
In operation of the auditory device 900, sensors coupled to the sensor fusion module 906 detect context attribute data based on the application. The sensor information may be used to determine of the environment of the user 932, thereby it captures if a person 932 is sitting, driving, moving, etcetera. The sensors maybe wirelessly connected or integrated into the auditory device 900. For example, if the auditory device 900 is incorporated into a hearing aid or other hearable device, sensory information may be obtained from sensors present in the hearables as well as from sensors present in external sources such as mobile phone, vehicle wireless infrastructure, VR infrastructure or other means. A user may influence which sensors are to be used.
In particular, for sensory information from external sources, there is a data communication pipe needed between sensory functions and the Hearables and/or Hearing Instruments. This data pipe may be via a wireless communication means like Bluetooth RF or NFMI.
In other examples, sensor information could be provided by the engine control unit (ECU) or car infotainment system. This sensor information may include speed, angular movement, and direction of the car based on the Global Positioning System (GPS) data. This sensor data may be either broadcasted via ECU or made available to person on seats which then can be communicated via Body Area Network (BAN) or NFMI to the device. Hearable devices may include wireless communication to enable a duplex communication channel from the vehicle to hearable and optionally vice-versa. The auditory controller may use Flight details if the context is a plane, Gyro information for specific movements if the context is a ship, or frames per second (FPS) if the context is a VR headset.
The controller unit 910 may process the sensor information received and performs the sensor fusion algorithms which processed the sensor data at the same time, for example using sensor fusion module 906. The sensor input module 912 may perform filtering of the sensor data. The AI processor 914 may perform the spectrum shaping of an auditory stimulus and generate the adapted stimulus signal for alleviating motion sickness. With the AI processor 914 enabled and the context attribute data, the controller unit 910 may adapt the generated stimulus for the user requirements eventually as the scenario changes. Stimulation control can be personalized for each user independently.
Based on the different application environments, the auditory stimulation can be varied accordingly. For example, if a person is listening to music in an autonomous car, the AI processor 914 may adapt the smart filter- and spectrum shaping functions to enrich the frequency spectrum of the music by filtering infrasound and providing additional frequency content, which may be in the inaudible frequency range for mitigating motion illness symptoms. In Gaming or VR applications, controller unit 910 may receive information about the running video for example the frame per second or video frame rate. Based on the information. The AI processor 914 may adapt the auditory signals to match the video or game visualized. The auditory signals may alleviate VR sickness.
The auditory controller 900 may adapt the profile settings based on the user for different levels of imbalance. The AI processor 914 may use sensory inputs to learn the different aspects of the environmental conditions and supplements for the behavioural characteristics of a user. The auditory controller 900 may include predefined profiles to provide an initial stimulus. The user may adjust or change the threshold levels of stimulus based on individual requirements. The AI processor 914 may learn the kind of stimulus to be output from the user feedback for the different scenario's and eventually perform the action of the user automatically. The user may override the AI processor 914 for tuning at any point of user's choice. The behavioural qualities captured by the AI processor 914 may be stored as specific user profile settings in the memory 916 which may also be reapplied in other devices.
The auditory device 900 may be plugged in to the ear to stimulate the vestibular system based on sensory information automatically without manual intervention. The auditory device 900 may be incorporated in one of a pair of hearable devices such as ear buds or hearing aids. Synchronization between ear buds or hearing aid devices may be done by wireless communication for example using NFMI wireless communication technology.
The sensed properties may be input to controller unit 910 to provide the auditory stimulus as explained previously for
The controller unit 910 may include predefined profiles and user feedback or tuning inputs stored in memory 916. The AI processor 914 may stimulate the auditory signals dependent on the sensor inputs. During the initial phase of AI learning, predefined profiles provide the required inputs to trigger the stimulus. A user may provide feedback via the user feedback input 918 to tune the stimulus thresholds based on individual need. With AI processing enabled, the controller unit 910 may learn the kind of stimulus to be triggered for different properties from the user and adapt the output.
By enabling the feedback path from a user 932, AI processor 914 may adapt and control the stimulus automatically based on the sensed properties. In some examples, the user may save the profile settings customized to individual, so that it can be used in other devices.
An audio controller for generating a signal for alleviating motion sickness is described. The audio controller comprises a sensor input module, a user control input and a processor comprising a machine learning model corresponding to a desired audio stimulation profile. The machine learning model is coupled to the sensor input module and the user control input. The machine learning model is configured to receive a sensor signal comprising at least one user attribute and at least one context attribute from the sensor input module. The audio controller includes a stimulus generator coupled to the machine learning model. The machine learning model controls the stimulus generator to generate a reference signal for alleviating motion sickness and adapts the reference signal dependent on at least one of the user control input and the sensor signal.
Although the appended claims are directed to particular combinations of features, it should be understood that the scope of the disclosure of the present invention also includes any novel feature or any novel combination of features disclosed herein either explicitly or implicitly or any generalisation thereof, whether or not it relates to the same invention as presently claimed in any claim and whether or not it mitigates any or all of the same technical problems as does the present invention.
In some example embodiments the set of instructions/method steps described above are implemented as functional and software instructions embodied as a set of executable instructions which are effected on a computer or machine which is programmed with and controlled by said executable instructions. Such instructions are loaded for execution on a processor (such as one or more CPUs). The term processor includes microprocessors, microcontrollers, processor modules or subsystems (including one or more microprocessors or microcontrollers), or other control or computing devices. A processor can refer to a single component or to plural components.
Features which are described in the context of separate embodiments may also be provided in combination in a single embodiment. Conversely, various features which are, for brevity, described in the context of a single embodiment, may also be provided separately or in any suitable sub combination.
The applicant hereby gives notice that new claims may be formulated to such features and/or combinations of such features during the prosecution of the present application or of any further application derived therefrom.
For the sake of completeness it is also stated that the term “comprising” does not exclude other elements or steps, the term “a” or “an” does not exclude a plurality, a single processor or other unit may fulfil the functions of several means recited in the claims and reference signs in the claims shall not be construed as limiting the scope of the claims.
Number | Date | Country | Kind |
---|---|---|---|
201911014990 | Apr 2019 | IN | national |