High Diversity Attribute Guided Face Generation with GANs

06/28/2018 ∙ by Evgeny Izutov, et al. ∙ Intel 0

In this work we focused on GAN-based solution for the attribute guided face synthesis. Previous works exploited GANs for generation of photo-realistic face images and did not pay attention to the question of diversity of the resulting images. The proposed solution in its turn introducing novel latent space of unit complex numbers is able to provide the diversity on the "birthday paradox" score 3 times higher than the size of the training dataset. It is important to emphasize that our result is shown on relatively small dataset (20k samples vs 200k) while preserving photo-realistic properties of generated faces on significantly higher resolution (128x128 in comparison to 32x32 of previous works).



There are no comments yet.


page 17

page 18

This week in AI

Get the week's most popular data science and artificial intelligence research sent straight to your inbox every Saturday.

1 Introduction

The last success of generative adversarial networks (GANs) in a wide range of utility tasks promotes researchers to pay more attention to GAN based solutions bringing each time something new. In this evidence the image generation task and the face synthesis problem in particular has become one of the most attractive challenges in computer vision. One must admit that other popular problems like classification, object detection, semantic segmentation have found their application in many real complex systems. As for image generation task, it lies between a non-standard test on the ability of modern neural networks to learn complex distributions on the one hand and some kind of art on the other hand.


To overcome an unproductive situation with potentially powerful framework and to bring one more instrument into the machine learning development kit we believe researchers should focus their attention on the problem of diversity of generated images. It means that even if we have strong methods which are able to produce photo-realistic images we are still limited to select a couple of valid samples from the thousands of improbable ones for the real usage. Regarding the face synthesis and additional requirement to provide the diversity property over samples with shared spatial template it turns the task into the category of complex problems because of its insufficiency to copy the template of a face ”two eyes, a nose and a mouth on the oval background” by combining different parts only. The real problem is that reasonable for people differences in faces are inseparable from the ”mean face” for the most of generative models including GANs. In this evidence we should focus on developing the solution providing a good trade-off between the generative and discriminative properties of the objective function.

Contribution. To cope with the issue we propose to use the following feasible three-fold solution:

  • Incorporating simple and powerful space of the unit complex numbers for the latent vector

    for GANs.

  • Extending well known histogram loss [1] to tackle a max entropy problem for the proposed below cycle-histogram.

  • Demonstrating the full model training procedure with auxiliary attribute classification subnetwork (inspired by [2] but improved in one critical way – overcoming possible gradient artifacts by using the regularization term from the contractive auto-encoder [3]) and the identity preserving component which is built on the auto-encoder subnetwork with the auxiliary loss.

2 Related Work

2.1 Face Synthesis

Most of the existing methods exploit the idea of fitting parametric model of a face to the real one and then generate new face by changing key parameters. Depending on a parametrization such methods can be divided on 2 groups: methods with a direct parametrization which are trying to capture some task-specific property e.g. face shaving

[4], aligning [5] and face reconstruction [6] and methods which can be used in performing transformations in a domain of face key points to carry out morphing between different facial expressions or a spatial rotation. Good survey for this can be found in [7].

The main limitation for the described above methods is a requirement to have a source face image. Another problem is to find a good model describing some properties like emotions, age, gender and so on. Recent success of CNN-based solutions have shown significant improvements over the traditional CV methods in the domain of human faces (e.g. 3D face reconstruction [8]

). Lately many researchers have focused their attention on the GAN-based solutions and it allows them to move problem from finding a good face model to learning a joint distribution of the required attributes. This fact makes the researcher be free from the model searching task and be more focused on the general solution.

2.2 Generative Adversarial Network

Introducing Generative Adversarial Networks (GANs) [9]

brought one more power framework to the family of generative models. Recent success of CNN based solutions has stimulated the usage of convolutional networks in the GAN framework but with some architectural changes like stride instead of pooling operators

[10], nearest neighbour upsampling versus deconvolutions [11]. It’s important that, a GAN framework can be used not only for the direct image synthesis but also as an regularization loss [12], [13].

The GAN framework is based on a min-max game of two players: the first player (generator ) learns the distribution over the real data with a domain by generating samples from the certain distribution over internal representation with a domain and the second one (discriminator ) tries to discriminate the generator answers from the real ones. More formally the GAN framework is presented in Eq. 1.


