=Paper=
{{Paper
|id=Vol-3105/paper5
|storemode=property
|title=Domain Randomization for Object Counting
|pdfUrl=https://ceur-ws.org/Vol-3105/paper5.pdf
|volume=Vol-3105
|authors=Enric Moreu,Kevin McGuinness,Diego Ortego,Noel E. O'Connor
|dblpUrl=https://dblp.org/rec/conf/aics/MoreuMOO21
}}
==Domain Randomization for Object Counting==
                               Domain Randomization for Object Counting⋆
                           Enric Moreu1,2[0000−0002−0555−3013] , Kevin McGuinness1,2[0000−0003−1336−6477] ,
                                         Diego Ortego1,2[0000−0002−1011−3610] , and Noel E.
                                                  O’Connor1,2[0000−0002−4033−9135]
                                                 1
                                                     Insight Centre for Data Analytics, Ireland
                                                         2
                                                           Dublin City University, Ireland
                                   Abstract. Recently, the use of synthetic datasets based on game engines
                                   has been shown to improve the performance of several tasks in computer
                                   vision. However, these datasets are typically only appropriate for the
                                   specific domains depicted in computer games, such as urban scenes
                                   involving vehicles and people. In this paper, we present an approach to
                                   generate synthetic datasets for object counting for any domain without
                                   the need for photo-realistic techniques manually generated by expensive
                                   teams of 3D artists. We introduce a domain randomization approach for
                                   object counting based on synthetic datasets that are quick and inexpensive
                                   to generate. We deliberately avoid photorealism and drastically increase
                                   the variability of the dataset, producing images with random textures and
                                   3D transformations, which improves generalization. Experiments show
                                   that our method facilitates good performance on various real word object
                                   counting datasets for multiple domains: people, vehicles, penguins, and
                                   fruit. The source code is available at: https://github.com/enric1994/dr4oc
                                   Keywords: Domain Randomization · Synthetic Data · Object Counting
                                   · Computer Vision
                          1      Introduction
                          Object counting is a computer vision task, the goal of which is to automatically
                          estimate the number of objects in an image or video. It has gained a lot of
                          interest in recent years because of its many potential uses: it can help to identify
                          the congestion level in a shopping center [31] (people counting), the level of
                          traffic on a road [8] (vehicle counting), the status of a penguin colony [1] (habitat
                          monitoring), or even to monitor a harvest [18] (fruit counting).
                              The main challenge of object counting is that the model has to learn all the
                          variations of the objects in terms of their size, shape, and pose whilst also dealing
                          with occlusion and perspective effects. Furthermore, object counting algorithms
                           ⋆
                               This project has received funding from the European Union’s Horizon 2020 research
                               and innovation programme under the Marie Sklodowska-Curie grant agreement
                               No 765140. This publication has emanated from research supported by Science
                               Foundation Ireland (SFI) under Grant Number SFI/12/RC/2289 P2, co-funded by
                               the European Regional Development Fund.
Copyright 2021 for this paper by its authors. Use permitted under Creative Commons License Attribution 4.0 International (CC BY 4.0)
2         Enric Moreu et al.
tend to overfit because of the small amount of annotated data available, which
degrades their performance when applying the model on other slightly different
domains.
    To address the problems above, some computer vision algorithms are trained
or pretrained using synthetic data, which can be automatically annotated with
perfect precision for a range of application domains, including those where
collecting data is problematic. Many computer vision tasks such as optical flow,
detection, segmentation, or counting have benefited from the use of synthetic
data. There are many well-known artificially generated datasets [21] that are
particularly useful because of their size, quality of the annotations, and the
variability within the dataset.
    The task of developing novel approaches to people counting in particular has
benefited from the use of synthetic data. However, when counting objects from
other domains such as wildlife, food, or everyday arbitrary objects, the datasets
produced by game engines are not useful because there are no realistic video
game renderings of these types of objects. It is not practical to create realistic
datasets for many different tasks because of the significant manual effort and
production costs required [17].
    Furthermore, models trained with synthetic images from a particular domain
perform poorly when tested on a different target domain because of the domain
gap, which has posed considerable obstacles to real-world adoption of synthetic
data for computer vision applications. The main cause is that convolutional
neural networks (CNN) introduce a bias towards textures, memorizing them
instead of shapes [7]. For object counting, understanding the shape of the items
is of paramount importance in order to address the challenges of overlapping
objects and occlusions.
    Domain randomization (DR) [23] can reduce the impact of the domain gap
