Sridhar Sankuratri - Campbell CA, US B. Anil Kumar - Saratoga CA, US Vladimir Stoyanov - Redmond WA, US Jeff B. Widergren - Mountain View CA, US Hon Luu - San Jose CA, US Damien Gerard Saint Macary - Sunnyvale CA, US
Assignee:
Microsoft Corporation - Redmond WA
International Classification:
G06F 13/14 G09G 5/02 G09G 5/00
US Classification:
345600, 345520, 345643
Abstract:
Example embodiments of the present disclosure provide techniques for efficiently processing and transmitting graphics data when sub-regions of the screen represented by the graphics data are updated at different relative update rates. In an embodiment, when the screen is divided into tiles and a plurality of the tiles have been determined as being changed, some of the sublevels resulting from the image transform may not be encoded and transmitted. The decoding process may use zeroes for any data not received. The rendering subsystem may render the image with the partial data, and the remaining data may be received in subsequent transmissions.
Denis Sergeyevich Shchepetov - Sunnyvale CA, US Sridhar Sankuratri - Campbell CA, US Damien Gerard Saint Macary - Sunnyvale CA, US Paul Johan Hsieh - San Jose CA, US
Assignee:
Microsoft Corporation - Redmond WA
International Classification:
G06F 15/80
US Classification:
345505
Abstract:
An invention is disclosed for performing entropy encoding in a parallelized manner, using a GPU. In embodiments, an input sequence of integers is received, and run-length encoding is performed on any runs of zeros in parallel operations on the GPU. Then, a plurality of parallelized operations are performed on the run-length encoded sequence to entropy encode the sequence. The value N may be entropy encoded using only N and the value that precedes it in the sequence, N−1, so the encoding may be sub-divided into multiple operations that may be performed in parallel on the GPU. After entropy encoding is performed, a bitstream may be produced using parallelized operations on the GPU.
Paul Johan Hsieh - San Jose CA, US Denis Sergeyevich Shchepetov - Sunnyvale CA, US Sridhar Sankuratri - Campbell CA, US Damien Gerard Saint Macary - Sunnyvale CA, US
Assignee:
Microsoft Corporation - Redmond WA
International Classification:
G06K 9/36
US Classification:
382233, 382248
Abstract:
An invention is disclosed for performing differencing of graphical data in post-transform space for a remote presentation session. Graphical data is transformed from a first representation to a second representation (e.g. with a DWT), and then a difference is taken of the post-transform data and the post-transform data of the frame that preceded the current frame. This difference is then encoded and transmitted to a client, which decodes it, and creates a representation of the graphical data using the delta, and a previously determined representation of the previous frame. By performing differencing in post-transform space, fidelity of the remote presentation session is retained while it may decrease bandwidth. This may occur because the entropy of the delta representation is usually lower than a non-delta representation while the scheme retains the identical data of the final decoded image of the non-delta version of the same compression scheme.
Web-Browser Based Desktop And Application Remoting Solution
Nadim Y. Abdo - Redmond WA, US B. Anil Kumar - Saratoga CA, US Wilhelm R. Schmieder - Snoqualmie WA, US Sridhar Sankuratri - Campbell CA, US Krishna Mohan Malladi - San Jose CA, US Asael Dror - San Francisco CA, US Joy Chik - Redmond WA, US Tad Brockway - Woodinville WA, US
Assignee:
Microsoft Corporation - Redmond WA
International Classification:
G06F 15/16
US Classification:
709219
Abstract:
An invention is disclosed for conducting a remote presentation session with a client that uses a web browser to conduct the session. In embodiments, a proxy server exists between the remote presentation server and the client. The proxy server establishes a HTTP session with the client and a remote presentation session with the client. The server generates graphics encoded with a remote presentation protocol and sends them to the proxy, which re-encodes them as video and sends them to the client for display in the web browser. The client captures user input at the web browser and sends it to the proxy, which encodes it with the remote presentation protocol and sends it to the server to be processed.
Cross-Frame Progressive Spoiling Support For Reduced Network Bandwidth Usage
Tong L. Wynn - Redmond WA, US Vladimir Stoyanov - Redmond WA, US Sridhar Sankuratri - Campbell CA, US Damien Saint Macary - Sunnyvale CA, US Voicu Anton Albu - Bellevue WA, US Costin Hagiu - Sammamish WA, US
Assignee:
Microsoft Corporation - Redmond WA
International Classification:
G06F 15/16
US Classification:
709217
Abstract:
An invention is disclosed for efficiently processing and transmitting graphics data in a remote desktop environment. In embodiments of the invention, a connection is established between a remote desktop server computer and a remote desktop client computer. The remote desktop server computer may process graphics data representative of a remote user desktop. The remote desktop server computer may divide the remote desktop screen in data regions and portions. The remote desktop server computer may then encode and transmit each region to the remote desktop client computer at a certain quality that may be adjusted progressively across the screen frames. The remote desktop server computer may also stop encoding and transmitting the portions of the data region that would not be visible to a user when the region is rendered on a display. The remote desktop user experiences an image quality gradually improving with each frame containing information about the image.
An invention is disclosed for encoding and decoding data in a 4:4:4 subsampling scheme, using an encoder/decoder that is not configured to encode or decode data in 4:4:4. In embodiments, an encoder planararizes an input frame into three component frames in a 4:0:0 scheme. The encoder then encodes each component frame in the 4:0:0 scheme, and aggregates the encoded component frames into a bit stream. A decoder receives such a bit stream, and decodes it with a component not configured to decode data in 4:4:4. The decoder decodes the bit stream to produce a representation of the three component frames in 4:0:0, then aggregates the three component frames into a representation of the original frame in 4:4:4.
Denis Sergeyevich Shchepetov - Sunnyvale CA, US Sridhar Sankuratri - Campbell CA, US Damien Gerard Saint Macary - Sunnyvale CA, US
Assignee:
Microsoft Corporation - Redmond WA
International Classification:
G06T 9/00
US Classification:
382248
Abstract:
An invention is disclosed for performing differencing of graphical data in post-transform space for a remote presentation session. Graphical data is transformed from a first representation to a second representation (e.g. with a DWT), and then a difference is taken of the post-transform data and the post-transform data of the frame that preceded the current frame. This difference is then encoded and transmitted to a client, which decodes it, and creates a representation of the graphical data using the delta, and a previously determined representation of the previous frame. By performing differencing in post-transform space, fidelity of the remote presentation session is retained while it may decrease bandwidth. This may occur because the entropy of the delta representation is usually lower than a non-delta representation while the scheme retains the identical data of the final decoded image of the non-delta version of the same compression scheme.
Block Vector Prediction In Video And Image Coding/Decoding
- Redmond WA, US Gary J. Sullivan - Bellevue WA, US Jizheng Xu - Beijing, CN Sridhar Sankuratri - Campbell CA, US B. Anil Kumar - Saratoga CA, US Feng Wu - Beijing, CN
Assignee:
Microsoft Technology Licensing, LLC - Redmond WA
International Classification:
H04N 19/52 H04N 19/91
Abstract:
Innovations in the area of prediction of block vector (“BV”) values improve encoding or decoding of blocks using intra block copy (“BC”) prediction. For example, some of the innovations relate to use of a default BV predictor with a non-zero value. Other innovations relate to use of a selected one of multiple BV predictor candidates for a current block. Still other innovations relate to use of a skip mode in which a current intra-BC-predicted block uses a predicted BV value.
Google
Software Engineering Manager
Microsoft Jan 2008 - Dec 2014
Principal Development Lead, Rdp Codecs
Calista Technologies Jan 2006 - Dec 2007
Principal Engineer
Netcontinuum Sep 2000 - Apr 2004
Principal Engineer
Infogrames Na Sep 1999 - Sep 2000
Technical Lead
Education:
Rensselaer Polytechnic Institute 1990 - 1992
Master of Science, Masters
Indian Institute of Technology, Delhi 1986 - 1990
Bachelors, Bachelor of Technology, Communications, Engineering, Electronics
Indian Institute of Technology, Madras
Bachelors, Bachelor of Technology, Communications, Engineering, Electronics
Skills:
Algorithms Unix Programming Windows Server Scalability Technical Leadership Software Project Management Hyper V Vdi Windows Distributed Systems C++ Software Development Tcp/Ip Visual Studio Architectures Software Engineering Architecture Engineering Management C Device Drivers Perl Agile Methodologies Software Design Cloud Computing Microsoft Azure C#