Usage of GANs is accompanied with difficulties in a training procedure due to its instability. To overcome them, two main ways are developed: some techniques applied during training like one sided label smoothing [14], instance noise [15], gradient regularization [16], minibatch discrimination [17], distribution matching [18] and finding a cost function with better theoretical properties. Regarding the last one, the most impressive results were shown after rethinking the Wasserstein distance: WGAN [19], [20] and with some simplification to the metric formulation BEGAN [21]. Other approaches use different discriminator scores [22] or metrics [23]. The investigation of other cost functions and some generalized formulation of any function can be found in [24].

The next barrier to successfully utilize GANs for real use-cases is a trade-off between quality and diversity. Several methods have been proposed to enhance an image quality by using some good working classical techniques like auto-encoders [25], [26], stacking lightweight and easy trainable subnetworks [27] and presented in a recent time the work of [28] which proposes to grow generator/discriminator subnetwork to improve the situation with the gradient flow for the deep networks. Unfortunately, in practice the closer the output of an algorithm to the photo-realistic image the further from the diverse solution. To measure the variation of a generated data several approaches have been suggested: the inception score [14] for the general purpose generators, explicit tests [29] and the birthday paradox test [30]. The last one looks more robust regarding its application for the wide range of target domains and it has been used in our work too. In general, variation decreasing is related to the ”mode collapse” problem, which is proposed to solve by introducing the auxiliary network [31], changing an objective function [29] or using some specific techniques [17]. In our opinion, such methods allow increasing the diversity but with too high cost - restricting the network architecture or the training procedure. In this work we propose more simple yet effective solution which does not restrict general network architecture, meaning that last successful trends in network-building can be used here as well.

2.3 Conditional Image Generation

The next challenge beyond the arbitrary image generation task is a synthesis of images with specified attributes. The first GAN based attempts to this task have been proposed in [32], [2] and its application for the face generation in [33]. Extended variant of the conditional-GAN framework is presented in Eq 2, where is drawn from the distribution over the attributes with domain :


Example of using the dense attributes like a semantic layout have been shown in [34]. To control the attributes directly the auxiliary classification subnetwork is added [35]. However in the specified above approaches the main limitation for generation of valid samples for the each state of latent vector is an inability to generate samples from the learned distribution . It is because the distributions are different but we know the theoretical only. To solve this problem it’s been proposed to complement the network with auto-encoder like in [36], add an auxiliary GAN to control the distribution of [37] or to control the latent vector subspace by introducing FaceNet-based [38] the identity preserving optimization [39], decomposing a latent vector into the internal and the attributes guided vector . One more solution is to specialize some latent variables by the mutual information maximization [40].

The different attempt to solve the attribute changing problem is based on training a specialized generator which is able to carry out only one type of a transformation. For instance, above mentioned model can translate any face image to some specified by the set of attributes face like ”man, black hair, square glasses” [41], [42], [43], [44]. For other set of attributes one more generator should be trained. The advanced methods allow researchers to carry out training on the unpaired data like in [45] or [46].

In the presented work we trying to improve the situation with a coherence between the learned and real distributions.

3 Proposed Method

Figure 1: Left: example of a mode collapse problem. Right: introducing auxiliary function incorporates an additional force to push different points far from each other.

3.1 Background

One of the problems with the original formulation of GAN framework (see Eq.1) is a mode collapse (the left image on Fig. 1) [47] which occurs when generator instead of learning bijective function where is a space of generated images starts to map the different points from the latent vector space to the same output point. This problem is aggravated by over-fitting while optimizing to get more photo-realistic images.

The reasonable assumption is that the choice of an objective function influences the properties of the obtained solution. Recently, it was proposed to use functions with more desirable properties like Wasserstein [19], [21] distance or more general f-GAN [24] which is based on general .

However, the last progress in theoretical analysis of GANs for the finite sample sizes [48] showed some justification that low-capacity discriminator is not able to distinguish the target distribution from a learned distribution with high diversity. In other words even if the neural net distance which is modeled by the discriminator between distributions is small enough the real distribution is still can be far from the learned . It’s worth saying that it’s not only a problem of an objective function selection but it’s mainly a problem of a general formulation of the task which is defined for the finite capacity models and given finite number of samples.