by generating highly variable samples at the cost of increasing the complexity
of the task. The objective of increasing variability is to expand the spectrum
of possibilities of the source domain whereby the real-world domain becomes
just another variation. The synthetic samples generated with this technique tend
to look less realistic because of the random textures, lighting, and backgrounds
used. DR avoids photorealism, minimizing the need for artistic design. Figure 1
shows several examples of DR applied to different environments.
    The contributions of this paper are as follows:
    – We train an object counting algorithm without labeling any data. The ground
      truth is calculated automatically during the generation of the synthetic
      images.
    – We introduce the first domain randomization approach for object counting
      based entirely on synthetic images. We increase the variability of the synthetic
      dataset by applying random textures, backgrounds, and lighting effects to
      the 3D scene. We demonstrate good performance on real-world datasets that
      is consistent across multiple domains.
    – We introduce a set of 3D transformations that increase the variability of the
      3D models while preserving their inner shape, making the task more complex
                               Domain Randomization for Object Counting           3
          (a) Crowd counting                         (b) Vehicle counting
       (c) Environmental survey                       (d) Harvest study
Fig. 1. Synthetic images generated using the proposed domain randomization approach.
    during training but improving generalization at test time. To the best of our
    knowledge, we are the first to use 3D transformations to randomize synthetic
    images in this way.
2   Related work
Early object counting algorithms mainly targeted crowd counting. They applied
detection-based approaches such as R-CNN [11] and YOLO [19] to estimate the
number of people in an image and demonstrated reasonable accuracy in sparse
scenes [20]. However, the performance dropped on densely crowded scenes where
people overlapped with heavy occlusion. Alternative regression-based methods [13]
can extract features (textures, gradients, shapes) to overcome occlusion and learn
a mapping function to evaluate how sparse the scene is, but they ignore the
spatial information. In general, CNN-based approaches [16] predict density maps
to estimate the number of instances in the scene and use the spatial information
contained in the density map. Currently, most of the object counting state-of-the-
art algorithms are based on fully convolutional networks [29] combined with other
techniques such as analyzing the context [9], using the perspective information [6]
or applying a multi-column architecture [31].
    Many object counting datasets have appeared in recent years [31,1,8,10],
especially for crowd counting. In general they are annotated with dots indicating
the position of the objects, e.g. crowd counting datasets define a dot on the head
of each person. The annotation of object counting datasets is expensive because
4       Enric Moreu et al.
Table 1. Details of the real-world datasets used to evaluate the proposed object counting
method.
           Dataset                Images         Resolution       Avg. Count
           SHT A [31]             482            589 × 868        501.4
           SHT B [31]             716            768 × 1024       123.6
           Penguins [1]           80095          2048 × 1536      7.2
           TRANCOS [8]            1244           640 × 480        36.5
           MinneApple [10]        670            720 × 1280       42.1
it requires precise dot annotations performed by an expert; hence the datasets
tend to be small, as shown in Table 1.
    Performance is measured using two main metrics: MAE (mean absolute error)
and MSE (mean squared error). They compute the average L1 and L2 distance
between the predicted count and the ground truth respectively. MAE and MSE
are scale-dependent and therefore can not be used to make comparisons between
datasets using different scales, e.g. it can not be used to compare performance
between different counting datasets because they may have a different average of
objects per image. The formula used to compute them is described as follows:
                                           n
                                           X |xi − yi |
                               M AE =                     ,                          (1)
                                           i=1
                                                    n
                                          n           2
                                          X (xi − yi )
                               M SE =                         ,                      (2)
                                          i=1
                                                    n
where x is the predicted count, y is the ground truth and n is the number of
images evaluated.
    Recently, synthetic datasets [21] have been used to train deep networks for
computer vision. The environments used to create the synthetic datasets range
from very simple methods using basic shapes and colors [18], to scenes generated
by complex game engines [21] that render photo-realistic images and videos. The
main benefit is that the data is labeled automatically, saving a substantial amount
of time especially in densely annotated datasets such as those for segmentation [5].
Also, it is possible in a virtual environment to reproduce rare scenes that are hard
to capture from the real world e.g. remote hard to access locations or unusual
weather phenomena.
    DR aims to make CNNs robust against challenges posed by novel domains
