Monte Carlo (MC) path tracing is a technique for rendering images of three-dimensional scenes by tracing paths of light through pixels on an image plane. This technique is capable of producing high quality images that are nearly indistinguishable from photographs. In MC path tracing, the color of a pixel is computed by randomly sampling light paths that connect the camera to light sources through multiple interactions with the scene. The mean intensity of many such samples constitutes a noisy estimate of the total illumination of the pixel. Unfortunately, in realistic scenes with complex light transport, these samples might have large variance, and the variance of their mean only decreases linearly with respect to the number of samples per pixel. Typically, thousands of samples per pixel are required to achieve a visually converged rendering. This can result in prohibitively long rendering times. Therefore, there is a need to reduce the number of samples needed for MC path tracing while still producing high-quality images.
Supervised machine learning using convolutional neural networks (CNNs) is applied to denoising images rendered by MC path tracing. The input image data may include pixel color and its variance, as well as a set of auxiliary buffers that encode scene information (e.g., surface normal, albedo, depth, and their corresponding variances). A repeated-block architecture and a residual-block architecture may be employed in the neural networks. In some embodiments, a CNN directly predicts the final denoised pixel value as a highly non-linear combination of the input features. In some other embodiments, a kernel-prediction neural network uses a CNN to estimate the local weighting kernels, which are used to compute each denoised pixel from its neighbors. In some embodiments, the input image can be decomposed into diffuse and specular components. The diffuse and specular components are then independently preprocessed, filtered, and postprocessed, before recombining them to obtain a final denoised image. A normalization procedure may be used as a preprocessing step in order to mitigate the high-dynamic range of the input images rendered by MC path tracing.
The patent or application file contains at least one drawing executed in color. Copies of this patent or patent application publication with color drawing(s) will be provided by the Office upon request and payment of the necessary fee.
In recent years, physically-based image synthesis has become widespread in feature animation and visual effects. Fueled by the desire to produce photorealistic imagery, many production studios have switched their rendering algorithms from REYES-style micropolygon architectures to physically-based Monte Carlo (MC) path tracing. While MC rendering algorithms can satisfy high quality requirements, they do so at a significant computational cost and with convergence characteristics that require long rendering times for nearly noise-free images, especially for scenes with complex light transport.
Recent postprocess, image-space, general MC denoising algorithms have demonstrated that it is possible to achieve high-quality results at considerably reduced sampling rates (see Zwicker et al. and Sen et al. for an overview), and commercial renderers are now incorporating these techniques. For example, Chaos group's VRay renderer, the Corona renderer, and Pixar's RenderMan now ship with integrated denoisers. Moreover, many production houses are developing their own internal solutions or using third-party tools (e.g., the Altus denoiser). Most existing image-space MC denoising approaches use a regression framework.
Some improvements in image-space MC denoising techniques have been achieved due to more robust distance metrics, higher order regression models, and diverse auxiliary buffers tailored to specific light transport components. These advances, however, have come at the cost of ever-increasing complexity, while offering progressively diminishing returns. This is partially because higher-order regression models are prone to overfitting to the noisy input. To circumvent the noise-fitting problem, Kalantari et al. recently proposed an MC denoiser based on supervised learning that is trained with a set of examples of noisy inputs and the corresponding reference outputs. However, this approach used a relatively simple multi-layer perceptron (MLP) for the learning model and was trained on a small number of scenes. Morover, their approach hardcoded the filter to either be a joint bilateral or joint non-local means, which limited the flexibility of their system.
Embodiments of the present invention provide a novel supervised learning framework that allows for more complex and general filtering kernels by leveraging deep convolutional neural networks (CNNs). Ever-increasing amount of production data can offer a large and diverse dataset for training a deep CNN to learn the complex mapping between a large collection of noisy inputs and corresponding references. One advantage is that CNNs are able to learn powerful non-linear models for such a mapping by leveraging information from the entire set of training images, not just a single input as in many of the previous approaches. Moreover, once trained, CNNs are fast to evaluate and do not require manual tuning or parameter tweaking. Also, such a system can more robustly cope with noisy renderings to generate high-quality results on a variety of MC effects without overfitting. Although this approach could be used for other applications of physically-based image synthesis, the present disclosure focuses on high-quality denoising of static images for production environments.
More specifically, embodiments of the present invention provide a deep learning solution for denoising MC renderings which is trained and evaluated on actual production data. It has been demonstrated that this approach performs on par or better than existing state-of-the-art denoising methods. Inspired by the standard approach of estimating a pixel value as a weighted average of its noisy neighborhood, embodiments of the present invention use a novel kernel-prediction CNN architecture that computes the locally optimal neighborhood weights. This provides regularization for a better training convergence rate and facilitates use in production environments. Embodiments of the present invention also explore and analyze the various processing and design decisions, including a two-network framework for denoising diffuse and specular components of the image separately, and a normalization procedure for the input image data that significantly improves the denoising performance for images with high dynamic range.
Path tracing is a technique for presenting computer-generated scenes on a two-dimensional display by tracing a path of a ray through pixels on an image plane. The technique can produce high-quality images, but at a greater computational cost. In some examples, the technique can include tracing a set of rays to a pixel in an image. The pixel can be set to a color value based on the one or more rays. In such examples, a set of one or more rays can be traced to each pixel in the image. However, as the number of pixels in an image increases, the computational cost also increases.
In a simple example, when a ray reaches a surface in a computer-generated scene, the ray can separate into one or more additional rays (e.g., reflected, refracted, and shadow rays). For example, with a perfectly specular surface, a reflected ray can be traced in a mirror-reflection direction from a point corresponding to where an incoming ray reaches the surface. The closest object that the reflected ray intersects can be what will be seen in the reflection. As another example, a refracted ray can be traced in a different direction than the reflected ray (e.g., the refracted ray can go into a surface). For another example, a shadow ray can be traced toward each light. If any opaque object is found between the surface and the light, the surface can be in shadow and the light may not illuminate the surface. However, as the number of additional rays increases, the computational costs for path tracing increases even further. While a few types of rays have been described that affect computational cost of path tracing, it should be recognized that there can be many other variables that affect computational cost of determining a color of a pixel based on path tracing.
In some examples, rather than randomly determining which rays to use, a bidirectional reflectance distribution function (BRDF) lobe can be used to determine how light is reflected off a surface. In such examples, when a material is more diffuse and less specular, the BRDF lobe can be wider, indicating more directions to sample. When more sampling directions are required, the computation cost for path tracing may increase.
In path tracing, the light leaving an object in a certain direction is computed by integrating all incoming and generated light at that point. The nature of this computation is recursive, and is governed by the rendering equation:
Lo({right arrow over (x)},{right arrow over (ω)}0)=Le({right arrow over (x)},{right arrow over (ω)}o)+∫Ωƒr({right arrow over (x)},{right arrow over (ω)}i,{right arrow over (ω)}o)Li({right arrow over (x)},{right arrow over (ω)}i)({right arrow over (ω)}i·{right arrow over (n)}i)d{right arrow over (ω)}i, (1)
where Lo represents the total radiant power transmitted from an infinitesimal region around a point {right arrow over (x)} into an infinitesimal cone in the direction {right arrow over (Ω)}0. This quantiy may be referred to as “radiance.” In equation (1), Le is the emitted radiance (for light sources), {right arrow over (n)} is the normal direction at position {right arrow over (x)}, Ω is the unit hemisphere centered around {right arrow over (n)} containing all possible values for incoming directions {right arrow over (ω)}i, and Li represents the incoming radiance from {right arrow over (ω)}i. The function ƒr is referred to as the bidirectional reflectance distribution function (BRDF). It captures the material properties of an object at {right arrow over (x)}.
The recursive integrals in the rendering equation are usually evaluated using a MC approximation. To compute the pixel's color, light paths are randomly sampled throughout the different bounces. The MC estimate of the color of a pixel i may be denoted as the mean of n independent samples pi,k from the pixel's sample distribution i as follows,
The MC approximated
In unbiased path tracing, the mean of i equals {tilde over (p)}i, and its variance depends on several factors. One cause might be that light rays sometimes just hit an object, and sometimes just miss it, or that they sometimes hit a light source, and sometimes not. This makes scenes with indirect lighting and many reflective objects particularly difficult to render. In these cases, the sample distribution is very skewed, and the samples pi,k can be orders of magnitude apart.
The variance of the MC estimate
Because the variance decreases linearly with respect to n, the expected error √{square root over (Var[
To deal with the slow convergence of MC renderings, several denoising techniques have been proposed to reduce the variance of rendered pixel colors by leveraging spatial redundancy in images. Denoising algorithms may be classified into a priori methods and a posteriori methods. The difference between the two categories is that a priori methods make use of analytical models based on intricate knowledge of the 3D scene, such as analytical material descriptions and geometry descriptions. A posteriori denoisers, on the other hand, operate from per-pixel statistics such as the mean and variance of the sample colors and possibly statistics of guiding features recorded during rendering, such as normal directions, texture information, direct visibility, and camera depth. The aim for both kinds of denoising approaches is to estimate the ground truth pixel colors {tilde over (p)}i achieved when the number of samples goes to infinity. Embodiments of the present invention use a posteriori denoising techniques.
Most existing a posteriori denoisers estimate {circumflex over (p)}i by a weighted sum of the observed pixels
{circumflex over (p)}i=
where i is a region (e.g. a square region) around pixel i and w(i, k)=1. The weights w(i, k) follow from different kinds of weighted regressions on i.
Most existing denoising methods build on the idea of using generic non-linear image-space filters and auxiliary feature buffers as a guide to improve the robustness of the filtering process. One important development was to leverage noisy auxiliary buffers in a joint bilateral filtering scheme, where the bandwidths of the various auxiliary features are derived from the sample statistics. One application of these ideas was to use the non-local means filter in a joint filtering scheme. The appeal of the non-local means filter for denoising MC renderings is largely due to its versatility.
Recently, it was shown that joint filtering methods, such as those discussed above, can be interpreted as linear regressions using a zero-order model, and that more generally most state-of-the-art MC denoising techniques are based on a linear regression using a zero- or first-order model. Methods leveraging a first-order model have proved to be very useful for MC denoising, and while higher-order models have also been explored, it must be done carefully to prevent overfitting to the input noise.
Embodiments of the present invention use machine learning instead of a fixed filter, which has been shown to perform on par with state-of-the-art image filters. The deep CNN according to embodiments of the present invention can offer powerful non-linear mappings without overfitting, by learning the complex relationship between noisy and reference data across a large training set. The methods implicitly learn the filter itself and therefore can produce better results.
In supervised machine learning, the aim may be to create models that accurately predict the value of a response variable as a function of explanatory variables. Such a relationship is typically modeled by a function that estimates the response variable y as a function ŷ=ƒ({right arrow over (x)},{right arrow over (w)}) of the explanatory variables {right arrow over (x)} and tunable parameters {right arrow over (w)} that are adjusted to make the model describe the relationship accurately. The parameters {right arrow over (w)} are learned from data. They are set to minimize a cost function, or loss, L(train,{right arrow over (w)}) over a training set train, which is typically the sum of errors on the entries of the dataset:
where l is a per-element loss function. The optimal parameters may satisfy
Typical loss functions for continuous variables are the quadratic or L2 loss l2 (y,ŷ)=(y−ŷ)2 and the Li loss l1 (y,ŷ)=|y−ŷ|.
Common issues in machine learning may include overfitting and underfitting. In overfitting, a statistical model describes random error or noise in the training set instead of the underlying relationship. Overfitting occurs when a model is excessively complex, such as having too many parameters relative to the number of observations. A model that has been overfit has poor predictive performance, as it overreacts to minor fluctuations in the training data. Underfitting occurs when a statistical model or machine learning algorithm cannot capture the underlying trend of the data. Underfitting would occur, for example, when fitting a linear model to non-linear data. Such a model may have poor predictive performance.
To control over-fitting, the data in a machine learning problem may be split into three disjoint subsets: the training set train, a test set test, and a validation set val. After a model is optimized to fit train, its generalization behavior can be evaluated by its loss on test. After the best model is selected based on its performance on test, it is ideally re-evaluated on a fresh set of data val.
Neural networks are a general class of models with potentially large numbers of parameters that have shown to be very useful in capturing patterns in complex data. The model function ƒ of a neural network is composed of atomic building blocks called “neurons” or nodes. A neuron ni has inputs {right arrow over (x)}i and an scalar output value yi, and it computes the output as
yi=ni({right arrow over (x)}i,{right arrow over (w)}i)=ϕi({right arrow over (x)}i·{right arrow over (w)}i), (8)
where {right arrow over (w)}i are the neuron's parameters and {right arrow over (x)}i is augmented with a constant feature. ϕ is a non-linear activation function that is important to make sure a composition of several neurons can be non-linear. Activation functions can include hyperbolic tangent tan h(x), sigmoid function ϕsigmoid (x)=(1+exp(−x))−1, and the rectified linear unit (ReLU) ϕReLU(x)=max(x, 0).
A neural network is composed of layers of neurons. The input layer N0 contains the model's input data {right arrow over (x)}, and the neurons in the output layer predict an output {circumflex over ({right arrow over (y)})}. In a fully connected layer Nk, the inputs of a neuron are the outputs of all neurons in the previous layer Nk-1.
The activity of a layer Ni of a fully-connected feed forward neural network can be conveniently written in matrix notation:
{right arrow over (N)}0={right arrow over (x)}, (9)
{right arrow over (N)}k=ϕk(Wk{right arrow over (N)}k-1)∀k∈[1,n), (10)
where Wk is a matrix that contains the model parameters {right arrow over (w)}j for each neuron in the layer as rows. The activation function ϕk operates element wise on its vector input.
1. Multilayer Perception Neural Networks
There are different ways in which information can be processed by a node, and different ways of connecting the nodes to one another. Different neural network structures, such as multilayer perceptron (MLP) and convolutional neural network (CNN), can be constructed by using different processing elements and/or connecting the processing elements in different manners.
The input layer can include one or more input nodes. The one or more input nodes can each receive data from a source that is remote from the MLP. In some examples, each input node of the one or more input nodes can correspond to a value for a feature of a pixel. Exemplary features can include a color value of the pixel, a shading normal of the pixel, a depth of the pixel, an albedo of the pixel, or the like. In such examples, if an image is 10 pixels by 10 pixels, the MLP can include 100 input nodes multiplied be the number of features. For example, if the features include color values (e.g., red, green, and blue) and shading normal (e.g., x, y, and z), the MLP can include 600 input nodes (10×10×(3+3)).
A first hidden layer of the one or more hidden layers can receive data from the input layer. In particular, each hidden node of the first hidden layer can receive data from each node of the input layer (sometimes referred to as being fully connected). The data from each node of the input layer can be weighted based on a learned weight. In some examples, each hidden layer can be fully connected to another hidden layer, meaning that output data from each hidden node of a hidden layer can be input to each hidden node of a subsequent hidden layer. In such examples, the output data from each hidden node of the hidden layer can be weighted based on a learned weight. In some examples, each learned weight of the MLP can be learned independently, such that a first learned weight is not merely a duplicate of a second learned weight.
A number of nodes in a first hidden layer can be different than a number of nodes in a second hidden layer. A number of nodes in a hidden layer can also be different than a number of nodes in the input layer (e.g., as in the neural network illustrated in
A final hidden layer of the one or more hidden layers can be fully connected to the output layer. In such examples, the final hidden layer can be the first hidden layer or another hidden layer. The output layer can include one or more output nodes. An output node can perform one or more operations described above (e.g., non-linear operations) on data provided to the output node to produce a result to be provided to a system remote from the MLP.
2. Convolutional Neural Networks
In a fully connected layer, the number of parameters that connect the layer with the previous one is the product of the number of neurons in the layers. When a color image of size w×h×3 is the input of such a layer, and the layer has a similar number of output-neurons, the number of parameters can quickly explode and become infeasible as the size of the image increases.
To make neural networks for image processing more tractable, convolutional networks (CNNs) simplify the fully connected layer by making the connectivity of neurons between two adjacent layers sparse.
In recent years, CNNs have emerged as a popular model in machine learning. It has been demonstrated that CNNS can achieve state-of-the-art performance in a diverse range of tasks such as image classification, speech processing, and many others. CNNs have also been used a great deal for a variety of low-level, image-processing tasks. In particular, several works have considered the problem of natural image denoising and the related problem of image super-resolution. However, a simple application of a convolutional network to MC denoising may expose a wide range of issues. For example, training a network to compute a denoised color from only a raw, noisy color buffer may cause overblurring, since the network cannot distinguish between scene noise and scene detail. Moreover, since the rendered images have high dynamic range, direct training may cause unstable weights (e.g., extremely large or small values) that can cause bright ringing and color artifacts in the final image.
By preprocessing features as well as exploiting the diffuse/specular decomposition, denoising methods according to embodiments of the present invention can preserve important detail while denoising the image. In addition, some embodiments of the present invention use a novel kernel prediction architecture to keep training efficient and stable.
According to some embodiments of the present invention, techniques based on machine learning, and more particularly based on convolutional neural networks, are used to denoise Monte Carlo path-tracing renderings. The techniques disclosed herein may use the same inputs used in conventional denoising techniques based on linear regression or zero-order and higher-order regressions. The inputs may include, for example, pixel color and its variance, as well as a set of auxiliary buffers (and their corresponding variances) that encode scene information (e.g., surface normal, albedo, depth, and the like).
Before introducing the denoising framework, some mathematical notations may be defined as follows. The samples output by a typical MC renderer can be averaged down into a vector of per-pixel data,
xp={cp,fp}, where xp∈3+D (11)
where, cp represents the red, green and blue (RGB) color channels, and fp is a set of D auxiliary features (e.g., the variance of the color feature, surface normals, depth, albedo, and their corresponding variances).
The goal of MC denoising may be defined as obtaining a filtered estimate of the RGB color channels ĉp for each pixel p that is as close as possible to a ground truth result
{circumflex over (θ)}p=argminθl(
where the denoised value is ĉp=g(Xp; {circumflex over (θ)}p), and l(
Since ground truth values
{right arrow over (θ)}p=argminθ(cq−θTϕ(xq))2ω(xp,xq), (13)
where ω(xp,xq) is the regression kernel. The final denoised pixel value may be computed as ĉp={circumflex over (θ)}pTϕ(xp). The regression kernel ω(xp, xq) may help to ignore values that are corrupted by noise, for example by changing the feature bandwidths in a joint bilateral filter. Note that ω could potentially also operate on patches, rather than single pixels, as in the case of a joint non-local means filter.
As discussed above, some of the existing denoising methods can be classified as zero-order methods with ϕ0(xq)=1, first-order methods with ϕ1(xq)=[1; xq], or higher-order methods where ϕm(xq) enumerates all the polynomial terms of xq up to degree m (see Bitterli et al. for a detailed discussion). The limitations of these MC denoising approaches can be understood in terms of bias-variance tradeoff. Zero-order methods are equivalent to using an explicit function such as a joint bilateral or non-local means filter. These represent a restrictive class of functions that trade reduction in variance for a high modeling bias. Although a well-chosen weighting kernel, ω, can yield good performance, such approaches are fundamentally limited by their explicit filters. MC denosing methods according to embodiments of the present invention may remove these limitations by making the filter kernel more flexible and powerful.
Using a first- or higher-order regression may increase the complexity of the function, and may be prone to overfitting as {circumflex over (θ)}p is estimated locally using only a single image and can easily fit to the noise. To address this problem, Kalantari et al. proposed to take a supervised machine learning approach to estimate g using a dataset of N example pairs of noisy image patches and their corresponding reference color information, ={(X1,
In this case, the parameters, θ, are optimized with respect to all the reference examples, not the noisy information as in Eq. (13). If {circumflex over (θ)} is estimated on a large and representative training data set, then it can adapt to a wide variety of noise and scene characteristics.
However, the approach of Kalantari et al. has several limitations, the most important of which is that the function g(Xi; θ) was hardcoded to be either a joint bilateral or joint non-local means filter with bandwidths provided by a multi-layer perceptron (MLP) with trained weights θ. Because the filter was fixed, the resulting system lacked the flexibility to handle the wide range of Monte Carlo noise that can be encountered in production environments.
To address this limitation, embodiments of the present invention extend the supervised machine learning approach to handle significantly more complex functions for g, which results in more flexibility while still avoiding overfitting. Such methods can reduce modeling bias while simultaneously ensuring the variance of the estimator is kept under control for a suitably large N. This can enable the resulting denoiser to generalize well to images not used during training.
There are three challenges inherent to a supervised machine learning framework that may be considered for developing a better MC denoising system. First, it may be desirable that the function, g, is flexible enough to capture the complex relationship between input data and reference colors for a wide range of scenarios. Second, the choice of loss function, l, can be important. Ideally, the loss should capture perceptually important differences between the estimated and reference color. However, it should also be easy to evaluate and optimize. Third, in order to avoid overfitting, it may be desirable to have a large training dataset . For models using reference images rendered at high sample counts, obtaining a large training dataset can be computationally expensive. Furthermore, in order to generalize well, the models may need examples that are representative of the various effects that can lead to particular noise-patterns to be identified and removed.
Embodiments of the present invention model the denoising function gin Eq. (14) with a deep convolutional neural network (CNN). Since each layer of a CNN applies multiple spatial kernels with learnable weights that are shared over the entire image space, they are naturally suited for the denoising task and have been previously used for natural image denoising. In addition, by joining many such layers together with activation functions, CNNs may be able to learn highly nonlinear functions of the input features, which can be advantageous for obtaining high-quality outputs.
The neural network 400 can further include one or more hidden layers 420. In an exemplary embodiment, the neural network 400 can include 8 hidden layers 420a-420h, as illustrated in
The neural network 400 further includes an output layer 430. The output layer 430 can include one or more output nodes. In some embodiments, the output of the convolutional neural network can be an image in a color space (e.g., RGB). For example, the output layer 430 may include 65×65×3 nodes, which represent the RGB color values for 65×65 pixels, as illustrated in
During the training of the neural network 400, the output image 430 can be compared to a ground truth 440 to compute an error function or a loss function. In some embodiments, the ground truth can be an MC rendered image of the same scene as the input image but traced with more samples per pixel (ssp), so that it is less noisy than the input image. In some other embodiments, the ground truth can be generated by applying a filter to a noisy input image. The loss function can be computed by calculating a norm of a vector between the output image 430 and the ground truth 440, where each element of the vector is a difference between values (e.g., color or intensity) of corresponding pixels in the two images. For example, the norm can be a one-norm (also known as the L1 norm), which is defined as the sum of the absolute values of its components. As another example, the norm can be a two-norm (also known as the L2 norm), which is defined as the square root of the sum of the squares of the differences of its components. Selection of the loss function will be discussed in more detail below.
Based on the loss function, a back-propagation process can be executed through the neural network 400 to update weights of the neural network in order to minimize the loss function. In some examples, the back-propagation can begin near the end of the neural network 400 and proceed to the beginning.
According to some embodiments, the neural network 400 can be a deep fully convolutional network with no fully-connected layers to keep the number of parameters reasonably low. This may reduce the danger of overfitting and speed up both training and inference. Stacking many convolutional layers together can effectively increase the size of the input receptive field to capture more context and long-range dependencies.
In each layer 1, the neural network may apply a linear convolution to the output of the previous layer, adds a constant bias, and then apply an element-wise nonlinear transformation ƒl(·), also known as the activation function, to produce output zl=ƒl(Wl*zl-1+bl). Here, Wl and bl are tensors of weights and biases, respectively (the weights in W are shared appropriately to represent linear convolution kernels), and zl-1 is the output of the previous layer.
For the first layer, one may set z0=Xp, which provides the block of per-pixel vectors around pixel p as input to the neural network. In some embodiments, one may use rectified linear unit (ReLU) activations, ƒl(a)=max(0, a), for all layers except the last layer, L. For the last layer L, one may use ƒL (a)=a (i.e., the identity function). Despite their C1 discontinuity, ReLUs have been shown to achieve good performance in many tasks and are known to encourage the (non-convex) optimization procedure to find better local minima. The weights and biases θ={(W1, b1), . . . , (WL,bL)}, represent the trainable parameters of g for an L-layer CNN.
According to some embodiments, repeated architectures may be used in a neural network framework. The motivation to use repeated architectures are inspired by the work of Yang. They observe that the quality of a convolutional denoiser with a small spatial support, such as the one presented by Jain, degrades quickly as the variance of the added noise increases. A larger spatial support is required to effectively remove large amounts of noise. In the default convolutional architecture, this increases the amount of model parameters, resulting in more difficult training and a need for more training data. To tackle this issue, embodiments of the present invention leverage the fact that many denoising algorithms rely on denoising frequency sub-bands separately with the same algorithm, and then combining those frequencies. Denoising may be performed by applying an iterative procedure si+1=si+D(si), n times, where si is the input of denoising step i. The denoising function D is the same at each step. This procedure may be referred to as a ‘recurrent residual’ architecture. This idea may be separated into two components, “recurrent” and “residual” as follows,
According to some embodiments, the two components are separately evaluated, since they can be used independently. To avoid confusion with the popular recurrent neural networks, the “recurrent” component is referred herein as the “repeated” component.
Repeating blocks in a neural network may intuitively make sense for image denoising, as the idea may be analogus to seeing denoising as an iterative process, gradually improving the image quality.
More particularly, a residual block in a feed-forward neural network adds a “skip connection” between its input and its output, as illustrated in
{right arrow over (o)}=R({right arrow over (i)})
where {right arrow over (ι)} and {right arrow over (o)} are the input and output of the block, R is the block's function without skip connection, and {right arrow over (w)} represents the set of model parameters of R. When R is a traditional convolutional neural network, and all parameters {right arrow over (w)}=0, the block represents the identity function.
Residual blocks for denoising can be motivated by intuition as well. Assume a network with only one block. When the noisy image is unbiased (e.g., its distribution has zero mean), the expected required “update” from a residual block is zero as well. This makes the output centered around zero across pixels.
According to some embodiments, the function g outputs denoised color values using two alternative architectures: a direct-prediction convolutional network (DPCN) or a kernel-prediction convolutional network (KPCN).
1. Direct Prediction Convolutional Network (DPCN)
To produce the denoised image using direct prediction, one may choose the size of the final layer L of the network to ensure that for each pixel p, the corresponding element of the network output, zpL∈3 is the denoised color:
ĉp=gdirect(Xp;θ)=zpL. (17)
Direct prediction can achieve good results in some cases. However, it is found that the direct prediction method can make optimization difficult in some cases. For example, the magnitude and variance of the stochastic gradients computed during training can be large, which slows convergence. In some cases, in order to obtain good performance, the DPCN architecture can require over a week of training.
2. Kernel Prediction Convolutional Network (KPCN)
According to some embodiments of the present invention, instead of directly outputting a denoised pixel, ĉp, the final layer of the network outputs a kernel of scalar weights that is applied to the noisy neighborhood of p to produce ĉp. Letting (p) be the k×k neighborhood centered around pixel p, the dimensions of the final layer can be chosen so that the output is zpL∈k×k Note that the kernel size k may be specified before training along with the other network hyperparameters (e.g., layer size, CNN kernel size, and so on), and the same weights are applied to each RGB color channel.
Defining [zpL]q as the q-th entry in the vector obtained by flattening zpL, one may compute the final, normalized kernel weights as,
The denoised pixel color may be computed as,
ĉp=gweighted(Xp;θ)=cqwpq. (19)
The kernel weights can be interpreted as including a softmax activation function on the network outputs in the final layer over the entire neighborhood. This enforces that 0≤wpq≤1, ∀q∈(p) and wpq=1.
This weight normalization architecture can provide several advantages. First, it may ensure that the final color estimate always lies within the convex hull of the respective neighborhood of the input image. This can vastly reduce the search space of output values as compared to the direct-prediction method and avoids potential artifacts (e.g., color shifts). Second, it may ensure that the gradients of the error with respect to the kernel weights are well behaved, which can prevent large oscillatory changes to the network parameters caused by the high dynamic range of the input data. Intuitively, the weights need only encode the relative importance of the neighborhood; the network does not need to learn the absolute scale. In general, scale-reparameterization schemes have recently proven to be beneficial for obtaining low-variance gradients and speeding up convergence. Third, it can potentially be used for denoising across layers of a given frame, a common case in production, by applying the same reconstruction weights to each component.
As described further below, although both direct prediction method and kernal prediction method can converge to a similar overall error, the kernel prediction method can converge faster than the direct prediction method.
Denoising the color output of a MC renderer in a single filtering operation can be prone to overblurring. This may be in part because the various components of the image have different noise characteristics and spatial structure, which can lead to conflicting denoising constraints. According to some embodiments of the present invention, to mitigate this issue, the input image can be decomposed into diffuse and specular components as in Zimmer et al. The diffuse and specular components are then independently preprocessed, filtered, and postprocessed, before recombining them to obtain the final image.
1. Diffuse-Component Denoising
The diffuse color—the outgoing radiance due to diffuse reflection—is usually well behaved and may have low dynamic ranges. Thus, training the diffuse network can be stable and the resulting network can yield good performance without color preprocessing. However, it may be advantageous to factor out the noisy albedo from the diffuse color in a preprocessing step. Albedo, also referred to as texture, is a measure of local diffuse reflecting power of a surface.
{tilde over (c)}diffuse=cdiffuseØ(falbedo+ε), (20)
where Ø is an element-wise (Hadamard) division, and ε is a constant. In one example, ε=0.00316.
The method may further include normalizing the effective irradiance as a preprocessing step (1022). The normalization step is optional.
The method may further include extracting gradients from the effective irradiance as another preprocessing step (1022).
The method may further include denoising the normalized effective irradiance through the diffuse network 1024, and reconstructing a denoised effective irradiance (1026). Because the effective irradiance is generally smoother than the original irrandiance, factoring out the albedo before denoising may allow larger filtering kernels to be used in the diffuse network 1024. The diffuse network 1024 may be trained using diffuse references.
The method may further include multiplying back the albedo to the denoised effective irrandiance to obtain a denoised irrandiance (1028) as,
ĉdiffuse=(falbedo+ε)⊙{tilde over (c)}diffuse, (21)
where ⊙ is an element-wise (Hadamard) product, thereby restoring all texture detail.
In some embodiments, the albedo data used in the multiplication step 1028 may be extracted from a separate, higher sampling rate pass so that they have relatively low noise. In practice, the low-noise albedo can be generated from either a fast high-sample count renderer that ignores illumination calculations, or alternatively from a separate denoising process (e.g., pre-filtering).
2. Specular-Component Denoising
Denoising the specular color can be a challenging problem due to the high dynamic range of specular and glossy reflections. The values in one image can span as much as several orders of magnitude in some cases. The large variations and arbitrary correlations in input images can make the iterative optimization process highly unstable. Thus, according to some embodiments of the present invention, a logarithmic transform is applied to the specular color as a preprocessing step.
{tilde over (c)}specular=log(ε+Cspecular), (22)
where ε is a constant that can have a value of one or less than one.
The logarithmic transform can significantly reduce the range of color values, and thus can significantly improve denoising performance as well as avoid artifacts in regions with high dynamic range.
The method may further include normalizing the log-transformed specular color and extracting gradients from the normalized specular color as further preprocessing steps (1132). The normalization step is optional.
The method may further include denoising the normalized specular color through the specular network 1134, and reconstructing a denoised specular color (1136). The specular network 1134 may be trained using specular references.
The method may further include performing an inverse logarithmic transformation to the denoised specular color (1138) to obtain a final denoised specular component as,
ĉspecular=exp({tilde over (c)}specular)−ε. (23)
3. Fine Tuning the Final Image
The denoised diffuse component and specular component can then be combined to obtain a final denoised image as,
ĉ=ĉdiffuse+ĉspecular. (24)
In some embodiments, the diffuse network 924 and the specular network 1134 are pre-trained separately on the diffuse references and specular references, respectively. Afterwards, Eq. (24) may be applied to obtain a final denoised image. Fine tuning of the complete framework may be then performed by minimizing the error of the final image for additional iterations. This may allow for recovering missing details and obtaining sharper results.
1. Input data and preprocessing
Training a deep neural network may require a large and representative training dataset in order to learn the complex relationship between input and output while avoiding overfitting. In some embodiments, 600 representative frames sampled from a first movie generated using RenderMan's path-tracer are used as a training dataset. Twenty five diverse frames from a second movie and a third movie are used as a test dataset. These frames contain effects such as motion blur, depth of field, glossy reflections, and global illumination. They significantly differ in style and content, which can be helpful in testing how the denoising methods can generalize to new inputs. For example, the test dataset can include mostly outdoor scenes with a wide-range of color palettes that are very different from the first movie.
In some embodiments, the reference images (i.e., the ground truths) for training are rendered with 1024 samples per pixel (spp). Removing the residual noise from these images using standard MC denoisers is considered. But it is found that the networks performed better when trained on images with uncorrelated residual noise rather than correlated errors and artifacts introduced by the additional denoising step.
In some embodiments, to evaluate the denoising methods, training, validation, and testing are performed on inputs rendered at a fixed 128 spp (for production-level quality) and 32 spp (for pre-visualization). For each scene, the renderer outputs the diffuse and specular RGB color buffers cdiffuse and cspecular, the corresponding per-pixel color variances σdiffuse2 and σspecular2, the feature buffers f, consisting of surface normals (3 channels), albedo (3 channels), depth (1 channel), and the corresponding per-pixel feature variances σf2. In some embodiments, variances of three channels are converted to a single channel by computing its luminance. Thus, there may be two channels for the color variance (for diffuse and specular) and three channels for the feature variance.
In some embodiments, the raw data is preprocessed to provide the network with more useful features that facilitate learning and convergence. For example, since the depth values can have arbitrary ranges, they are linearly scaled to the range [0,1] for each frame. The color buffers may also be preprocessed as described above to obtain {tilde over (c)}diffuse and {tilde over (c)}specular. In addition, the gradients in both x and y directions, Gx and Gy, may be extracted for all buffers. It is found that the gradients can highlight important details in the images, which can facilitate training.
Since the color buffers are preprocessed, an appropriate transformation may need to be applied to their variances to make them valid. In general, if a transformation, h, is applied to a random variable, X, a corresponding transformation can be approximated on its second moment using a Taylor series expansion: σh(X)≈(h′(μX))2σX2, where μX and σX2 are the mean and variance of X, respectively, and h′ is the derivative with respect to X. Thus, for the diffuse and specular components, the modified variance may be given by,
({tilde over (σ)}diffuse)2≈σdiffuse2Ø(falbedo+ε)2, (25)
and
({tilde over (σ)}specular)2≈σspecular2Ø({tilde over (c)}specular)2, (26)
respectively. After this processing, the network input may be reconstructed as,
x={{tilde over (c)},Gx({{tilde over (c)},f}),Gy({{tilde over (c)},f}),{tilde over (σ)}2,σf2}, (27)
where {tilde over (c)} and {tilde over (σ)}2 are either diffuse or specular.
a) Importance Sampling
In some embodiments, after preprocessing the input data at each pixel, the images are split into 65×65 patches that are sampled, shuffled, and used to train the network. Although uniform sampling could be used to select the patches from each frame, it is found that this can be suboptimal as the network would be frequently shown simple cases containing smooth regions that are straightforward to denoise. Therefore, it may be advantageous to expose the network to more difficult cases and and make it learn how to handle them.
In some embodiments, the following sampling strategy may be used. For example, to obtain 400 patches for each 1920×1080 frame, “dart throwing” may be initially used to find candidate patches, which are then pruned using a probability density function (PDF) based on the variance of the noisy color buffer and the shading normals. Using the color ensures that we target regions that have lots of noise, detail, or texture, while using the normal buffer provides examples with geometric complexity. To provide a proper balance between the easy and hard cases and avoid biasing the network, a patch may be automatically accepted after it has been rejected a certain number of times.
2. Training
In an exemplary embodiment, eight hidden layers (i.e., nine total convolutions, so L=9) with 100 kernels of 5×5 in each layer are used for each network. For a kernel-prediction convolutional network (KPCN), an output kernel with size k=21×21 is used. Weights of the networks for both the 128 and 32 spp datasets are initialized using the Xavier method (see Glorot and Bengio). For example, random values can be generated from a uniform distribution with a variance determined by the number of nodes between layers.
The specular and diffuse networks are trained independently using the l1 (absolute value) error metric. It is observed that this loss function offered the best perceptual quality while still being fast to compute and optimize (see further discussions below). The loss for the diffuse network may be computed between the reconstructed irradiance (i.e., before multiplying with the albedo) and the albedo-factorized reference image. The loss for the specular network may be computed in the log domain.
The networks may be optimized using the Adaptive Moment Estimation (ADAM) optimizer (see Kingma and Ba) in TensorFlow (see Abadi) with a learning rate of 10−5 and mini-batches of size 5. Each network may be pre-trained for approximately 750 thousands iterations over the course of 1.5 days on an Nvidia Quadro M6000 GPU. Afterwards, the system is combined and fine-tuned as discussed above for another 0.5 days or 250 thousands iterations.
3. Results
Test results demonstrate that favorable results can be achieved using the denoising methods disclosed herein relative to existing denoisers on 32 spp production-quality data both perceptually and quantitatively. As an example,
As another example,
As a further example,
To demonstrate that the methods disclosed herein can perform well on noisier data from a different rendering system, denoising is performed on publicly available Tungsten scenes.
4. Case Studies
In some embodiments, various design choices made in the network architecture are evaluated using hold-out frames from a movie and test frames from another movie. For example, the choice of loss function, the comparison of direct prediction convolutional network (DPCN) and kernal prediction convolutional network (KPCN), the effects of decomposition of diffuse and specular components, and the effects of including additional features (e.g., shading normal, depth, albedo) are studied.
a) Loss Functions
The choice of loss function can be an important aspect of a network design. For MC denoising, ideally a loss function should reflects the perceptual quality of the image relative to the reference. To evaluate the behavior of various error metrics, the network was optimized with different loss functions including: l1, relative l1, l2, relative l2, and structural similarity index (SSIM). The denoising performance is evaluated in terms of l1, relative l1, l2, relative l2, and SSIM in turn.
As illustrated in
It is interesting to note that sometimes the network optimized on a given error is not always the best performing one. For example, the network trained on l1 error performs better on l2 than the network optimized on l2. One possible reason for this is that l2 may be sensitive to outliers, such as fireflies, or extremely bright specular highlights that significantly contribute to the error. Trying to compensate for these regions may sacrifice performance elsewhere, while networks trained on different losses can be more robust to outliers.
b) Comparison of Direct Prediction Convolutional Network (DPCN) and Kernel Prediction Convolutional Network (KPCN)
c) Effects of Decomposition and Including Additional Features
In some embodiments, the effects of the various additions to the denoising framework disclosed herein are evaluated.
The one or more design computers 2610 can include hardware and software elements configured for designing CGI and assisting with computer-aided animation. Each of the one or more design computers 2610 may be embodied as a single computing device or a set of one or more computing devices. Some examples of computing devices are PCs, laptops, workstations, mainframes, cluster computing system, grid computing systems, cloud computing systems, embedded devices, computer graphics devices, gaming devices and consoles, consumer electronic devices having programmable processors, or the like. The one or more design computers 2610 may be used at various stages of a production process (e.g., pre-production, designing, creating, editing, simulating, animating, rendering, post-production, etc.) to produce images, image sequences, motion pictures, video, audio, or associated effects related to CGI and animation.
In one example, a user of the one or more design computers 2610 acting as a modeler may employ one or more systems or tools to design, create, or modify objects within a computer-generated scene. The modeler may use modeling software to sculpt and refine a neutral 3D model to fit predefined aesthetic needs of one or more character designers. The modeler may design and maintain a modeling topology conducive to a storyboarded range of deformations. In another example, a user of the one or more design computers 2610 acting as an articulator may employ one or more systems or tools to design, create, or modify controls or animation variables (avars) of models. In general, rigging is a process of giving an object, such as a character model, controls for movement, therein “articulating” its ranges of motion. The articulator may work closely with one or more animators in rig building to provide and refine an articulation of the full range of expressions and body movement needed to support a character's acting range in an animation. In a further example, a user of design computer 2610 acting as an animator may employ one or more systems or tools to specify motion and position of one or more objects over time to produce an animation.
Object library 2620 can include elements configured for storing and accessing information related to objects used by the one or more design computers 2610 during the various stages of a production process to produce CGI and animation. Some examples of object library 2620 can include a file, a database, or other storage devices and mechanisms. Object library 2620 may be locally accessible to the one or more design computers 2610 or hosted by one or more external computer systems.
Some examples of information stored in object library 2620 can include an object itself, metadata, object geometry, object topology, rigging, control data, animation data, animation cues, simulation data, texture data, lighting data, shader code, or the like. An object stored in object library 2620 can include any entity that has an n-dimensional (e.g., 2D or 3D) surface geometry. The shape of the object can include a set of points or locations in space (e.g., object space) that make up the object's surface. Topology of an object can include the connectivity of the surface of the object (e.g., the genus or number of holes in an object) or the vertex/edge/face connectivity of an object.
The one or more object modeling systems 2630 can include hardware and/or software elements configured for modeling one or more objects. Modeling can include the creating, sculpting, and editing of an object. In various embodiments, the one or more object modeling systems 2630 may be configured to generate a model to include a description of the shape of an object. The one or more object modeling systems 2630 can be configured to facilitate the creation and/or editing of features, such as non-uniform rational B-splines or NURBS, polygons and subdivision surfaces (or SubDivs), that may be used to describe the shape of an object. In general, polygons are a widely used model medium due to their relative stability and functionality. Polygons can also act as the bridge between NURBS and SubDivs. NURBS are used mainly for their ready-smooth appearance and generally respond well to deformations. SubDivs are a combination of both NURBS and polygons representing a smooth surface via the specification of a coarser piecewise linear polygon mesh. A single object may have several different models that describe its shape.
The one or more object modeling systems 2630 may further generate model data (e.g., 2D and 3D model data) for use by other elements of system 2600 or that can be stored in object library 2620. The one or more object modeling systems 2630 may be configured to allow a user to associate additional information, metadata, color, lighting, rigging, controls, or the like, with all or a portion of the generated model data.
The one or more object articulation systems 2640 can include hardware and/or software elements configured to articulating one or more computer-generated objects. Articulation can include the building or creation of rigs, the rigging of an object, and the editing of rigging. In various embodiments, the one or more articulation systems 2640 can be configured to enable the specification of rigging for an object, such as for internal skeletal structures or eternal features, and to define how input motion deforms the object. One technique is called “skeletal animation,” in which a character can be represented in at least two parts: a surface representation used to draw the character (called the skin) and a hierarchical set of bones used for animation (called the skeleton).
The one or more object articulation systems 2640 may further generate articulation data (e.g., data associated with controls or animations variables) for use by other elements of system 2600 or that can be stored in object library 2620. The one or more object articulation systems 2640 may be configured to allow a user to associate additional information, metadata, color, lighting, rigging, controls, or the like, with all or a portion of the generated articulation data.
The one or more object animation systems 2650 can include hardware and/or software elements configured for animating one or more computer-generated objects. Animation can include the specification of motion and position of an object over time. The one or more object animation systems 2650 may be invoked by or used directly by a user of the one or more design computers 2610 and/or automatically invoked by or used by one or more processes associated with the one or more design computers 2610.
In various embodiments, the one or more animation systems 2650 may be configured to enable users to manipulate controls or animation variables or utilized character rigging to specify one or more key frames of animation sequence. The one or more animation systems 2650 generate intermediary frames based on the one or more key frames. In some embodiments, the one or more animation systems 2650 may be configured to enable users to specify animation cues, paths, or the like according to one or more predefined sequences. The one or more animation systems 2650 generate frames of the animation based on the animation cues or paths. In further embodiments, the one or more animation systems 2650 may be configured to enable users to define animations using one or more animation languages, morphs, deformations, or the like.
The one or more object animation systems 2650 may further generate animation data (e.g., inputs associated with controls or animation variables) for use by other elements of system 2600 or that can be stored in object library 2620. The one or more object animation systems 2650 may be configured to allow a user to associate additional information, metadata, color, lighting, rigging, controls, or the like, with all or a portion of the generated animation data.
The one or more object simulation systems 2660 can include hardware and/or software elements configured for simulating one or more computer-generated objects. Simulation can include determining motion and position of an object over time in response to one or more simulated forces or conditions. The one or more object simulation systems 2660 may be invoked by or used directly by a user of the one or more design computers 2610 and/or automatically invoked by or used by one or more processes associated with the one or more design computers 2610.
In various embodiments, the one or more object simulation systems 2660 may be configured to enables users to create, define, or edit simulation engines, such as a physics engine or physics processing unit (PPU/GPGPU) using one or more physically-based numerical techniques. In general, a physics engine can include a computer program that simulates one or more physics models (e.g., a Newtonian physics model), using variables such as mass, velocity, friction, wind resistance, or the like. The physics engine may simulate and predict effects under different conditions that would approximate what happens to an object according to the physics model. The one or more object simulation systems 2660 may be used to simulate the behavior of objects, such as hair, fur, and cloth, in response to a physics model and/or animation of one or more characters and objects within a computer-generated scene.
The one or more object simulation systems 2660 may further generate simulation data (e.g., motion and position of an object over time) for use by other elements of system 2600 or that can be stored in object library 2620. The generated simulation data may be combined with or used in addition to animation data generated by the one or more object animation systems 2650. The one or more object simulation systems 2660 may be configured to allow a user to associate additional information, metadata, color, lighting, rigging, controls, or the like, with all or a portion of the generated simulation data.
The one or more object rendering systems 2670 can include hardware and/or software element configured for “rendering” or generating one or more images of one or more computer-generated objects. “Rendering” can include generating an image from a model based on information such as geometry, viewpoint, texture, lighting, and shading information. The one or more object rendering systems 2670 may be invoked by or used directly by a user of the one or more design computers 2610 and/or automatically invoked by or used by one or more processes associated with the one or more design computers 2610. One example of a software program embodied as the one or more object rendering systems 2670 can include PhotoRealistic RenderMan, or PRMan, produced by Pixar Animation Studios of Emeryville, Calif.
In various embodiments, the one or more object rendering systems 2670 can be configured to render one or more objects to produce one or more computer-generated images or a set of images over time that provide an animation. The one or more object rendering systems 2670 may generate digital images or raster graphics images.
In various embodiments, a rendered image can be understood in terms of a number of visible features. Some examples of visible features that may be considered by the one or more object rendering systems 2670 may include shading (e.g., techniques relating to how the color and brightness of a surface varies with lighting), texture-mapping (e.g., techniques relating to applying detail information to surfaces or objects using maps), bump-mapping (e.g., techniques relating to simulating small-scale bumpiness on surfaces), fog/participating medium (e.g., techniques relating to how light dims when passing through non-clear atmosphere or air), shadows (e.g., techniques relating to effects of obstructing light), soft shadows (e.g., techniques relating to varying darkness caused by partially obscured light sources), reflection (e.g., techniques relating to mirror-like or highly glossy reflection), transparency or opacity (e.g., techniques relating to sharp transmissions of light through solid objects), translucency (e.g., techniques relating to highly scattered transmissions of light through solid objects), refraction (e.g., techniques relating to bending of light associated with transparency), diffraction (e.g., techniques relating to bending, spreading and interference of light passing by an object or aperture that disrupts the ray), indirect illumination (e.g., techniques relating to surfaces illuminated by light reflected off other surfaces, rather than directly from a light source, also known as global illumination), caustics (e.g., a form of indirect illumination with techniques relating to reflections of light off a shiny object, or focusing of light through a transparent object, to produce bright highlights on another object), depth of field (e.g., techniques relating to how objects appear blurry or out of focus when too far in front of or behind a focal plane), motion blur (e.g., techniques relating to how objects appear blurry due to high-speed motion, or the motion of the camera), non-photorealistic rendering (e.g., techniques relating to rendering of scenes in an artistic style, intended to look like a painting or drawing), or the like.
The one or more object rendering systems 2670 may further render images (e.g., motion and position of an object over time) for use by other elements of system 2600 or that can be stored in object library 2620. The one or more object rendering systems 2670 may be configured to allow a user to associate additional information or metadata with all or a portion of the rendered image.
Computer system 2700 may include familiar computer components, such as one or more data processors or central processing units (CPUs) 2705, one or more graphics processors or graphical processing units (GPUs) 2710, memory subsystem 2715, storage subsystem 2720, one or more input/output (I/O) interfaces 2725, communications interface 2730, or the like. Computer system 2700 can include system bus 2735 interconnecting the above components and providing functionality, such connectivity as inter-device communication.
The one or more data processors or central processing units (CPUs) 2705 can execute logic or program code or for providing application-specific functionality. Some examples of CPU(s) 2705 can include one or more microprocessors (e.g., single core and multi-core) or micro-controllers, one or more field-gate programmable arrays (FPGAs), and application-specific integrated circuits (ASICs). As user herein, a processor includes a multi-core processor on a same integrated chip, or multiple processing units on a single circuit board or networked.
The one or more graphics processor or graphical processing units (GPUs) 2710 can execute logic or program code associated with graphics or for providing graphics-specific functionality. GPUs 2710 may include any conventional graphics processing unit, such as those provided by conventional video cards. In various embodiments, GPUs 2710 may include one or more vector or parallel processing units. These GPUs may be user programmable, and include hardware elements for encoding/decoding specific types of data (e.g., video data) or for accelerating 2D or 3D drawing operations, texturing operations, shading operations, or the like. The one or more graphics processors or graphical processing units (GPUs) 2710 may include any number of registers, logic units, arithmetic units, caches, memory interfaces, or the like.
Memory subsystem 2715 can store information, e.g., using machine-readable articles, information storage devices, or computer-readable storage media. Some examples can include random access memories (RAM), read-only-memories (ROMS), volatile memories, non-volatile memories, and other semiconductor memories. Memory subsystem 2715 can include data and program code 2740.
Storage subsystem 2720 can also store information using machine-readable articles, information storage devices, or computer-readable storage media. Storage subsystem 2720 may store information using storage media 2745. Some examples of storage media 2745 used by storage subsystem 2720 can include floppy disks, hard disks, optical storage media such as CD-ROMS, DVDs and bar codes, removable storage devices, networked storage devices, or the like. In some embodiments, all or part of data and program code 2740 may be stored using storage subsystem 2720.
The one or more input/output (I/O) interfaces 2725 can perform I/O operations. One or more input devices 2750 and/or one or more output devices 2755 may be communicatively coupled to the one or more I/O interfaces 2725. The one or more input devices 2750 can receive information from one or more sources for computer system 2700. Some examples of the one or more input devices 2750 may include a computer mouse, a trackball, a track pad, a joystick, a wireless remote, a drawing tablet, a voice command system, an eye tracking system, external storage systems, a monitor appropriately configured as a touch screen, a communications interface appropriately configured as a transceiver, or the like. In various embodiments, the one or more input devices 2750 may allow a user of computer system 2700 to interact with one or more non-graphical or graphical user interfaces to enter a comment, select objects, icons, text, user interface widgets, or other user interface elements that appear on a monitor/display device via a command, a click of a button, or the like.
The one or more output devices 2755 can output information to one or more destinations for computer system 2700. Some examples of the one or more output devices 2755 can include a printer, a fax, a feedback device for a mouse or joystick, external storage systems, a monitor or other display device, a communications interface appropriately configured as a transceiver, or the like. The one or more output devices 2755 may allow a user of computer system 2700 to view objects, icons, text, user interface widgets, or other user interface elements. A display device or monitor may be used with computer system 2700 and can include hardware and/or software elements configured for displaying information.
Communications interface 2730 can perform communications operations, including sending and receiving data. Some examples of communications interface 2730 may include a network communications interface (e.g. Ethernet, Wi-Fi, etc.). For example, communications interface 2730 may be coupled to communications network/external bus 2760, such as a computer network, a USB hub, or the like. A computer system can include multiple of the same components or subsystems, e.g., connected together by communications interface 2730 or by an internal interface. In some embodiments, computer systems, subsystem, or apparatuses can communicate over a network. In such instances, one computer can be considered a client and another computer a server, where each can be part of a same computer system. A client and a server can each include multiple systems, subsystems, or components.
Computer system 2700 may also include one or more applications (e.g., software components or functions) to be executed by a processor to execute, perform, or otherwise implement techniques disclosed herein. These applications may be embodied as data and program code 2740. Additionally, computer programs, executable computer code, human-readable source code, shader code, rendering engines, or the like, and data, such as image files, models including geometrical descriptions of objects, ordered geometric descriptions of objects, procedural descriptions of models, scene descriptor files, or the like, may be stored in memory subsystem 2715 and/or storage subsystem 2720.
Such programs may also be encoded and transmitted using carrier signals adapted for transmission via wired, optical, and/or wireless networks conforming to a variety of protocols, including the Internet. As such, a computer readable medium according to examples described herein may be created using a data signal encoded with such programs. Computer readable media encoded with the program code may be packaged with a compatible device or provided separately from other devices (e.g., via Internet download). Any such computer readable medium may reside on or within a single computer product (e.g. a hard drive, a CD, or an entire computer system), and may be present on or within different computer products within a system or network. A computer system may include a monitor, printer, or other suitable display for providing any of the results mentioned herein to a user.
Any of the methods described herein may be totally or partially performed with a computer system including one or more processors, which can be configured to perform the steps. Thus, embodiments can be directed to computer systems configured to perform the steps of any of the methods described herein, potentially with different components performing a respective step or a respective group of steps. Although presented as numbered steps, steps of methods herein can be performed at a same time or in a different order. Additionally, portions of these steps may be used with portions of other steps from other methods. Also, all or portions of a step may be optional. Additionally, any of the steps of any of the methods can be performed with modules, circuits, or other means for performing these steps.
The specific details of particular embodiments may be combined in any suitable manner without departing from the spirit and scope of embodiments of this disclosure. However, other embodiments of the disclosure herein may be directed to specific embodiments relating to each individual aspect, or specific combinations of these individual aspects.
The above description of exemplary embodiments of this disclosure have been presented for the purposes of illustration and description. It is not intended to be exhaustive or to limit this disclosure to the precise form described, and many modifications and variations are possible in light of the teaching above. The embodiments were chosen and described in order to best explain the principles of this disclosure and its practical applications to thereby enable others skilled in the art to best utilize this disclosure in various embodiments and with various modifications as are suited to the particular use contemplated.
A recitation of “a,” “an” or “the” is intended to mean “one or more” unless specifically indicated to the contrary.
All patents, patent applications, publications, and descriptions mentioned here are incorporated by reference in their entirety for all purposes. None is admitted to be prior art.
The present application is a continuation of, and claims the benefit and priority of U.S. application Ser. No. 15/814,190, filed Nov. 15, 2017, now U.S. Pat. No. 10,475,165, issued Nov. 12, 2019, entitled “KERNEL-PREDICTING CONVOLUTIONAL NEURAL NETWORKS FOR DENOISING”, which claims the benefit and priority under 35 U.S.C. 119(e) of U.S. Provisional Application No. 62/482,593, filed Apr. 6, 2017, entitled “KERNEL-PREDICTING CONVOLUTIONAL NEURAL NETWORKS FOR DENOISING”, the entire contents of which are incorporated herein by reference for all purposes.
Number | Name | Date | Kind |
---|---|---|---|
7747070 | Puri | Jun 2010 | B2 |
9008391 | Solanki | Apr 2015 | B1 |
9324022 | Williams, Jr. | Apr 2016 | B2 |
9760690 | Petkov | Sep 2017 | B1 |
10475165 | Vogels et al. | Nov 2019 | B2 |
20130335434 | Wang | Dec 2013 | A1 |
20160321523 | Sen | Nov 2016 | A1 |
20170161891 | Madabhushi | Jun 2017 | A1 |
20170339394 | Paulus, Jr. | Nov 2017 | A1 |
20180025257 | van den Oord | Jan 2018 | A1 |
20180150728 | Vandat | May 2018 | A1 |
20180293713 | Vogels | Oct 2018 | A1 |
Entry |
---|
Bako, S., Vogels, T., McWilliams, B., Meyer, M., Novák, J., Harvill, A., . . . & Rousselle, F. (2017). Kernel-predicting convolutional networks for denoising Monte Carlo renderings. ACM Trans. Graph., 36(4), 97-1. (Year: 2017). |
Liu, Zichen. “Machine Learning for Filtering Monte Carlo Noise in Ray Traced Images.” (2017). (Year: 2017). |
Vogels, Thijs, et al. “Denoising with kernel prediction and asymmetric loss functions.” ACM Transactions on Graphics (TOG) 37.4 (2018): 124. (Year: 2018). |
Chaitanya, Chakravarty R. Alla, et al. “Interactive reconstruction of Monte Carlo image sequences using a recurrent denoising autoencoder.” ACM Transactions on Graphics (TOG) 36.4 (2017): 98. (Year: 2017). |
Kalantari, Nima Khademi, Steve Bako, and Pradeep Sen. “A machine learning approach for filtering Monte Carlo noise.” ACM Trans. Graph. 34.4 (2015): 122-1. (Year: 2015). |
U.S. Appl. No. 15/814,190, “Notice of Allowance”, dated Jul. 1, 2019, 13 pages. |
Bako et al., “Kernel-predicting convolutional networks for denoising Monte Carlo renderings.”, ACM Trans. Graph., vol. 36 No. 4, 2017, 14 pages. |
Chaitanya et al., “Interactive reconstruction of Monte Carlo image sequences using a recurrent denoising autoencoder,” ACM Transactions on Graphics (TOG) vol. 36, No. 4 (2017): 98., (Year: 2017), 12 pages. |
Kalantari et al., “A machine learning approach for filtering Monte Carlo noise.” ACM Trans Graph., vol. 34, No. 4 (2015), 122-1. (Year: 2015). |
Liu, “Machine Learning for Filtering Monte Carlo Noise in Ray Traced Images.”, 2017, 66 pages. |
Vogels et al., “Denoising with kernel prediction and asymmetric loss functions.”, ACM Transactions on Graphics (TOG) vol. 37, No. 4: 124, 2018, 15 pages. |
Number | Date | Country | |
---|---|---|---|
20200027198 A1 | Jan 2020 | US |
Number | Date | Country | |
---|---|---|---|
62482593 | Apr 2017 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 15814190 | Nov 2017 | US |
Child | 16584760 | US |