The key strategy is to take auxiliary an objective function for control the diversity properties directly instead of digging for more pleasant distance metric.

In our opinion the most suitable framework for this is an auto-encoder (see the right image on Fig. 1). It introduces an additional function and the reconstruction distance between real sample and recovered from the internal representation state :



is a loss function like

or distances in common ways.

In context of GANs this loss is responded for the identity preserving objective: extracting and saving the most representative features during the main GAN based reconstruction phase. Incorporating an additional loss from Eq. 3 to our target objective (Eq. 2

) doesn’t solve neither the problem of a coherence between the estimated and real distributions over the internal representation

nor the diversity challenge. As it will be shown later in this chapter some additional loss which is connected with encoder can bring us the desired properties.

3.2 Problem definition

Figure 2:

Densities of the latent space variables in case of common used uniform and normal distributions. The red color curve is the theoretical distribution and white with blue bars - learned distribution. Left: uniform distribution with support

. Right: normal distribution . As it can be seen there is a significant gap between theoretical and real distributions of latent vector .

Bellow we assume that the domain of a distribution over the internal representation or latent state is . When we speak about auto-encoders the first question for us is the choice of the target space because it implicitly influences on the capacity of a target model unlike more clear for understanding the size of a vector . The most common practices are to choose either from the uniform or normal

multidimensional random variables. VAE

[49] uses slightly different formulation which estimates parameters of the selected distribution directly like and in case of the normally distributed random variable.

The main limitation for usage auto-encoders together with GANs is a significant discrepancy between the learned distribution and the target distribution . It means that a generator is faced with learning two different distributions: one is output of the encoder (see Eq. 3) and another one is GAN specific from Eq. 2. In this case we can assume that two targets of objective function proposed above are independent. Moreover, in light of the limited capacity of a generator, the final model will be a trade-off between two losses and potentially will produce a poor performance compared with the single GAN objective.

One more problem is a degradation of the distribution learned by encoder. Fig. 2 shows the theoretical and real distributions of . For instance, the uniform continuous distribution with support is reduced into the uniform discrete distribution with only two different states . Note that, neither the proper initialization of an encoder weights nor incorporating in a training process an additional loss to fit the target distribution (like auxiliary GAN for the latent space [37] or as it’s proposed later in this paper) can help to fix it.

In literature, the possible way to tackle this problem is to normalize the vector to the unit sphere. However, to preserve the maximal capacity property the individual variables in a vector (which is a multivariate random variable) should be independent but after the normalization the condition mentioned above is broken.

Our goal is to select a space of a latent vector for which we will be able to learn the same distribution of an encoder as the input distribution for the generator during the GAN objective optimization.

3.3 Proposed latent space

In this paper regarding specified above problem about space selection we focus on the uniform continuous distribution with a domain . It has several advantages over the normal distribution or VAE [49] technique: a linear dependence between the edge values and which can help during the optimization procedure and simple form of the support in context of the next synthesis task.

However, using it directly we face a problem of the saturation of the edge values: instead of learning the continuous manifold which is able to represent quantitative properties for each target feature the model learns qualitative properties only. Mostly it’s result of the learning procedure which first extracts the most simple features and then concatenates more specific features or tries to clarify existing one. Unfortunately during the first stage the learning procedure is stumped near the edge values and we explored only one solution for this – to increase the size of the latent vector.

We do not consider the option of improving learning procedure by switching to adaptive methods or utilizing some other tricks because it’s a heavy solution without a guarantee of success. More clear way is to think not about the line segment but about the closed segment. Imagine if we don’t have the edge values we can’t stuck in them and all values can be covered by the forward step (a walk with positive move) only.

While being intuitive an idea to use the periodic functions like trigonometric to achieve the desirable properties we should take into account that without the reference point on the support, the feature cannot be used as a marker of some property and there is no continuous transformation between different states of the same feature. As a result, the final manifold will not satisfy the natural requirements of learning procedure which is SGD in our case.

In this work we propose to use the vector of the unit complex numbers as a domain of :