outside the training set, a phenomenon known as the domain gap. It was first
explained by Tobin et al. [23] by varying the texture of the objects, background
image, and lighting in a semantic segmentation task. The objective is to generate
enough variations of synthetic data that the model views real data as just another
variation, even if the variations used for training appear unrealistic to humans.
Expanding the spectrum of possibilities also raises the complexity of the task,
requiring a model with a higher capacity. If the model is trained on a sufficient
                               Domain Randomization for Object Counting           5
    (a) Human           (b) Vehicles          (c) Penguin             (d) Apple
           Fig. 2. Low-poly 3D models used to create synthetic datasets.
number of environments it will interpolate well to novel ones. This method can
be considered to be an evolved form of data augmentation.
    Conversely, domain adaptation (DA) [25] tries to bring the training data
closer to the real-world data [26] by matching the distributions of both datasets
and learning the shared properties. When DA is applied on synthetic images,
they will look more realistic. DA is useful when data can be easily obtained
by modeling the distribution of the synthetic features to match the real ones.
However, many domains cannot benefit from this technique because of the high
variability of the data and the low amount of real images available, e.g. face
recognition datasets have a limited amount of infants smiling [27].
3     Proposed Approach
3.1   Scene creation
Our DR datasets are generated using a mixture of 3D models, textures, back-
ground images, and lighting effects. The 3D software to render the scenes is
Blender [4], which can be easily automated. We specify 3D models to have less
than 200 faces, low-poly models, as shown in Figure 2. We found that using
highly-realistic models, which can have a thousand faces, does not improve the
results while significantly increasing the rendering time.
    The low-poly 3D models structure is modified to produce more variations,
some of them unrealistic. The generated structures are, however, constrained
to keep the basic shape, e.g. humans with one head and two legs, otherwise
the model will not learn the inner properties of the object. Learning a vast
amount of shapes improves generalization to novel scenarios. Figure 3 shows the
different 3D transformations that we used to produce the synthetic datasets:
scale, randomization, and extrusion. Scale smoothly expands/contracts all the
vertices on the same axis. It is useful when objects tend to have very different
sizes, e.g. adults tend to be twice as big as children.
    The scale of every 3D model is determined by K ∼ U(1/No , 8/No ) where
U is a uniform distribution and No is the number of objects in the image.
Randomizing the vertices of the mesh translates all the vertices in different
lengths and directions, uniformly by a factor of 40%. This method improves the
performance in environments where the pose of the objects is variable, e.g. people
can have multiple poses while vehicles do not. Extrusion alters the surfaces of the
mesh to increase the thickness by adding depth. This helps to make objects bigger
6      Enric Moreu et al.
or smaller but adds bumps and holes. We used the built-in Solidify transform in
Blender and modified the thickness by T where T ∼ U(−0.1, 0.5).
    Textures from the Describable Textures Dataset [3] are applied to the 3D
models as shown in Figure 4. The dataset contains 5640 textures organized into 47
categories. Textures are mapped to the different parts of the 3D models, e.g. hair,
skin, shirt, pants. This technique helps our DR approach to transcend realism by
producing unrealistic sets of randomly textured 3D models.
    The 3D models are placed in the scene by sampling positions from a standard
Gaussian mixture distribution as follows:
                                     K
                                     X
                            p(x) =         λi N (x | µi , Σi ),                 (3)
                                     i=1
where x is the three-dimensional x, y, z position, λi are the mixture component
weights, µi are the means, and Σi = I. The number of components K is sampled
for each scene as K ∼ U(1 + No /20, 2 + No /8) where U is a uniform distribution
and No is the number of objects in the scene. The mean vectors are uniformly
sampled from the rendered area in the 3D space.
    This method creates occlusion in the clusters but also produces large empty
areas where the background image is displayed. It also mimics how objects are
distributed on the real world, e.g. people are not uniformly distributed [14], they
tend to form small groups on the street. We found that when the objects are
distributed uniformly the test mean absolute error (MAE) increased to 63.4 on
the SHT B dataset for crowd counting, compared with 23.2 using the Gaussian
mixture approach.
    Images from the Places2 dataset [32] are used as the background image. The
