258 lines
15 KiB
XML
258 lines
15 KiB
XML
== Desktop and mobile interactions<m:interaction>
|
|
|
|
=== Desktop interaction
|
|
|
|
Regarding desktop interaction, we keep the interaction we described in Section~\ref{bi:our-nve}, namely:
|
|
- W, A, S and D keys to translate the camera;
|
|
- mouse motions to rotate the camera.
|
|
A screenshot of this interface is displayed in @m:desktop.
|
|
|
|
#figure(
|
|
image("../assets/system-bookmarks/screenshots/desktop.png", width: 100%),
|
|
caption: [Screenshot of the desktop version, with a bookmark and its thumbnail on the bottom left corner and three bookmarks],
|
|
)<m:desktop>
|
|
|
|
=== Mobile interaction
|
|
|
|
Mobile interactions are more complex because the user does not have the keyboard and mouse to interact with.
|
|
However, there are some other sensors on most mobile devices that can help interaction.
|
|
One useful sensor for 3D interaction on mobile devices is definitely the gyroscope.
|
|
We use the gyroscope to enable a user to rotate his device to rotate the virtual camera.
|
|
We also add the possibility to rotate the camera by using touch controls. The user can touch a part of the screen to get a hold at the virtual camera, and drag the camera direction along the two screen axis.
|
|
This way, the user is not forced to perform a real-world half-turn to be able to look behind or to point the device towards the sky (which can quickly become tiring) to look up.
|
|
These interactions, however, only allow the user to rotate the camera but not translate it.
|
|
For this reason, we display a small joystick on the bottom-left corner of the screen that mimics the first person video games interactions and allows the user travelling in the scene:
|
|
- moving the joystick up makes the camera move forward;
|
|
- moving the joystick down makes the camera move backwards;
|
|
- moving the joystick on the sides makes the camera move sideways.
|
|
A screenshot of this interface is displayed in @m:mobile. The virtual joystick is rendered as a black circle inside a larger semi-transparent white circle. The black circle can be moved up, down, and sideways to define the direction in which the camera is translated.
|
|
|
|
#figure(
|
|
image("../assets/system-bookmarks/screenshots/mobile.png", width: 100%),
|
|
caption: [Screenshot of the mobile version, with its joystick on the bottom left corner],
|
|
)<m:mobile>
|
|
|
|
== Adding bookmarks into DASH NVE framework<m:bookmarks>
|
|
|
|
While the previously defined interactions allow users to navigate freely throughout the scene, controlling such a high number of degrees of freedom can feel overwhelming to some users. That is why we introduce bookmarks, i.e. widgets that help the users reach a distant part of the scene using only a single, simple, interaction.
|
|
|
|
|
|
=== Bookmark interaction and visual aspect
|
|
|
|
In Chapter~\ref{bi} Section~\ref{bi:3d-bookmarks}, we described two 3D widgets that we use to display bookmarks to users.
|
|
One of the conclusions of the user-study, described in Section~\ref{bi:user-study}, was that the impact of the way we display bookmark was not significant.
|
|
In this work, we chose a slightly different way of representing bookmarks due to some concerns with our original representations:
|
|
- viewport bookmarks are simple, but non computer vision experts may not be familiar with this type of representation;
|
|
- arrow bookmarks are more intuitive to most users, but need to be regenerated when the camera moves, which can harm the rendering framerate.
|
|
For these reasons, we changed the bookmarks display to a vertical bar textured with a 2D sprite of a pictorial representation of an eye. The use of such symbol is partly inspired by the cartographic pictograms used to showcase a worthwhile panorama.
|
|
This 2D sprite is always facing the camera to prevent it from being invisible when the camera would be on the side of it.
|
|
Screenshots of user interfaces with bookmarks are available in @m:desktop and @m:mobile.
|
|
|
|
The size of the sprite changes over time following a sine function to help the user distinguish what is part of the scene and what is extra widgets.
|
|
Since our scene is static, a user knows that a changing object is not part of the scene, but part of the UI.
|
|
|
|
The other bookmark parameters remain unchanged since @bi: in order to avoid users to lose context, clicking on a bookmark triggers an automatic, smooth, camera displacement that ends up at the bookmarked camera position.
|
|
We also display a thumbnail of the bookmark's viewpoint when the mouse hovers a bookmark.
|
|
Such thumbnail is displayed in @m:desktop.
|
|
Note that since on mobile, there is no mouse and thus no pointer, thumbnails are not used in the mobile setting.
|
|
|
|
|
|
// \begin{algorithm}[th]
|
|
// \SetKwInOut{Input}{input}
|
|
// \SetKwInOut{Output}{output}
|
|
//
|
|
// \SetKwData{BookmarkViewpoint}{bookmarked\_viewpoint}
|
|
// \SetKwData{OptimalOrder}{optimal\_order}
|
|
// \SetKwData{TotalModel}{total\_model}
|
|
// \SetKwData{EmptyModel}{empty\_model}
|
|
// \SetKwData{I}{i}
|
|
// \SetKwData{BestSegment}{best\_segment}
|
|
// \SetKwData{BestPsnr}{best\_delta\_psnr}
|
|
// \SetKwData{PreviousPsnr}{previous\_psnr}
|
|
// \SetKwData{None}{none}
|
|
// \SetKwData{CurrentModel}{current\_model}
|
|
// \SetKwData{EmptyRender}{empty\_render}
|
|
// \SetKwData{CurrentRender}{current\_render}
|
|
// \SetKwData{GroundTruthRender}{ground\_truth\_render}
|
|
// \SetKwData{CurrentPsnr}{current\_psnr}
|
|
// \SetKwData{CurrentDeltaPsnr}{current\_delta\_psnr}
|
|
// \SetKwData{Segment}{segment}
|
|
// \SetKwData{Candidates}{candidates}
|
|
// \SetKwFunction{Render}{render}
|
|
// \SetKwFunction{Psnr}{psnr}
|
|
//
|
|
// \Input{The bookmarked viewpoint, the ground truth render at this viewpoint, the candidate segments}
|
|
// \Output{The optimal order of the segments}
|
|
//
|
|
// \OptimalOrder\leftarrow{} []\;
|
|
// \EmptyRender\leftarrow\Render{\EmptyModel,\BookmarkViewpoint}\;
|
|
// \PreviousPsnr\leftarrow\Psnr{\EmptyRender,\GroundTruthRender}\;
|
|
//
|
|
// \TotalModel\leftarrow\EmptyModel\;
|
|
//
|
|
// \For{\I\in0\ldots200}{%
|
|
//
|
|
// \BestSegment\leftarrow\None\;
|
|
// \BestPsnr\leftarrow0\;
|
|
//
|
|
// \For{\Segment\in\Candidates}{%
|
|
//
|
|
// \CurrentModel\leftarrow\TotalModel\cup\Segment\;
|
|
// \CurrentRender\leftarrow\Render{\CurrentModel,\BookmarkViewpoint}\;
|
|
// \CurrentPsnr\leftarrow\Psnr{\CurrentRender,\GroundTruthRender}\;
|
|
// \CurrentDeltaPsnr\leftarrow\CurrentPsnr$-$\PreviousPsnr\;
|
|
//
|
|
// \If{\CurrentDeltaPsnr$>$\BestPsnr}{%
|
|
// \BestSegment\leftarrow\Segment\;
|
|
// \BestPsnr\leftarrow\CurrentDeltaPsnr\;
|
|
// }
|
|
// }
|
|
// \OptimalOrder\leftarrow\OptimalOrder+\BestSegment\;
|
|
// \TotalModel\leftarrow\TotalModel\cup\BestSegment\;
|
|
// }
|
|
// \caption{Computation of the optimal order of segments from a bookmark\label{sb:algo-optimal-order}}
|
|
// \end{algorithm}
|
|
|
|
|
|
=== Segments utility at bookmarked viewpoint<m:utility>
|
|
|
|
Introducing bookmarks is a way to make users navigation more predictable.
|
|
Indeed, since they are emphasized and, in a way, recommended viewpoints, bookmarks are more likely to be visited by a significant portion of users than any other viewpoint on the scene.
|
|
As such, bookmarks can be used as a way to optimize streaming by downloading segments in an optimal, precomputed order.
|
|
|
|
More specifically, segment utility as introduced in Section~\ref{d3:utility} is only an approximation of the segment's true contribution to the current viewpoint rendering.
|
|
When bookmarks are defined, it is possible to obtain a better measure of segment utility by performing an offline rendering at each bookmark's viewpoint.
|
|
// Then, by simply counting the number of pixels that are rendered using each segment, we can rank the segments by order of importance in the rendering.
|
|
We define $cal(U)^* (s,B_i)$ as being the optimized utility of a segment $s$ in a viewpoint defined at bookmark $B_i$.
|
|
|
|
In order to compute the optimized utility of a segment, we developed Algorithm~\ref{sb:algo-optimal-order}, that sorts segments according to their optimized utility.
|
|
This algorithm takes as input the considered viewpoint, the ground truth rendering from this viewpoint and the set of segments (both geometry and texture) to sort.
|
|
Starting from an empty model, each segment from the set of candidates is independently added to the scene, and the PSNR between the corresponding render and the ground truth render is computed.
|
|
We can thus determine which segment brings the highest $Delta"PSNR" slash s$, $s$ being the size of the segment in bytes.
|
|
Once the best segment is found, it is registered, and a new iteration begins.
|
|
That way, we are able to generate an order of segments sorted by $Delta"PSNR" slash s$.
|
|
This order is then saved as a JSON file that a client can download in order to know which segments contribute the most to a certain viewpoint.
|
|
|
|
Sorting all the segments from the model would be an excessively time consuming computation.
|
|
To speed up this algorithm, we only sort the 200 first best segments, and we choose these segments among a filtered set of candidates.
|
|
To find those candidates, we reuse the ideas developed in Chapter~\ref{bi}.
|
|
We render the "pixel to geometry segment" and "pixel to texture" maps, as shown in @m:bookmarks-utility.
|
|
These renderings allow us to know which geometry segment and which texture correspond to each pixel, and filter out useless candidates.
|
|
|
|
#figure(
|
|
grid(
|
|
columns: (1fr, 0.1fr, 1fr, 0.1fr, 1fr),
|
|
image("../assets/system-bookmarks/bookmark/ground-truth.png", width: 100%),
|
|
[],
|
|
image("../assets/system-bookmarks/bookmark/geometry.png", width: 100%),
|
|
[],
|
|
image("../assets/system-bookmarks/bookmark/texture.png", width: 100%),
|
|
),
|
|
caption: [A bookmarked viewpoint (left), a pixel to geometry segment map (center), and a pixel to texture map (right)]
|
|
)<m:bookmarks-utility>
|
|
|
|
Figure~\ref{sb:precomputation} shows how this precomputation improves the quality of rendering.
|
|
Each curve represents the PSNR one can obtain by downloading a certain amount of data following a streaming policy.
|
|
The blue curve, labelled "Default order", is obtained by optimizing the utilities as defined in Section~\ref{d3:utility}, whereas the green curve labelled "Proposed order" uses the sorting computed in Algorithm~\ref{sb:algo-optimal-order}.
|
|
We can observe that for the same amount of data downloaded, the optimized order reaches a higher PSNR which means that its utility metric is more accurate.
|
|
Note that this curve is averaged over all the 9 bookmarks of the scene. These bookmarks are chosen to cover the widest area in the scene, and each one faces a particular object-of-interest.
|
|
|
|
// \begin{figure}[th]
|
|
// \centering
|
|
// \begin{tikzpicture}
|
|
// \begin{axis}[
|
|
// xlabel=Data downloaded (in B),
|
|
// ylabel=PSNR,
|
|
// no markers,
|
|
// cycle list name=mystyle,
|
|
// width=\tikzwidth,
|
|
// height=\tikzheight,
|
|
// legend pos=south east,
|
|
// xmin=0,
|
|
// ]
|
|
//
|
|
// \addplot table [x=x, y=y]{assets/system-bookmarks/precomputation/greedy.dat};
|
|
// \addlegendentry{\scriptsize Default order $cal(U)$}
|
|
// \addplot table [x=x, y=y]{assets/system-bookmarks/precomputation/precomputed.dat};
|
|
// \addlegendentry{\scriptsize Proposed order $cal(U)^*$}
|
|
//
|
|
// \end{axis}
|
|
// \end{tikzpicture}
|
|
// \caption{Impact of using the precomputed information of bookmarks to select segments to download\label{sb:precomputation}}
|
|
// \end{figure}
|
|
|
|
|
|
=== MPD modification
|
|
|
|
We now present how to include bookmarks information in the Media Presentation Description (MPD) file.
|
|
Bookmarks are fully defined by a position, a direction, and the additional content needed to properly render and use a bookmark in a system.
|
|
This additional data consist in two files: a thumbnail of the point of view at the bookmark, along with the JSON file giving the optimal segment order for this viewpoint, as computed by Algorithm~\ref{sb:algo-optimal-order}.
|
|
For this reason, for each bookmark, we create a separate adaptation set in the MPD.
|
|
The bookmarked viewpoint information is stored as a supplemental property.
|
|
Bookmarks adaptation set only contain one representation, composed of two segments: the thumbnail used as a preview for the desktop interface and the JSON file.
|
|
|
|
#figure(
|
|
align(left,
|
|
raw(
|
|
read("../assets/system-bookmarks/bookmark-as.xml"),
|
|
block: true,
|
|
lang: "xml"
|
|
),
|
|
),
|
|
caption: [MPD description of a geometry adaptation set, and a texture adaptation set],
|
|
)<m:bookmark-as>
|
|
|
|
An example of a bookmark adaptation set is depicted on @m:bookmark-as.
|
|
The three first values in the supplemental property are the camera position coordinates, and the three last values are the target point coordinates.
|
|
|
|
=== Loader modifications
|
|
|
|
We build on the loader introduced in Algorithm~\ref{d3:next-segment} to implement a client adaptation logic.
|
|
We include a bookmark adaptation logic such that (i) when a bookmark is hovered for the first time, the corresponding thumbnail image as well as the JSON file containing the optimal order of the segments (see @m:bookmark-as) are downloaded, and (ii) when a bookmark is clicked, we switch from utility $cal(U)$ to optimized utility $cal(U)^*$ to determine which segments to download next.
|
|
|
|
// \begin{algorithm}[th]
|
|
// \SetKwInOut{Input}{input}
|
|
// \SetKwInOut{Output}{output}
|
|
//
|
|
// \SetKw{Continue}{continue}
|
|
// \SetKwData{Bw}{bw\_estimation}
|
|
// \SetKwData{Rtt}{rtt\_estimation}
|
|
// \SetKwData{CurrentSegment}{segment}
|
|
// \SetKwData{Segment}{best\_segment}
|
|
// \SetKwData{Candidates}{candidates}
|
|
// \SetKwData{AllSegments}{all\_segments}
|
|
// \SetKwData{DownloadedSegments}{downloaded\_segments}
|
|
// \SetKwData{Frustum}{frustum}
|
|
// \SetKwFunction{Argmax}{argmax}
|
|
// \SetKwFunction{Filter}{filter}
|
|
// \SetKwFunction{EstimateNetwork}{estimate\_network\_parameters}
|
|
// \SetKwFunction{Append}{append}
|
|
//
|
|
// \Input{Current index $i$, time $t_i$, viewpoint $v(t_i)$, buffer of already downloaded \texttt{segments}, MPD, utility metric $cal(U)$, streaming polic $\Omega$}
|
|
// \Output{Next segment to request, updated buffer}
|
|
// \BlankLine{}
|
|
//
|
|
// \uIf{bookmark clicking}{%
|
|
// \uIf{not optimal order fetched}{%
|
|
// \Return{} optimal order segment\;
|
|
// }
|
|
// \Else{%
|
|
// \Return{} next segment\;
|
|
// }
|
|
// }
|
|
// \Else{%
|
|
// \tcc{Loading policy from previous chapter}
|
|
// (\Bw, \Rtt) \leftarrow{} \EstimateNetwork{}\;
|
|
//
|
|
// \BlankLine{}
|
|
// \Candidates\leftarrow{} \AllSegments\newline\makebox[1cm]{}.\Filter{$\CurrentSegment\rightarrow\CurrentSegment\notin\DownloadedSegments$}\newline\makebox[1cm]{}.\Filter{$\CurrentSegment\rightarrow\CurrentSegment\in\Frustum$}\;
|
|
// \BlankLine{}
|
|
// \Segment\leftarrow{} \Argmax{\Candidates, \CurrentSegment\rightarrow{} $\Omega\left(cal(U),\CurrentSegment\right)$}\;
|
|
// \DownloadedSegments.\Append{\Segment}\;
|
|
// \Return\Segment;
|
|
// {\caption{Algorithm to identify the next segment to query\label{sb:next-segment}}}
|
|
//
|
|
// }
|
|
// \end{algorithm}
|
|
//
|