Despite doubling the size of a latent vector to the support size is still and can be interpreted as an angle of a rotation of a unit vector. Continue our reasoning about the uniform distribution over the linear segment we have extended it to an angle formulation only. As we can see the proposed formulation saves the property of preserving the reference point – we still are able to saturate at the edge values of a pair when or is close to the infinity and it corresponds to four angles but thanks to the normalization term, so now we can force the state to leave the edge value.

Regarding its application for GAN this is expressed in the following:

  • During sampling from we first sample a random angle and then project it on two axes to get pair.

  • To fit the output of an encoder to the introduced space we double the output vector and then normalize each two values into the unit sphere.

3.4 Additional losses

As it was discussed above it’s not enough to add the encoder part to the framework without additional losses which gives us two important properties: the uniform distribution over the angles in the latent space and the diversity of the generated by samples in order to overcome the mode collapse problem.

To tackle the first problem we borrowed the idea to estimate the -dimensional histogram over some statistics from [1] and adopted it to the cycle distribution of angles . As in the original paper we assume the histogram nodes are uniformly spread out over the interval . Then the value of each node is calculated in the same way but and due to the cycle property. After this we can interpret the histogram of angles as a discrete distribution and demand the uniform distribution over it. It can be simply reformulated as maximizing the entropy for the distribution of angles due to its property.

To solve the second problem we follow the proposed in [26] idea and use the introduced earlier encoder with its acquired properties. The original concept was to use an encoder as an auxiliary component to align the latent space distributions of the real and generated data. We have extended it to control the diversity of the generated by samples by minimizing the reconstruction loss between the real and estimated latent vector

. The key moment is to carry out the optimization in respect to the parameters of a generator only. It’s very important to fit the parameters of an encoder on the real samples only. In other words an encoder should never see any sample from the space of synthesized points

. See in Eq. 5 formal description of the proposed loss.


The first term is responded for the identity preserving in respect to the random latent state. The second one carry out the same thing but for the real sample and its representation state in a space . Both terms complement each other to solve the above specified problem to combine in one model the distributions produced by encoder and real .

Finally, the objective function for the default GANs is a sum of terms of Eq. 2, Eq. 3, Eq. 5. Note, in this paper we use BEGAN framework and that means that Eq. 2 is slightly different (for more details see the next chapter).

4 Implementation details

4.1 Network architecture

The proposed network consists of four main components: encoder , generator , discriminator

and attribute classifier

(see on Fig. 0.C.1). As it was described earlier in [11]

the discriminator subnetwork should require some additional conditions because the generator subnetworks is learned on the gradients back-propagated from the upper networks(which is the discriminator originally). It means that underlying subnetworks can learn all possible gradient artifacts, whose main sources are the checkerboard-based operations like max-pooling, deconvolution and convolution with stride more than one.

In other words if we want to use any network as objective for some target network with an output , the function must be smoothed in the input domain. In context of the CNN based objective functions it means the next necessary recommendations:

  • The stride of convolutional operations is equal to one.

  • No max-pooling operations which worsen the situation with gradient artifacts. It’s better to replace it with average pooling.

  • No deconvolution. The better choice is to replace single deconvolution operation by sequence of the nearest neighbor interpolation following by convolution 1x1 with stride 1.

  • Use the nonlinearity with continuous derivatives like the ELU [50]activation function.

In our case not only the discriminator should satisfy the specified above conditions but the encoder and the attribute classifier too. As a result, we are limited in choice of the state of the art architectures to carry out the feature extraction with better quality. But as it shows in practice the fundamental problems like GANs convergence and their diversity are more influential than the attendant problems.

Finally, the architectures of the encoder and generator implemented in this paper can be found in Tables 0.B.1 and 0.B.2. Note, the encoder has a normalizer at the end to carry out a normalization of each pair of values according to Eq. 4 limitations. The generator has one additional enhancement in relation to the default architecture: according to the results in [51] we use one more upscaling step with the next average pooling operator to force the network taking into account the opinions of neighbors pixels too.

4.2 Reconstruction loss

The key moment from our point of view is selection of the reconstruction loss . Following the conclusions in [52] about this objective we have chosen two terms loss: distance for each channel in the RGB color space and gradient magnitude of Y channel in the YIQ color space:


where - pixel value of channel of image and - the gradient magnitude of image .

The next problem during training is over-fitting on most frequent templates which in case of face synthesis problem is more actual due to common similarity of faces.