dataset contains a wide range of scenes from 365 different environments including
indoors, streets, and nature. The fact that the background images are very
different make the task more complex but improves generalization. Depending on
the task, some image categories have been removed to avoid unlabeled instances
of the relevant objects in the background, e.g. the “stadium-football” category
when counting people or the “iceberg” category when counting penguins. Finally,
a combination of colored lights is randomly placed around the scene to produce
different exposure levels and cast shadows around the 3D objects.
        (a) Scale               (b) Randomization                 (c) Extrude
            Fig. 3. 3D transformations used for domain randomization.
                                Domain Randomization for Object Counting          7
3.2   Counting procedure
We used the Distribution Matching for Crowd Counting [24] approach as a
baseline. The authors use Optimal Transport to measure the similarity between
the normalized predicted density map and the normalized ground truth density
map. They also include a total variation loss to force the neighbouring pixels
to have similar values. The baseline performance is particularly good on scenes
where the density and overlapping of the objects is high. We used a ResNet50 [12]
model, pretrained on ImageNet LSVRC [22], as the base model for all of the
counting tasks. Horizontal flips are applied to double the amount of available
synthetic images. In addition, training images are randomly cropped into multiple
smaller images (512 × 512) to obtain more samples.
4     Evaluation
In this section we analyze the performance of our DR method and evaluate the
models trained entirely with synthetic data on real-world datasets. Two types of
experiments are conducted: 1) testing on real-world datasets; 2) analyzing the
effect of 3D transformations.
4.1   Comparison with real-world datasets
We propose a new scheme to remedy the lack of datasets in non-urban environ-
ments. By training our model only on synthetic data we obtain good performance
on multiple real-world environments. Table 2 compares the performance of train-
ing with real data and synthetic data.
Table 2. Object counting performance (MAE) of real and DR synthetic data on multiple
real-world domains.
             Dataset            Real                       DR (Ours)
             SHT A [31]         PGCNet [28]: 57.0          158.7
             SHT B [31]         SANet [2]: 6.5             23.2
             Penguins [1]       Marsden et al. [15]: 5.8   14.6
             TRANCOS [8]        FCN-rLSTM [30]: 4.2        13.6
    Table 3 compares our DR approach with Wang et al. [26] for crowd counting.
Their method is based on DA applied on images from a realistic video game.
Using real-world images to feed a GAN they improve the textures of the video
game images. DA is successfully applied to domains where it is easy to obtain
real-world images and produce synthetic data using a video game, e.g. urban
environments involving people and vehicles. Our DR approach obtains similar
results without using real-world data and very simple rendering techniques. Whilst
the approach of [26] performs better than our approach, it should be noted that
our performance is achieved with an automatically generated synthetic dataset.
8      Enric Moreu et al.
Fig. 4. Random textures from the Describable Textures Dataset applied on a low-poly
3D model of a penguin.
Table 3. Crowd counting performance (MAE/MSE) using synthetic data comparison.
                   Dataset           GCC [26]        DR (Ours)
                   SHT A [31]        123.4/192.4     158.7/253.2
                   SHT B [31]        19.9/28.3       23.2/41.5
4.2   3D transformations analysis
3D transformations increase the variability of the dataset in terms of shape,
improving the generalization to novel domains. To the best of our knowledge,
we are the first to use 3D transformations on synthetic datasets for generating
training data. Table 4 shows how 3D transformations affect performance on the
object counting task. For each experiment we generated 2k synthetic images with
the given 3D transformation.
    We also observed that when applying strong 3D transformations the training
process takes longer because the task becomes more complex.
             Table 4. Domain randomization techniques (MAE/MSE).
       Dataset               Scale              Extrude       Randomize
       SHT A [31]            183.97/291.7       159.0/253.2   158.7/253.2
       SHT B [31]            29.17/47.8         30.2/54.2     23.2/41.5
       Penguins [1]          18.9/25.1          14.6/20.1     14.6/20.4
       TRANCOS [8]           15.4/19.3          13.6/17.3     13.6/17.6
       MinneApple [10]       22.4/29.4          21.3/27.5     17.5/22.3
    Randomizing the vertices works better on environments with objects that
