Avatars are used to represent users of computing devices in many different contexts, including in computer forums, messaging environments, video game environments, and social media. Avatars can take many different forms, including two-dimensional images or three-dimensional characters. Some avatars may be animated. In such examples, image data capturing a user's face may be used to map determined user facial expressions to an animated avatar, thereby controlling the expressions of the animated avatar.
This Summary is provided to introduce a selection of concepts in a simplified form that are further described below in the Detailed Description. This Summary is not intended to identify key features or essential features of the claimed subject matter, nor is it intended to be used to limit the scope of the claimed subject matter. Furthermore, the claimed subject matter is not limited to implementations that solve any or all disadvantages noted in any part of this disclosure.
Examples are disclosed that relate to displaying computer-generated facial expressions. One example provides a method for displaying computer-generated facial expressions. The method comprises receiving expression data, and generating one or more facial expressions for an eye region of a user based at least on the expression data. The method further comprises displaying the one or more facial expressions for the eye region on an outward-facing display of a head-mounted device.
As mentioned above, avatars may be used to represent computing device users in a variety of use contexts. However, avatars may present various shortcomings in comparison to face-to-face or video interpersonal interaction. For example, people may rely on seeing expressions on each other's facial expressions as a mode of communication, whereas many avatars provide no indication of a user's expressions during conversation. Some computing systems, such as smart phones, tablets and laptops, may use image data capturing a user's face to control expressions displayed on an avatar. However, such cameras may be difficult to integrate into a compact head-mounted device, and also may consume signification power.
Accordingly, examples are disclosed that relate to controlling the display of computer-generated facial expressions on an avatar utilizing a facial tracking sensor system comprising one or more facial tracking sensors. As described in more detail below, values are received from each facial tracking sensor over time, and a value range is determined for each facial tracking sensor based upon the data received, the value range comprising minimum and maximum values received during a period of time (e.g. during a rolling time window). The value range and incoming sensor values are processed to translate the incoming sensor values to blendshape mappings, wherein the blendshape mappings correspond to locations of the sensor values within the value range. Then, expression data is determined based at least upon the blendshape mapping, and is provided to one or more devices for presentation. In such a manner, a set of facial tracking sensors can be used together to sense overall approximation of an expression of a user and thereby control the expressions of an avatar. The avatar may be presented to other people than the user of the sensor device. This may help with interpersonal communication in an AR (augmented reality) and/or VR (virtual reality) environment.
Avatar 114 displays computer-generated facial expressions based at least in part on sensor data acquired using sensors on first head-mounted device 106. Signals from facial tracking sensors on first head-mounted device 106 are interpreted at runtime, and the signals are mapped to blendshapes representing facial expressions for the avatar. The blendshape mapping is used to obtain expression data, which is then provided to one or more display devices. The display devices may use the expression data to display facial expressions, including animations, for the avatar.
First head-mounted device 106 comprises a plurality of facial tracking sensors each of which is configured to detect a proximity of a location on a face of first user 102 to the sensor. Facial tracking sensors may be positioned proximate to various location on the face of first user 102, such as left and right eyebrows, left and right cheeks, and nose bridge. In some examples, multiple sensors may be used to sense different locations on eyebrows, different location on cheeks, etc. to obtain more detailed data. The data from the plurality of facial tracking sensors collectively represents a facial surface configuration of first user 102, which provides information about the expression of first user 102.
In some examples, first head-mounted device 106 may comprise other sensors, such as eye-tracking cameras and/or an inertial measurement unit (IMU). In such examples, data from such sensors may be used to respectively determine an eye gaze direction and/or a head pose for controlling an eye and/or a head of the avatar, respectively.
In various examples, processing of the sensor data may be performed locally on first head-mounted device 106, on a remote computing system 116 (e.g. a data center server or a local host computing device in various examples) accessible by a network 118 (e.g. a suitable local area network and/or wide area network, such as the internet), or distributed between first head-mounted device 106 and network-accessible remote device 116. The expression data determined is provided to second head-mounted device 110 to control facial animations of avatar 114. As such, in
Head-mounted device 200 further may comprise a microphone 206, an eye-tracking camera 208, an outward-facing camera system 209, and/or an IMU 210 in various examples. Audio data acquired using microphone 206 may be used for voice-driven animation, e.g. by linking phonemes to mouth blendshapes. Likewise, data from eye-tracking camera 208 may help to determine a gaze direction to drive eye-related animation of an avatar. Further, data from IMU 210 and/or outward-facing camera system 209 may help to determine a head pose to drive head-related animation of an avatar, potentially in combination with a separate user-facing camera (e.g. a webcam or mobile device camera) (not shown in
Head-mounted device 200 further comprises a display 212, a processor 214, and computer-readable memory 216 comprising instructions 218 executable by the processor 214 to control the various functionalities of head-mounted device 200, including the determination and display of computer-generated facial expressions.
Pipeline 300 is configured to estimate a range of sensor values corresponding to a range of motion of a face, and then interpret the sensor values based upon the determined range to map sensor values to blendshapes. The range may be updated in a rolling manner, as described below. Pipeline 300 receives raw sensor data acquired by a facial tracking sensor, as indicated at 302. In the depicted example, the raw sensor data represents digital sensor values received from an ADC. For simplicity, pipeline 300 is depicted for data received from a single facial tracking sensor. It will be understood that pipeline 300 can be replicated in full or in part for sensor data acquired using each additional facial tracking sensor.
Pipeline 300 determines rolling minimum and rolling maximum sensor values at 304. In some examples, to help exclude outlying signals (e.g. data that arises from a bumping of a head-mounted device rather than facial motions), pipeline 300 periodically reduces a range between the rolling minimum and the rolling maximum, as indicated at 306. As one example, the rolling minimum and the rolling maximum can be revaluated by taking a median value and adding/subtracting ¼ of the minimum/maximum respectively. As another example, a middle 80% of the minimum/maximum window may be used for a next time window. The range reduction may be performed at any suitable frequency. In some examples, the range is reduced at a frequency within a range of once every five to fifteen seconds. In other examples, a calibration step can establish minimum/maximum values. In yet other examples, the range can be adjusted in any suitable manner and/or at any suitable frequency.
Continuing, pipeline 300 centers the incoming data at 308. Centering the data may include, at 310 determining a rolling centered median sensor value, as well as centered rolling minimum and centered rolling maximum values. The rolling centered median value may be updated periodically, as indicated at 310. In some examples, the rolling centered median value may be updated at a frequency of once every one to five seconds of time. In other examples, any other suitable update frequency may be used.
As depicted at 312, the resulting data comprises data having values between the centered minimum and the centered maximum, where the centered minimum is less than zero and the centered maximum is greater than zero. In some examples, the centered data may be normalized, while in other examples normalization may be omitted.
In some examples, the centered sensor value is evaluated for directionality of facial movement (e.g. raising or lowering of an eyebrow). Directionality may be determined based on whether the centered sensor value is below or above zero. In such a manner, pipeline 300 can determine a directional relationship between the sensor value and a blendshape mapping. In some examples, a calibration step can be performed to determine sensor directionality, such as for eyebrows, upper cheeks, or other suitable facial groups, as directionality data for a facial tracking sensor may be different for different users. In some such examples, the calibration step can comprise a guided experience in which the user is guided to perform expressions so that a directionality association can be obtained for one or more of the face tracking sensors. In other examples, an image sensor (e.g., an eye-tracking camera) may be configured to identify when the user raises a facial landmark, such as an eyebrow, and associate the directionality of the sensor when that happens. Such calibration steps may help to enable pipeline 300 to be implemented more easily for differently-shaped faces.
Continuing, pipeline 300 determines an interpolation value for each centered data value at 314. In the depicted example, an inverse linear interpolation is performed on the centered sensor value. In other examples, any other suitable interpolation can be used, such as ease-in-out, ease-in, and/or ease-out interpolations.
In some examples, pipeline 300 next may perform a linear-to-gamma space conversion on the interpolated value to form a transformed value at 316. In the depicted example, the transformed value comprises a range of between zero and one, which is the same range of the normalized data obtained from the linear interpolation. However, the linear-to-gamma space conversion may emphasize more subtle facial movements compared to the normalized data from the interpolation at 314. An example linear-to-gamma space conversion plot is shown in
Returning to
In some facial expressions, a facial movement in a first location may be reflected other location(s) of a face. As such, a list of linked blendshape nodes can be used to link sensed movement of one facial location to the other locations linked with the first location. For example, a sensed movement of a cheek may correspond to a movement of a corner of a mouth. As such, a blendshape node for a cheek may be linked to a blendshape node for the corner of the mouth, allowing the sensed motion of the cheek to affect the shape of the mouth in a displayed avatar. In this manner, a one-to-many blendshape association per-sensor, and/or a cross-sensor analysis to determine what the face is likely doing, may be performed. In examples where the linear-to-gamma space conversion is omitted, the blendshape mapping can be based directly on the interpolated value.
Continuing with
As mentioned above, in some examples a blendshape mapping for an interpolated or transformed value can be determined for each blendshape node of a list of linked blendshape nodes.
In some examples, a plurality of lists of linked blendshape nodes 500 may be stored, where each list in the plurality of lists can be associated with a different facial tracking sensor. Such a configuration may help to determine blendshape mappings from each a plurality of facial tracking sensors directed towards a plurality of areas of a face. Further, each blendshape node 502, 504, 506 comprises a corresponding weight 508, 510, and 512, respectively. Corresponding weight 508 indicates how much of the sensor value affects the blendshape mapping of first blendshape node 502. Similarly, corresponding weights 510 and 512 can indicate how much of the sensor value affects the blendshape mappings of second and third blendshape nodes 504 and 506, respectively. In some examples, each blendshape node 502, 504, 506 can further comprise a threshold value used to indicate a directionality. For example, when a sensor value acquired using an eyebrow sensor goes up, an animated eyebrow raises, and when the sensor value goes down, the animated eyebrow lowers. Such a configuration may help to determine expression data across multiple users with different facial landmark positions.
In some examples, data from multiple different types of sensors may be used to determine expression data.
Head-mounted device 602 comprises one or more eye-tracking cameras 608, one or more facial tracking sensors 610, and one or more microphones 612. Head-mounted device 602 is configured to determine facial landmark tracking data 614 based upon data acquired using facial tracking sensors 610 and eye-tracking cameras 608. Such a configuration may help to track facial landmark movement, including a gaze direction in some examples. Head-mounted device 602 is further configured to acquire audio data 616 using microphones 612.
Avatar animation service 604 comprises fusion module 618 configured to determine expression data 606 from facial landmark tracking data 614 and audio data 616. In some examples, fusion module 618 can utilize pipeline 300 to process data from facial tracking sensors 610. In some examples, fusion module 618, further can determine voice-driven animation based on audio data 616 (e.g., by determining one or more visemes based upon detected phonemes). This may allow animations for portions of a face not sensed by a facial tracking sensor 610 to be produced based upon the audio data 616.
Avatar animation service 604 is further configured to provide expression data 606 to a device, as indicated at 620. The device can be head-mounted device 602, a different head-mounted device, or any other suitable display device. In such a manner, computing system 600 may utilize a power-light set of facial tracking sensors in combination with eye-tracking cameras and microphones to create a simulacrum of a user's facial expression based on the input readings of those sensors synthesized into a final output indicating expression data. In other examples, other sensors may be used to provide additional data for avatar animation. For example, sensors such as an IMU and/or cameras (internal or external to a head-mounted device) may be used to drive animation of head motion of an avatar.
As previously mentioned, in some examples a facial tracking sensor may comprise a resonant RF sensor.
Each antenna 704 is configured for near-field electromagnetic detection. In some examples, each antenna 704 may comprise a narrowband antenna with a quality factor in the range of 150 to 2000. The use of a such narrowband antenna may provide for greater sensitivity than an antenna with a lower quality factor. The oscillator 708 and amplifier 710 are configured to generate an oscillating signal on the antenna. In some examples, the oscillating signal is selected to be somewhat offset from a target resonant frequency of the resonant RF sensor (e.g. a resonant frequency that is often experienced during device use, such as a resonant frequency when a face is in a rest state), as such a configuration may provide for lower power operation than where the oscillating signal is more often at the resonant frequency of the resonant RF signal.
Head-mounted device 700 further comprises a logic subsystem 712 and a storage subsystem 714. In the head-mounted device example, logic subsystem 712 may execute instructions stored in the storage system 714 to control each resonant RF sensor 702, and to determine data regarding face tracking based upon signals received from each resonant RF sensor 702. Logic subsystem 712 may be configured to detect facial inputs (e.g. motions and/or poses) using any suitable method. As a more detailed example, the instructions stored in the storage subsystem 714 may be configured to perform any suitable portion of pipeline 300.
Head-mounted device 700 may further comprise an IMU 716. IMU data from the IMU 716 may be used to detect changes in position of the head-mounted device, and may help to distinguish device movements (e.g. a device being adjusted on or removed from the head) from facial movements. In some examples, IMU data may be used at least in part to drive animation of avatar head motion. Further, head-mounted device 700 includes one or more eye-tracking cameras 718 and a microphone 720.
The capacitance 810 of the antenna 808 and the inductor 802 form a series resonator. The capacitance of the antenna 808 is a function of a surface proximate (e.g. a face) to the antenna 808, and thus varies based on changes in a position of the surface proximate to the sensor. Changes in the capacitance at capacitor 810 changes the resonant frequency of the series resonator, which may be sensed as a change in one or more of a phase and an amplitude of a sensor output detected at output node 816. In some examples, a separate capacitor may be included to provide additional capacitance to the resonant circuit, for example, to tune the resonant circuit to a selected resonant frequency.
As shown on lens 902a, antennas 904a-g are separated by trench regions 906, indicated by thick dark lines. Trench regions 906 are regions between antennas that lack an electrically conductive film(s) that form antennas 904a-g. In some examples, trench regions 906 may comprise electrically conductive traces to carry signals to and/or from antennas 904a-g to other circuitry. Trench regions 906 may be formed by masking followed by deposition of the conductive film for the antennas, or by etching after forming the conductive film, in various examples. In some examples, trench regions are etched into the lens or other substrate.
As a conductive film from which the antennas 904a-g are formed may not be fully transparent, the antenna layout may be visible to a user in some examples. However, when incorporated into a device configured to be worn on the head, the antenna layout may be positioned closer than a focal length of the human eye during most normal use of head-mounted device 900. As such, the layout may be out of focus to a user during ordinary device use, and thus may not obstruct the user's view or distract the user.
In some examples, method 1000 may comprise, at 1006, receiving head pose data. In some such examples, the head pose data may be received from an IMU unit. In other examples, head pose data alternatively or additionally may be received from an image sensor. In some examples, the image sensor may comprise an outward-facing image sensor on the head-mounted device. In such examples, a detected change of orientation of the head-mounted device relative to an environment may be indicative of head motion. In other examples, an external user-facing camera may be used to sense head motion. Further, in some examples, method 1000 comprises, at 1012, receiving eye-tracking data. In other examples, steps 1006, 1008, 1010, and/or 1012 may be omitted.
Method 1000 further comprises, at 1014, determining an interpolated value for the sensor value within a value range. The value range corresponds to a blendshape range for a facial expression. The interpolated value may represent a location of the sensor value within the value range. In some examples, method 1000 comprises, at 1016, determining a rolling minimum sensor value and a rolling maximum sensor value received during a period of time. The rolling minimum sensor value and the rolling maximum sensor value are based upon a range of received sensor values, and the period of time may comprise a rolling window. Method 1000 further may comprises, at 1018, determining a rolling centered median value, and at 1020, determining a centered sensor value based at least upon the rolling centered median sensor value, the rolling centered minimum, and the rolling centered maximum. Method 1000 additionally may comprise interpolating the centered sensor value. In some examples, method 1000 may comprise performing an inverse interpolation based upon the centered sensor value to obtain the interpolated value, as indicated at 1022. In other examples, any other suitable interpolation may be used.
In some examples, method 1000 may comprise, at 1024, performing a transform on the interpolated value to form a transformed value. In some such examples, the transform may comprise, at 1026, converting the interpolated value into a gamma space value. This conversion may help to generate more meaningful and natural looking computer-generated facial expressions. In other examples, method 1000 may omit 1024 and/or 1026.
Continuing, method 1000 comprises, at 1028, determining a blendshape mapping based at least upon the interpolated value. In some examples, the interpolated value itself is mapped to the blendshape. In other examples, where the interpolated value is transformed to the transformed value, the blendshape mapping may be based upon the transformed value.
In some examples, method 1000 comprises, at 1034, determining a blendshape mapping to each blendshape node of a list of linked blendshape nodes. Such a configuration can help to determine a one-to-many association between a sensor value received and blendshapes the sensor value may affect. In some such examples, each blendshape node comprises a corresponding weight, as indicated at 1036. The corresponding weight may indicate a percentage of the sensor value that affects a target blendshape. Such a manner may help to get meaningful and more natural looking movements out of the computer-generated facial expressions. Continuing, method 1000 comprises, at 1038, determining a directional relationship between the sensor value and the blendshape mapping. This may be performed based upon a calibration performed previously. Such a configuration may help to adjust for different facial landmark positioning across multiple users.
Continuing, method 1000 comprises, at 1040, determining expression data based at least upon the blendshape mapping. In examples where the head pose data is received, the expression data can be further based upon the head pose data, indicated at 1042. Additionally, in examples where eye-tracking data is received, the expression data further may be based upon the eye-tracking data, as indicated at 1044. Method 1000 additionally comprises, at 1046, providing the expression data to a device. In some examples, the expression data may be provided to more than one device.
The disclosed examples of controlling computer-generated facial expressions help to produce facial animations of an avatar and may help communication between users in an AR and/or VR environment. Further, utilizing resonant RF sensors to power the facial animations may help to increase an availability of facial tracking data.
In some examples, a VR device may be configured with an outward-facing display on which an avatar (e.g. an avatar that represents a portion of a user's face, such as an eye region) may be displayed. Such a device may allow facial expressions of the eye region of a user to be displayed on the outward-facing display when the user is communicating with another person. The term “eye region” represents a facial region around the user's eyes that is occluded from the view of others by a head-mounted device.
In some examples, facial expressions 1108 displayed on outward-facing display 1106 may be based at least on expression data determined using facial tracking sensors, as discussed above. In other examples, any other suitable type of facial tracking data alternatively or additionally may be used, including image data acquired using one or more face-tracking cameras configured to image the user's face.
In some examples, user-facing display 1220 may be configured to selectively operate in a video augmented reality (AR) mode. In the video AR mode, head-mounted device 1200 images an environment of head-mounted device 1200 using one or more outward-facing cameras 1212, and displays the environment on user-facing display 1220. In such a manner, the user of head-mounted device 1200 may view the real-world environment, including other people in the environment, while wearing head-mounted device 1200. Thus, the use of the video AR mode may facilitate interpersonal communication while wearing head-mounted device 1200.
However, as mentioned above, head-mounted device 1200 may occlude an eye region of the user's face. As such, outward-facing display 1222 may be used to display one or more facial expressions for an eye region of the user when operating in the video AR mode. The displayed facial expressions may facilitate face-to-face communications while head-mounted device 1200 is worn, as others can view simulations of the facial expression of the user of head-mounted device 1200. In some such examples, the head-mounted device may be configured to cease display of the one or more facial expressions of the eye region when switching out of the video AR mode. Ceasing display of the one or more facial expressions of the eye region when switching out of the video AR mode may signal to others that the user of head-mounted device 1200 is reengaging with a virtual reality experience.
In the depicted example, computer-readable memory 1214 comprises a facial model 1224, a texture 1226, and instructions 1228 executable by processor 1216 to control various functionalities of head-mounted device 1200, including the generation and/or display of computer-generated facial expressions. Facial model 1224 may comprise various blendshapes, and/or any other suitable information indicating expressions of a face. Texture 1226 may comprise information relating to a visual appearance of the eye region of the user, such as skin and/or eye color as examples, or may comprise any other suitable texture information. In other examples, computer-readable memory 1214 may comprise any other suitable information related to displaying and/or generating facial expressions of an eye region of a user.
Continuing, method 1300 comprises, at 1312, displaying the one or more facial expressions for the eye region on an outward-facing display of the head-mounted device. In this manner, the one or more facial expressions for the eye region may be visible to a person communicating with the user. In some examples, method 1300 comprises, at 1314, mapping a blendshape of a facial model based at least upon the expression data. In such a manner, a facial expression that represents the user's actual facial expression with suitable accuracy may be generated. In some examples, as described above, method 1300 may comprise applying a texture to the facial model at 1316. The texture may apply a visual appearance of the eye region of the user to the one or more facial expressions generated, such as skin and/or eye color.
Facial expressions may be displayed using an outward-facing display in a variety of scenarios. For example, as mentioned above, facial expressions may be displayed during operation of a video AR mode. As such, method 1300 further comprises, at 1318, displaying the one or more facial expressions of the eye region when operating the head-mounted device in a video AR mode. The video AR mode may comprise displaying on a user-facing display of the head-mounted device images acquired by an outward-facing image sensor of the head-mounted device. Method 1300 further comprises, at 1320, ceasing display of the one or more facial expressions of the eye region when switching out of the video AR mode. In other examples, processes 1318 and/or 1320 may be omitted.
Continuing, method 1400 comprises, at 1408, determining a blendshape mapping based at least on the sensor value. The blendshape mapping may correspond to a location of the sensor value within a value range of sensor values received over time as discussed above. In some examples, method 1400 comprises, at 1410, interpolating a centered sensor value within a centered value range. The value interpolated may be used to determine a blendshape mapping as discussed above.
Method 1400 further comprises, at 1412, determining expression data based at least upon the blendshape mapping. In some examples, method 1400 comprises, at 1414, determining a directional relationship between the sensor value and the blendshape mapping. This may be performed based upon a calibration performed previously. Such a configuration may help to adjust for different facial landmark positioning across multiple users. Additionally, in examples where eye-tracking data is received, the expression data further may be based on the eye-tracking data, as indicated at 1416. Method 1400 further comprises generating, at 1418, one or more facial expressions for an eye region of a user based on the expression data and displaying, at 1420, the one or more facial expressions for the eye region on an outward-facing display of the head-mounted device.
In some embodiments, the methods and processes described herein may be tied to a computing system of one or more computing devices. In particular, such methods and processes may be implemented as a computer-application program or service, an application-programming interface (API), a library, and/or other computer-program product.
Computing system 1500 includes a logic subsystem 1502 and a storage subsystem 1504. Computing system 1500 may optionally include a display subsystem 1506, input subsystem 1508, communication subsystem 1510, and/or other components not shown in
Logic subsystem 1502 includes one or more physical devices configured to execute instructions. For example, the logic machine may be configured to execute instructions that are part of one or more applications, services, programs, routines, libraries, objects, components, data structures, or other logical constructs. Such instructions may be implemented to perform a task, implement a data type, transform the state of one or more components, achieve a technical effect, or otherwise arrive at a desired result.
The logic machine may include one or more processors configured to execute software instructions. Additionally or alternatively, the logic machine may include one or more hardware or firmware logic machines configured to execute hardware or firmware instructions. Processors of the logic machine may be single-core or multi-core, and the instructions executed thereon may be configured for sequential, parallel, and/or distributed processing. Individual components of the logic machine optionally may be distributed among two or more separate devices, which may be remotely located and/or configured for coordinated processing. Aspects of the logic machine may be virtualized and executed by remotely accessible, networked computing devices configured in a cloud-computing configuration.
Storage subsystem 1504 includes one or more physical devices configured to hold instructions executable by the logic machine to implement the methods and processes described herein. When such methods and processes are implemented, the state of storage subsystem 1504 may be transformed—e.g., to hold different data.
Storage subsystem 1504 may include removable and/or built-in devices. Storage subsystem 1504 may include optical memory (e.g., CD, DVD, HD-DVD, Blu-Ray Disc, etc.), semiconductor memory (e.g., RAM, EPROM, EEPROM, etc.), and/or magnetic memory (e.g., hard-disk drive, floppy-disk drive, tape drive, MRAM, etc.), among others. Storage subsystem 1504 may include volatile, nonvolatile, dynamic, static, read/write, read-only, random-access, sequential-access, location-addressable, file-addressable, and/or content-addressable devices.
It will be appreciated that storage subsystem 1504 includes one or more physical devices. However, aspects of the instructions described herein alternatively may be propagated by a communication medium (e.g., an electromagnetic signal, an optical signal, etc.) that is not held by a physical device for a finite duration.
Aspects of logic subsystem 1502 and storage subsystem 1504 may be integrated together into one or more hardware-logic components. Such hardware-logic components may include field-programmable gate arrays (FPGAs), program- and application-specific integrated circuits (PASIC/ASICs), program- and application-specific standard products (PSSP/ASSPs), system-on-a-chip (SOC), and complex programmable logic devices (CPLDs), for example.
The terms “module” and “program” may be used to describe an aspect of computing system 1500 implemented to perform a particular function. In some cases, a module or program may be instantiated using logic subsystem 1502 executing instructions held by storage subsystem 1504. It will be understood that different modules and/or programs may be instantiated from the same application, service, code block, object, library, routine, API, function, etc. Likewise, the same module and/or program may be instantiated by different applications, services, code blocks, objects, routines, APIs, functions, etc. The terms “module” and “program” may encompass individual or groups of executable files, data files, libraries, drivers, scripts, database records, etc.
It will be appreciated that a “service”, as used herein, is an application program executable across multiple user sessions. A service may be available to one or more system components, programs, and/or other services. In some implementations, a service may run on one or more server-computing devices.
When included, display subsystem 1506 may be used to present a visual representation of data held by storage subsystem 1504. This visual representation may take the form of a graphical user interface (GUI). As the herein described methods and processes change the data held by the storage machine, and thus transform the state of the storage machine, the state of display subsystem 1506 may likewise be transformed to visually represent changes in the underlying data. Display subsystem 1506 may include one or more display devices utilizing virtually any type of technology. Such display devices may be combined with logic subsystem 1502 and/or storage subsystem 1504 in a shared enclosure, or such display devices may be peripheral display devices.
When included, input subsystem 1508 may comprise or interface with one or more user-input devices such as a keyboard, mouse, touch screen, or game controller. In some embodiments, the input subsystem may comprise or interface with selected natural user input (NUI) componentry. Such componentry may be integrated or peripheral, and the transduction and/or processing of input actions may be handled on- or off-board. Example NUI componentry may include a microphone for speech and/or voice recognition; an infrared, color, stereoscopic, and/or depth camera for machine vision and/or gesture recognition; a head tracker, eye tracker, accelerometer, and/or gyroscope for motion detection and/or intent recognition; as well as electric-field sensing componentry for assessing brain activity.
When included, communication subsystem 1510 may be configured to communicatively couple computing system 1500 with one or more other computing devices. Communication subsystem 1510 may include wired and/or wireless communication devices compatible with one or more different communication protocols. As non-limiting examples, the communication subsystem may be configured for communication using a wireless telephone network, or a wired or wireless local- or wide-area network. In some embodiments, the communication subsystem may allow computing system 1500 to send and/or receive messages to and/or from other devices using a network such as the Internet.
Another example provides a method for displaying computer-generated facial expressions. The method comprises receiving expression data, generating one or more facial expressions for an eye region of a user based at least on the expression data, and displaying the one or more facial expressions for the eye region on an outward-facing display of a head-mounted device. In some such examples, generating the one or more facial expressions for the eye region alternatively or additionally comprises mapping a blendshape of a facial model based at least upon the expression data. In some such examples, the method alternatively or additionally comprises applying a texture to the facial model. In some such examples, the method is alternatively or additionally performed on the head-mounted device, and displaying the one or more facial expressions for the eye region alternatively or additionally comprises displaying the one or more facial expressions of the eye region when operating the head-mounted device in a video augmented reality mode. In some such examples, the method alternatively or additionally comprises ceasing display of the one or more facial expressions of the eye region when switching out of the video augmented reality mode. In some such examples, receiving the expression data alternatively or additionally comprises determining the expression data based at least upon receiving a sensor value received from a facial tracking sensor of the head-mounted device. In some such examples, the facial tracking sensor alternatively or additionally comprises a resonant radio frequency sensor. In some such examples, receiving the expression data alternatively or additionally comprises receiving the expression data from a remote server.
Another example provides a method comprising receiving a sensor value acquired using a facial tracking sensor of a head-mounted device, determining a blendshape mapping based at least on the sensor value, determining expression data based at least upon the blendshape mapping, generating one or more facial expressions for an eye region of a user based on the expression data, and displaying the one or more facial expressions for the eye region on an outward-facing display of the head-mounted device. In some such examples, receiving the sensor value alternatively or additionally comprises receiving a plurality of sensor values acquired from a plurality of facial tracking sensors of the head-mounted device. In some such examples, determining the blendshape mapping alternatively or additionally comprises interpolating a centered sensor value within a centered value range. In some such examples, the method alternatively or additionally comprises determining a directional relationship between the sensor value and the blendshape mapping. In some such examples, the method alternatively or additionally comprises receiving eye-tracking data, and determining the expression data is alternatively or additionally based on the eye-tracking data.
Another example provides computing system comprising a facial tracking sensor, an outward-facing display, a logic system, and a memory system comprising instructions executable by the logic system to receive expression data, generate one or more facial expressions for an eye region of a user based on the expression data, and display the one or more facial expression for the eye region on the outward-facing display. In some such examples, the computing system alternatively or additionally comprises a head-mounted device, and the instructions executable to display the one or more facial expressions for the eye region alternatively or additionally comprise instructions executable to display the one or more facial expressions of the eye region when in a video augmented reality mode. In some such examples, the method alternatively or additionally comprises instructions executable to cease display of the one or more facial expression of the eye region when switching out of the video augmented reality mode. In some such examples, the facial tracking sensor alternatively or additionally comprises a resonant radio frequency sensor. In some such examples, the instructions executable to receive the expression data alternatively or additionally comprise instructions executable to receive the expression data from a remote server. In some such examples, the instructions executable to receive the expression data alternatively or additionally comprise instructions executable to determine the expression data based at least upon receiving a sensor value acquired using the facial tracking sensor. In some such examples, the instructions executable to generate the one or more facial expressions for the eye region alternatively or additionally comprise instructions executable to map a blendshape of a facial model based at least upon the expression data.
It will be understood that the configurations and/or approaches described herein are exemplary in nature, and that these specific embodiments or examples are not to be considered in a limiting sense, because numerous variations are possible. The specific routines or methods described herein may represent one or more of any number of processing strategies. As such, various acts illustrated and/or described may be performed in the sequence illustrated and/or described, in other sequences, in parallel, or omitted. Likewise, the order of the above-described processes may be changed.
The subject matter of the present disclosure includes all novel and non-obvious combinations and sub-combinations of the various processes, systems and configurations, and other features, functions, acts, and/or properties disclosed herein, as well as any and all equivalents thereof.
This application is a continuation-in-part of U.S. patent application Ser. No. 17/663,111, titled CONTROLLING COMPUTER-GENERATED FACIAL EXPRESSIONS, filed May 12, 2022, the entirety of which is hereby incorporated herein by reference for all purposes.
Number | Date | Country | |
---|---|---|---|
Parent | 17663111 | May 2022 | US |
Child | 17808049 | US |