In general the best solution is to focus on the most difficult spatial areas of the reconstructed image i.e. areas with the high reconstruction error . In our opinion, the most suitable solution was proposed in [53] by introducing the Loss Max-Pooling operation . This operation allows to filter the pixels with low value of errors and being focused on each hard areas.

Regarding implementation of the above declared method we have modified the paradigm of pixel set selection - originally the loss max-pooling acts on each image from the batch independently but we have merged pixel-losses from all images in one set. It means that whole images can be skipped if current sample is already well known during the optimization step. Our experiments showed that it enhances the situation with possible over-fitting in case of training on small dataset.

4.3 Generator architecture

Having the wide choice of possible GAN frameworks to use in our network we have focused on BEGAN. The main reason to use BEGAN is it’s the paradigm to measure the reconstruction loss as a GAN objective instead of commonly used binary answer i.e. true or false for sources of the input distribution.

The BEGAN based discriminator uses the same idea of auto-encoders which is much discussed above. One more change to the original BEGAN discriminator which we have made is its extending for the conditional inference. This was achieved by simple concatenation of attribute vector to channels after unfolding an output of a dense layer into a spatial representation.

The negative side of such decision is low sensitiveness of final solution to the input attributes. We believe that it’s a property of BEGAN framework with the proposed loss and without the degradation in the image performance the improvements are unlikely.

In this evidence we are forced to incorporate the additional subnetwork named attribute classifier aiming to control the conformity of the generated images to the initial attributes.

The discriminator architecture is a concatenation of an encoder and generator architectures (see Table 0.B.2) but without normalization layer in the encoder and the last up-sampling block in a generator.

Figure 3: Density of the latent space variables in case of common uniform distribution. The red color curve is the theoretical distribution and white one with blue bars - the learned distribution.

4.4 Attribute classifier

In this work we deal with three types of face attributes: age, gender and ethnicity. The last two are the categorical variables and can be modeled by the simple

softmax function. Regarding the first one it’s a continuous variable. In literature it’s proposed to tackle with it either as a regression task or classification over the quantized values. In practice the last one works better however the target objective should take into account the neighborhood property - the closer the prediction to the true label, the lower the value of loss function should be and vise versa.

In this work we use combined loss for the quantized values of an age attribute variable. It consists of three terms: simple softmax for the classification objective, the softargmax [54] for the regression and the locality loss (see Eq. 7, where true values of age) to force the prediction be local near the true age value.


One more challenge we have faced is combining losses from different networks heads: age, gender, ethnicity attributes predictors. The simple solution like re-weighting losses manually is not working well properly because of the possibility to dominate one objective over the rest during training. Reasonable solution for this problem is to use adaptive scheme of loss mixing. We have chosen two term solution: proposed in [55] focal loss to tackle with class imbalance problem and the adaptive multi-target loss with learnable weights imbued by the idea from [56]. Assume below is a set of nonnegative values from the time step . We can interpret each independent value as time serie and the best practice to work with such data is applying exponential smoothing, which gives us a set of smoothed values . Than we re-weight each value by multiplying with regularization weight and learnable weight :


The next question for us is how to incorporate the attribute classifier into the main pipeline. There are two obvious variants: to train the best attribute classifier separately from the main network and then to add it ”as is” to propagate the gradients through it only or to merge it in one super-net and to optimize it in adversarial manner as GAN framework too. In case of the last one the objective on the negative phase (adversarial) of GAN optimizing will be default cross-entropy with the uniform labels for the true distribution.

We have tried with both variants and figure out that the best solution in our case is to train the attribute classifier as an individual network but with strong augmentation of the input images, dropouts for the last two fully-connected layers and additional penalty to the input sensitivity (Frobenius norm of the Jacobian of the nonlinear mapping) as in the contractive auto-encoder (originally [57]).

The attribute classifier architecture is demonstrated in Table 0.B.3. The network consists in the shared backbone (in the table it’s everything before the last block) and the class specific heads (last block in each table, where is number classes in the current task e.g. for the gender classification task ).

4.5 Optimization

All experiments have been performed in the TensorFlow framework

[58]. Both the attribute classifier and the main networks have been optimized using batch size 32 with Adam optimizer and exponentially decayed learning rate starting with .