can present different poses, e.g. people. The results obtained with the extrude
transform are similar to the randomize ones because it also creates small irregu-
larities in the shape. Extrude exhibits good performance on environments where
the objects are solid, e.g. vehicles.
                                 Domain Randomization for Object Counting            9
5    Conclusion
In this paper, we proposed a domain randomization approach for object counting
that can be easily applied to any domain. The counting model was trained only
with synthetic images and achieves good performance on different real-world
counting datasets: crowd counting, vehicle counting, penguin counting, and fruit
counting. Applying the right 3D transformations to the meshes increases the
counting accuracy when evaluating on real-world datasets. The impact of 3D
transformations depends on the nature of the object, e.g. variable pose and size.
Future work in this area will look to extend the proposed domain randomization
approach to the video domain and to use the depth information from the synthetic
data.
References
 1. Arteta, C., Lempitsky, V., Zisserman, A.: Counting in the wild. In: European
    conference on computer vision. pp. 483–498. Springer (2016)
 2. Cao, X., Wang, Z., Zhao, Y., Su, F.: Scale aggregation network for accurate and
    efficient crowd counting. In: Proceedings of the European Conference on Computer
    Vision (ECCV). pp. 734–750 (2018)
 3. Cimpoi, M., Maji, S., Kokkinos, I., Mohamed, S., , Vedaldi, A.: Describing textures
    in the wild. In: Proceedings of the IEEE Conf. on Computer Vision and Pattern
    Recognition (CVPR) (2014)
 4. Community, B.O.: Blender - a 3D modelling and rendering package. Blender
    Foundation, Stichting Blender Foundation, Amsterdam (2018), http://www.blender.
    org
 5. Cordts, M., Omran, M., Ramos, S., Rehfeld, T., Enzweiler, M., Benenson, R.,
    Franke, U., Roth, S., Schiele, B.: The cityscapes dataset for semantic urban scene
    understanding. In: Proceedings of the IEEE Conference on Computer Vision and
    Pattern Recognition (CVPR) (June 2016)
 6. Gao, J., Wang, Q., Li, X.: Pcc net: Perspective crowd counting via spatial convolu-
    tional network. IEEE Transactions on Circuits and Systems for Video Technology
    (2019)
 7. Geirhos, R., Rubisch, P., Michaelis, C., Bethge, M., Wichmann, F.A., Brendel, W.:
    Imagenet-trained cnns are biased towards texture; increasing shape bias improves
    accuracy and robustness. In: International Conference on Learning Representations
    (2018)
 8. Guerrero-Gómez-Olmedo, R., Torre-Jiménez, B., López-Sastre, R., Maldonado-
    Bascón, S., Onoro-Rubio, D.: Extremely overlapping vehicle counting. In: Iberian
    Conference on Pattern Recognition and Image Analysis. pp. 423–431. Springer
    (2015)
 9. Guo, D., Li, K., Zha, Z.J., Wang, M.: Dadnet: Dilated-attention-deformable convnet
    for crowd counting. In: Proceedings of the 27th ACM International Conference on
    Multimedia. pp. 1823–1832 (2019)
10. Häni, N., Roy, P., Isler, V.: Minneapple: A benchmark dataset for apple detection
    and segmentation. IEEE Robotics and Automation Letters 5(2), 852–858 (2020)
11. He, K., Gkioxari, G., Dollár, P., Girshick, R.: Mask r-cnn. In: Proceedings of the
    IEEE international conference on computer vision. pp. 2961–2969 (2017)
10      Enric Moreu et al.
12. He, K., Zhang, X., Ren, S., Sun, J.: Deep residual learning for image recognition.
    In: Proceedings of the IEEE conference on computer vision and pattern recognition.
    pp. 770–778 (2016)
13. Idrees, H., Saleemi, I., Seibert, C., Shah, M.: Multi-source multi-scale counting in
    extremely dense crowd images. In: Proceedings of the IEEE conference on computer
    vision and pattern recognition. pp. 2547–2554 (2013)
14. Liu, X., Song, W., Fu, L., Lv, W., Fang, Z.: Typical features of pedestrian spatial
    distribution in the inflow process. Physics Letters A 380(17), 1526–1534 (2016)
15. Marsden, M., McGuinness, K., Little, S., Keogh, C.E., O’Connor, N.E.: People,
    penguins and petri dishes: Adapting object counting models to new visual domains
    and object types without forgetting. In: Proceedings of the IEEE Conference on
    Computer Vision and Pattern Recognition. pp. 8070–8079 (2018)