Regarding the whole network training we use the same method as in BEGAN paper [21] and update the parameters , and independently on the same step and no alternating for and was used.

Note that the end-to-end training with the proposed losses is more sophisticated task than default GAN training even with its convergence problems. This fact can be explained by problem of balance between target GAN training and the convergence of the additional objectives.

5 Experimented Result

5.1 Data

To evaluate the proposed method we have chosen a UTKFace dataset [59] because it contains challengeable labels like categorical age, ethnicity and continues age in addition to the large scale face data . This dataset includes more than 20k images in the wild. The ground truth of an annotation is estimated by the DEX algorithm [60] and double checked by humans as it’s reported by the authors.

To demonstrate the power of the proposed solution we decided to carry out experiments on the aligned and cropped images of faces thereby complicating the task in terms of variety of faces because there is no impact of the secondary attributes like hairstyle and dress on the face diversity.

5.2 Face synthesis

The first thing we should discuss is properties of the learned distribution of the latent vector . It was demonstrated above that the default choice of a space for the latent vector either restricts the support size like for the uniform distribution or produces significantly different distribution (like for the normal distribution), making sampling impossible.

However after changing the latent space to the unit complex number and applying the introduced losses the final distribution is well-fitted to the theoretical as it’s shown on the Fig. 3. In other words, after handling this we can generate the images from the same distribution as it was trained on and no other transformation is required. The summary of using other latent spaces is shown in the Table 1.

Latent space Result
Gaussian Not converged
Uniform Capacity degradation
VAE [49] Initially low capacity
Unit complex numbers Maximal diversity
Table 1: Results of training with different latent spaces.

The next challenge is to make the model be more sensitive to the attribute changing task. The problem is complicated by the fact that synthesized faces must fit the same personality in addition to the general requirement to be photo-realistic. We have performed several experiments to show the robustness of our solution for the specified above problem: variation of the gender (Fig. 0.A.1, left), ethnicity (Fig. 0.A.1, right) and age (Fig. 0.A.2) attributes.

Finally, Fig. 0.A.3 shows examples of generated images with uniform attributes. As you can see even normalized face images (crop and align transforms) look well enough providing a good trade-off between photo-realistic and diversity properties.

5.3 Diversity test

As it was mentioned before, the most important question addressed to GANs is the diversity of the generated samples or in other words the size of the support of the discrete distribution. The simple but powerful framework for the support size estimation is based on the birthday paradox. It says if the discrete distribution support size is then set of samples should have duplicates.

Method Resolution Train size Diversity
DCGAN [10] 32x32 200k 0.8x
MIX+DCGAN [48] 32x32 200k 0.8x
ALI [18] 32x32 200k 5x
Our 128x128 20k 3x
Table 2: The ”birthday paradox” test results of different methods. Proposed solution demonstrates the diversity compatible with ALI method but on the significantly higher resolution and relatively small train dataset.

To cope with it in the context of GANs diversity the birthday paradox test has been proposed in [30]. To measure the difference between the generated samples in an automatic manner the FaceNet [38] is used. It outputs the embedding for each input face image and decides whether the faces are same or not (using the distance between them). Finally, the test includes the next simple steps:

  1. Sample the set of images using the generator .

  2. Select top (relatively small number to check by hand) most similar pairs of faces using FaceNet.

  3. Check duplicates in top pairs by hand.

  4. If no duplicates are found then increase and repeat. Otherwise stop and the support size is .

Regarding the proposed in this paper solution we have found that with the probability higher than

the batch of 250 images in resolution 128x128 contains duplicates. It means that the support size is about samples and it’s three times more than the training set size. The results of other methods (according to the work [30]) are presented in the Table 2.

6 Conclusion

In this work we highlighted the problem of generating photo-realistic faces depending on face attributes. We demonstrated the efficiency of the auto-encoder based solution which resolved the diversity problem of generated by the GAN framework images and focused the attention on the mode collapse problem. To cope with it we introduced the novel space for the latent vector and the auxiliary loss for efficient fitting of the target distribution. Finally, we empirically evidenced that our method can generate the attribute guided face images with the desired trade-off between the quality and diversity showing the support size of the high-resolution 128x128 images 3 times higher than the size of original dataset. We believe that this work introduces one more helpful tool to work with auto-encoders in general case and with GANs in particular.


Appendix 0.A Final images

Figure 0.A.1: Left: variation of the gender attribute line by line. Right: variation of the ethnicity attribute (in each line the same person)
Figure 0.A.2: Variation of the age attribute for the same random person.
Figure 0.A.3: Generated face images.

Appendix 0.B Network architectures

Layer name shortcuts: conv - convolution operator with next batch norm and ELU nonlinearity, avg pool - average pooling operator, fc - fully connected layer, norm - pairwise normalizer, nn resize - nearest neighbor resize operator.

Layer Kernel Stride Out HxWxC
input - - 128 x 128 x 3
conv 3x3 1 128 x 128 x 64
conv 3x3 1 128 x 128 x 64
avg pool 2x2 2 64 x 64 x 64
conv 3x3 1 64 x 64 x 64
conv 3x3 1 64 x 64 x 128
conv 3x3 1 64 x 64 x 128
avg pool 2x2 2 32 x 32 x 128
conv 3x3 1 32 x 32 x 128
conv 3x3 1 32 x 32 x 256
conv 3x3 1 32 x 32 x 256
avg pool 2x2 2 16 x 16 x 256
conv 3x3 1 16 x 16 x 256
conv 3x3 1 16 x 16 x 512
conv 3x3 1 16 x 16 x 512
avg pool 2x2 2 8 x 8 x 512
conv 3x3 1 8 x 8 x 512
conv 3x3 1 8 x 8 x 1024
conv 3x3 1 8 x 8 x 1024
avg pool 2x2 2 4 x 4 x 1024
conv 3x3 1 4 x 4 x 1024
fc - - 1 x 1 x 100
norm - - 1 x 1 x 100
Table 0.B.1: Encoder architecture
Layer Kernel Stride Out HxWxC
input - - 1 x 1 x 100
fc - - 1 x 1 x 16384
reshape - - 4 x 4 x 1024
conv 3x3 1 4 x 4 x 512
conv 3x3 1 4 x 4 x 512
nn resize - - 8 x 8 x 512
conv 3x3 1 8 x 8 x 256
conv 3x3 1 8 x 8 x 256
nn resize - - 16 x 16 x 256
conv 3x3 1 16 x 16 x 128
conv 3x3 1 16 x 16 x 128
nn resize - - 32 x 32 x 128
conv 3x3 1 32 x 32 x 64
conv 3x3 1 32 x 32 x 64
nn resize - - 64 x 64 x 64
conv 3x3 1 64 x 64 x 32
conv 3x3 1 64 x 64 x 32
nn resize - - 128 x 128 x 32
conv 3x3 1 128 x 128 x 32
nn resize - - 256 x 256 x 32
conv 3x3 1 256 x 256 x 32
conv 3x3 1 256 x 256 x 3
avg pool 3x3 2 128 x 128 x 3
Table 0.B.2: Generator architecture
Layer Kernel Stride Out HxWxC
input - - 128 x 128 x 3
conv 3x3 1 128 x 128 x 16
avg pool 2x2 2 64 x 64 x 16
conv 3x3 1 64 x 64 x 16
avg pool 2x2 2 32 x 32 x 16
conv 3x3 1 32 x 32 x 32
avg pool 2x2 2 16 x 16 x 32
conv 3x3 1 16 x 16 x 48
avg pool 2x2 2 8 x 8 x 48
conv 3x3 1 8 x 8 x 64
avg pool 2x2 2 4 x 4 x 64
conv 3x3 1 4 x 4 x 96
conv 3x3 1 4 x 4 x 128
conv 3x3 1 4 x 4 x 192
avg pool 4x4 1 1 x 1 x 192
fc - - 1 x 1 x 192
fc - - 1 x 1 x 192
fc - - 1 x 1 x
Table 0.B.3: Attribute classifier architecture

Appendix 0.C Training scheme

Figure 0.C.1: Network training scheme. The proposed scheme for training a face generator with the auto-encoder based identity and diversity preserving losses. Rectangles with the same subnetwork names (e.g. encoder ) have shared parameters. On the figure and - the real and random attribute labels correspondingly, - the random normalized latent vector, - an input train sample, , , - the generated images, - the reconstruction loss in the image domain, - the reconstruction loss in the latent space domain.