16. Pham, V.Q., Kozakaya, T., Yamaguchi, O., Okada, R.: Count forest: Co-voting
    uncertain number of targets using random forest for crowd density estimation.
    In: Proceedings of the IEEE International Conference on Computer Vision. pp.
    3253–3261 (2015)
17. Radau, P., Lu, Y., Connelly, K., Paul, G., Dick, A., Wright, G.: Evaluation frame-
    work for algorithms segmenting short axis cardiac MRI. The MIDAS Journal-Cardiac
    MR Left Ventricle Segmentation Challenge 49 (2009)
18. Rahnemoonfar, M., Sheppard, C.: Deep count: fruit counting based on deep simu-
    lated learning. Sensors 17(4), 905 (2017)
19. Redmon, J., Divvala, S., Girshick, R., Farhadi, A.: You only look once: Unified,
    real-time object detection. In: Proceedings of the IEEE conference on computer
    vision and pattern recognition. pp. 779–788 (2016)
20. Ren, P., Fang, W., Djahel, S.: A novel yolo-based real-time people counting approach.
    In: 2017 international smart cities conference (ISC2). pp. 1–2. IEEE (2017)
21. Richter, S.R., Vineet, V., Roth, S., Koltun, V.: Playing for data: Ground truth
    from computer games. In: European conference on computer vision. pp. 102–118.
    Springer (2016)
22. Russakovsky, O., Deng, J., Su, H., Krause, J., Satheesh, S., Ma, S., Huang, Z., Karpa-
    thy, A., Khosla, A., Bernstein, M., et al.: Imagenet large scale visual recognition
    challenge. International journal of computer vision 115(3), 211–252 (2015)
23. Tobin, J., Fong, R., Ray, A., Schneider, J., Zaremba, W., Abbeel, P.: Domain
    randomization for transferring deep neural networks from simulation to the real
    world. In: 2017 IEEE/RSJ International Conference on Intelligent Robots and
    Systems (IROS). pp. 23–30. IEEE (2017)
24. Wang, B., Liu, H., Samaras, D., Hoai, M.: Distribution matching for crowd counting.
    In: Advances in Neural Information Processing Systems (2020)
25. Wang, M., Deng, W.: Deep visual domain adaptation: A survey. Neurocomputing
    312, 135–153 (2018)
26. Wang, Q., Gao, J., Lin, W., Yuan, Y.: Learning from synthetic data for crowd
    counting in the wild. In: Proceedings of the IEEE conference on computer vision
    and pattern recognition. pp. 8198–8207 (2019)
27. Xia, Y., Huang, D., Wang, Y.: Detecting smiles of young children via deep transfer
    learning. In: Proceedings of the IEEE International Conference on Computer Vision
    Workshops. pp. 1673–1681 (2017)
28. Yan, Z., Yuan, Y., Zuo, W., Tan, X., Wang, Y., Wen, S., Ding, E.: Perspective-
    guided convolution networks for crowd counting. In: Proceedings of the IEEE
    International Conference on Computer Vision. pp. 952–961 (2019)
                                Domain Randomization for Object Counting           11
29. Zhang, L., Shi, M., Chen, Q.: Crowd counting via scale-adaptive convolutional
    neural network. In: 2018 IEEE Winter Conference on Applications of Computer
    Vision (WACV). pp. 1113–1121. IEEE (2018)
30. Zhang, S., Wu, G., Costeira, J.P., Moura, J.M.: FCN-rLSTM: Deep spatio-temporal
    neural networks for vehicle counting in city cameras. In: Proceedings of the IEEE
    international conference on computer vision. pp. 3667–3676 (2017)
31. Zhang, Y., Zhou, D., Chen, S., Gao, S., Ma, Y.: Single-image crowd counting via
    multi-column convolutional neural network. In: Proceedings of the IEEE conference
    on computer vision and pattern recognition. pp. 589–597 (2016)
32. Zhou, B., Lapedriza, A., Khosla, A., Oliva, A., Torralba, A.: Places: A 10 million
    image database for scene recognition. IEEE Transactions on Pattern Analysis and
    Machine Intelligence (2017)