Next Article in Journal
Load-Out and Hauling Cost Increase with Increasing Feedstock Production Area
Previous Article in Journal
Bedding Management for Suppressing Particulate Matter in Cage-Free Hen Houses
 
 
Font Type:
Arial Georgia Verdana
Font Size:
Aa Aa Aa
Line Spacing:
Column Width:
Background:
Article

Chicken Tracking and Individual Bird Activity Monitoring Using the BoT-SORT Algorithm

by
Allan Lincoln Rodrigues Siriani
1,
Isabelly Beatriz de Carvalho Miranda
2,
Saman Abdanan Mehdizadeh
3 and
Danilo Florentino Pereira
4,*
1
Graduate Program in Agribusiness and Development, School of Sciences and Engineering, São Paulo State University, Tupã 17602-496, SP, Brazil
2
Undergraduate Program in Big Data, Sao Paulo College of Technology, Pompeia 17586-050, SP, Brazil
3
Department of Mechanics of Biosystems Engineering, Faculty of Agricultural Engineering and Rural Development, Agricultural Sciences and Natural Resources University of Khuzestan, Ahvaz 63417-73637, Iran
4
Department of Management, Development, and Technology, School of Sciences and Engineering, São Paulo State University, Tupã 17602-496, SP, Brazil
*
Author to whom correspondence should be addressed.
AgriEngineering 2023, 5(4), 1677-1693; https://doi.org/10.3390/agriengineering5040104
Submission received: 14 August 2023 / Revised: 25 September 2023 / Accepted: 27 September 2023 / Published: 29 September 2023

Abstract

:
The analysis of chicken movement on the farm has several applications in evaluating the well-being and health of birds. Low locomotion may be associated with locomotor problems, and undesirable bird movement patterns may be related to environmental discomfort or fear. Our objective was to test the BoT-SORT object tracking architecture embedded in Yolo v8 to monitor the movement of cage-free chickens and extract measures to classify running, exploring, and resting behaviors, the latter of which includes all other behaviors that do not involve displacement. We trained a new model with a dataset of 3623 images obtained with a camera installed on the ceiling (top images) from an experiment with layers raised cage-free in small-scale aviaries and housed in groups of 20 individuals. The model presented a mAP of 98.5%, being efficient in detecting and tracking the chickens in the video. From the tracking, it was possible to record the movements and directions of individual birds, and we later classified the movement. The results obtained for a group of 20 chickens demonstrated that approximately 84% of the time, the birds remained resting, 10% of the time exploring, and 6% of the time running. The BoT-SORT algorithm was efficient in maintaining the identification of the chickens, and our tracking algorithm was efficient in classifying the movement, allowing us to quantify the time of each movement class. Our algorithm and the measurements we extract to classify bird movements can be used to assess the welfare and health of chickens and contribute to establishing standards for comparisons between individuals and groups raised in different environmental conditions.

1. Introduction

The welfare of chickens in a production environment depends on several conditions on the farm and the birds’ health. Van Veen et al. [1] verified with laying hen producers that the activity and movement of the hens are important indicators to assess health and well-being. In this direction, several studies have sought to better understand the behavior of animals to infer welfare [2,3,4].
Human monitoring of animal behavior can be exhaustive and imprecise [5,6,7]. In this field, computer vision has gained space for using non-invasive sensors and ensuring good accuracy in analyzes [8,9,10,11,12].
The ability of chickens to walk may indicate lameness [13,14,15], while the level of agitation of the flock may indicate stress to the rearing environment [16]. Thus, tracking chickens in a production environment has several applications for health and comfort diagnosis that can support mitigating measures and reduce losses in production [12].
Computer vision systems based on deep learning techniques make it possible to automatically discover data representations more easily, enabling the extraction of location and distance measurements [7]. The automatic detection of chickens housed on shavings bedding using computer vision cannot be considered a trivial task, as in the monitored area, there are variations in brightness, shadows, concealment by equipment, and the distortion of the camera lens itself [17]. In this sense, several studies propose different methods of detecting birds [12,16,18].
Several studies sought to track chickens in different rearing environments [6,18,19,20,21,22]. A common problem in tracking organisms is the loss of detection caused by traditional methods, causing ID changes during tracking. Banerjee et al. [23] tested the Strong Simple Online Real Time Tracking (Strong SORT) model on C. elegans worms and verified the effectiveness of the Id maintenance method. Young-Chul et al. [24] describe the use of a combination of association based on the proximity of Cartesian coordinates using the Hungarian algorithm and an association based on visual characteristics to maintain the trajectory of the detected object.
The BoT-SORT algorithm [25], which uses a Kalman filter and a Hungarian algorithm and is associated with the track model in Yolo, presents itself as a new possibility to track objects using a one-step detection method. We hypothesize that this tool can efficiently maintain the identification of chickens in flocks, making it possible to extract important information that may indicate states of agitation and the well-being of individuals and the flock. Our system is different from others, such as Deep-Sort [26], which is state-of-the-art in object tracking and leverages Deep Learning using a large residual network to extract features related to the appearance of an object. BoT-SORT is used to extract object movement variables such as speed, acceleration, and displacement, where these attributes were used to maintain tracking and ignore detection failures of the bird and the behavior we wanted to observe.
This study aimed to develop an intelligent system to automatically identify chickens in flocks whose housing density represents a challenge for computer vision, track the paths taken by each bird, and extract information such as distances and movement speeds of individuals.

2. Materials and Methods

2.1. Experiment and Video Recording

This study utilised a 15-minute video of 20 chickens housed in a reduced-scale shed. The camera was situated atop the aviary to capture bird images from an overhead perspective. The entire shed area was monitored by a POWER ® camera, model AP2688W, equipped with an analog Charge-Coupled Device (CCD) image sensor. Eighty layers of the Lohmann lineage were monitored from 10 June to 8 September 2020. The birds were 29 weeks old at the beginning of the experiment and were obtained from a commercial farm. The chickens were randomly divided into four groups of 20 birds each. The feed was administered daily in the amount of 110 g/bird. Access to water was free. Light management was similar to that adopted by the original farm, with a photoperiod of 17 h of light. Four models of small-scale warehouses were used, with usable dimensions of 140 cm × 300 cm and 150 cm in height, arranged in an east-west orientation. The birds were housed on a 15 cm high wood chip bed. Each henhouse had two nest boxes (40 cm × 40 cm × 40 cm) installed side by side, a pendulum feeder (Φ 30 cm), and four nipple drinkers. The complete experiment was described by Fernandes et al. [16].

2.2. Dataset and Hardware Setup

From the set of all videos recorded in the experiment, 3623 frames were randomly extracted, divided into 3123 for training, 259 for testing, and 241 for validation. The images are 352 × 240 pixels, and the capture rate was 30 fps. In each frame, all the birds appearing in the image were marked, using the Label Studio (https://labelstud.io/, accessed on 5 June 2023) tool (Figure 1). The coordinates of the birds’ bounding boxes were saved in text files and, together with the images, formed the dataset for generating the Yolo model [27,28,29,30,31].
The hardware configuration of the computer utilized in this study is detailed in Table 1. The scripts for processing the videos were developed and executed using Python 3.9.16, and the Pytorch 1.13.1 framework was employed for deep learning purposes.

2.3. Detection Model—Yolo v8n

A Yolo v8n model was generated and trained using the specified dataset for 50 epochs. Model performance was evaluated using the following metrics.
P r e c i s i o n = T r u e   P o s i t i v e T r u e   P o s i t i v e + F a l s e   p o s i t i v e
R e c a l l = T r u e   P o s i t i v e T r u e   P o s i t i v e + F a l s e   N e g a t i v e
m A P = 1 N i = 1 N A P i
where A P i is the average precision for each class and N is the number of classes. In this study, m A P equals A P .
As described in Equation (4), the loss function was utilized to evaluate how the algorithm modeled the data set and achieved the desired outcome.
L o s s y o l o = l b o x + l c o n f + l c l a s s
l b o x = λ c o o r d i = 0 S 2 j = 0 B I i , j o b j x i x ^ i 2 + y i y ^ i 2 + λ c o o r d i = 0 S 2 j = 0 B I i , j o b j w i w ^ i 2 + h i h ^ i 2
l c o n f = λ n o o b j i = 0 S 2 j = 0 B I i , j n o o b j ( C i C l ^ ) 2
l c l a s s = i = 0 S 2 j = 0 B I i , j o b j C c l a s s e s p i c p ^ i c 2
where l b o x , l c o n f , l c l a s s are the losses of location, trust and class; λ c o o r d increase weight for loss in bounding box coordinates; I i , j o b j = 1 if the chicken in box j and cell i match, I i , j o b j = 0 where not; I i , j n o o b j it’s just the opposite; x i , y i , w i   h i are the coordinates ( x , y ) of the location, width and height of the i t h bouding box; λ n o o b j reduces loss when detecting background; C is the total number of classes, which in our model is equal to 1; p ^ i c denotes the conditional class probability for the class c in the cell i .

2.4. Tracking Algorithm

The BoT-SORT multi-object tracking model of Yolo v8n was utilized in this study, which employs a state vector based on the Kalman filter and Hungarian algorithm [25].
The tracking model was elaborated through a map of stages for the execution of the system, described in Figure 2.
For the chicken tracking task, the default Kalman filter is based on a linear observation model and constant velocity movement, governed by the following linear stochastic difference equations, available at Aharon et al. [25].
x k = F k x k 1 + n k 1
z k = H k x k + v k
where F k is the transition matrix for the discrete-time of k 1 for k ; H k is the matrix with observed values; n k e v k are random variables that represent the process and measurement noise, respectively.
The process noise covariance matrix Q k and the measurement noise covariance matrix R k can change at each step in time. The Kalman filter consists of predicting the current time and updating over time according to the equations given below.
x ^ k | k 1 = F k x ^ k 1 | k 1
P k | k 1 = F k P k 1 | k 1 F k T + Q k
K k = P k | k 1 H k T H k P k | k 1 H k T + R k 1
x ^ k | k = x ^ k | k 1 + K k z k H k x ^ k | k 1
P k | k = I K k H k P k | k 1
For each time step k , the Kalman filter estimates the state x ^ k | k 1 and the covariance matrix P k | k 1 , and later updates the later estimated state x ^ k | k given the observation z k and the covariance matrix P k | k , calculated based on the Kalman gain K k .
For the BoT-SORT model, the Kalman Filter state vector is described in Equation (12) and the measurement vector in Equation (13), which is implied in the corrections of the process noise covariance matrices ( Q k ) and measurement noise covariance ( R k ) shown in Equations (14) and (15), respectively [16].
x k = [ x c k ,   y c k ,   w k ,   h k ,   x c ˙ k , y c ˙ k , w ˙ k ,   h ˙ k ]
z k = [ z x c k ,   z y c k ,   z w k ,   z h k ]
Q k = d i a g σ p w ^ k 1 | k 1 2 ,   σ p h ^ k 1 | k 1 2 , σ p w ^ k 1 | k 1 2 ,   σ p h ^ k 1 | k 1 2 , σ p w ^ k 1 | k 1 2 ,   σ p h ^ k 1 | k 1 2 , σ p w ^ k 1 | k 1 2 ,   σ p h ^ k 1 | k 1 2
R k = d i a g σ m w ^ k | k 1 2 ,   σ m h ^ k | k 1 2 ) ,
where x c and y c are the coordinates of the chicken’s bounding box; w and h are the width and height of the bounding box k and k 1 is the current and previous state; σ p , σ v and σ m are the standard deviations of the noise factors.

2.5. Measurement of Distance and Velocity of Travel

The distance covered was calculated from the coordinates of the centroids of each bird between two frames using the Euclidean method.
D ( F i F i + 1 ) = ( x i + 1 x i ) 2 + ( y i + 1 y i ) 2 2
where D ( F i F i + 1 ) is the distance between two points, the first being captured in the frame F i and the second in the frame F i + 1 , x i and y i are the coordinates of the point in the frame F i and x i + 1 and y i + 1 are the coordinates of the point in the frame F i + 1 .
Therefore, for every two frames, we calculate the distance traveled by a chicken centroid and accumulate these values during the complete shooting. However, these values are expressed in pixels and cannot be compared with other distances from other videos due to differences in camera placement and image resolution. To make the measurements comparable, we convert pixels into centimeters using a ratio rule from a known measurement of the scene.
Birds were identified as they appeared on the scene. When the bird left the scene, the path data for that identification was closed so that the same bird, when it returned to the scene, received a new identification. Thus, the distances covered were recorded for each identification.
D I d = D ( F i F i + 1 )
where are D i d is the distance traveled by a chicken with the identification I d by the number of sequential frames that this identification was maintained.
The speed was calculated from the distances covered by the I d s , according to the equation below.
S I d = D I d t
where S I d is the speed of the bird identified by I d , D I d is the distance traveled by the bird I d and t is the time between frames (in our work t = 1 / 30 s).

2.6. Distinction of Running, Exploring, and Resting Behaviors

In the process of detecting chickens in the images, different values of displacements in time were established to differentiate three movement states: resting, exploring, and running. Initially, a noise filter was applied to eliminate erroneous identifications, along with the definition of limits that demarcate the transitions from one behavior to another.
To classify the behaviors, a minimum frame count was defined to indicate the beginning of a new behavior in chickens. Specifically, “Resting” requires a minimum of 5 frames, “Exploring” requires four frames, and “Running” requires three frames. Furthermore, to qualify for detection of one of these behaviors, a bird must maintain a minimum “lifetime” of 18 frames. This implies that the identified bird, designated by its unique track_Id, must be present in the video for at least 18 consecutive frames.
Using these data, the velocity parameter was employed to distinguish the behaviors. This involved calculating the average instantaneous velocity over the last ten frames. For the “Resting” behavior, a speed of 1 cm/frame or less was used as a limit, considering that the resting chicken can move only the head or other body parts, leading to changes in the position of the centroid, even if it remains still or without displacement.
For the “Exploring” behavior, velocities were defined that vary between more than 1 cm/s and less than 100 cm/s, determined in the analysis of the results. “Running” behavior was classified when the velocity was greater than 100 cm/s. To increase accuracy and reduce false positives when identifying “Running” behavior, an additional criterion has been implemented. This criterion measured the distance between the initial and final positions within a vector containing centroids of the last ten associated frames when the reference velocity was exceeded, and we only considered when the distance measured between the extremes was greater than 20 cm. In our tests, this condition differentiated the “Running” behavior from other behaviors with fast movements and without significant movement of the hen.

3. Results

3.1. Yolo Tracking Model

Figure 3 shows the mAP (mean average precision) and Loss plots of the generated Yolo v8n model. The model achieved 98.5% accuracy. These plots depict the evolution of mAP and loss throughout training, offering a detailed view of the model’s performance in chicken identification. The model demonstrated robustness, as the mAP curve remained stable above 98% despite a decrease in the loss curve starting from epoch 15. This suggests the model continues to identify chickens with high precision after an initial training phase.
As illustrated in the images presented in Figure 4, our system was capable of detecting chickens within the nest, albeit with less certainty. Moreover, certain areas, such as those behind the feeder, remained concealed. Additionally, the impact of camera lens distortion on image quality at the periphery also merits consideration.
The quality of detection of chickens is fundamental for successful tracking. Chickens that can be confused with background, or vice versa, generate centroid coordinates that have the potential to interfere with the identification of birds by the Kaman filter. This is a crucial point in the development of the tracking system.

3.2. Appearing and Hiding of Chickens

We had problems hiding the chickens in the scene during our tracking tests. In Figure 4, we highlight two common places where the chicken identification is lost in the image due to obstruction of objects. In Figure 5, we show the example of the path of two chickens that appeared and disappeared in the scene near the feeder and near the nest.
Markings in magenta and red correspond respectively to the first and last coordinates of chicken detection in the video, that is, the beginning and end of the mapped path. Along the way, the more yellow the marking, the faster the chicken travels. We can observe that the places of emergence and disappearance of chickens in Figure 5 are close to the nest or feeder. This was due to the already mentioned fact that we lost the identification of the bird when it left the scene, entered the nest, or passed behind the feeder. This condition is expected in the case of monitoring chickens in commercial farms, as the camera capture area will be smaller than the area of the shed, and, therefore, there will be the appearance and disappearance of chickens (same individuals or not) along the edges of the image. Thus, we decided to work with this feature, allowing our methodology to be applied in commercial breeding conditions in the future.

3.3. Direction of Displacement and Minimum Displacement

In the path graphs, we observe that there are times when the bird walks faster, and in others, there is minimal movement, suggesting that the bird is standing still, expressing some natural behavior.
As can be seen in Figure 6, our processing considered small lateral displacements, accumulating as distances covered by the birds. However, situations like the one illustrated can refer to a bird standing still, resting, or expressing some natural behavior. Therefore, our code considers distances greater than 1 cm/frame as displacement of the bird. The variation in the displacement direction also seems to contribute to the identification of the hen’s state of movement, so we also started to observe this information.

3.4. Measures to Determine the State of Movement

Once the correction was made, we looked for metrics indicating when a bird was standing still, walking, or running. Analyzing the velocity graph in Figure 7, we observed that the velocity of this displacement varied at values below 100 cm/s when the bird was walking and peaked much above this value when the bird ran.
Figure 7 presents a graph depicting the variation in velocity during the time a bird was tracked by our model. This particular bird was selected for analysis as it exhibited all three behaviors during the tracking period. At the onset of tracking, a spike in speed is observed, confirmed in the original video as indicative of the running behavior. This pattern was also observed in other birds, and a velocity threshold of 100 cm/s was established for classifying running behavior in our code. Resting behavior is characterized by the bird remaining completely stationary, disregarding any minor displacements (<1 cm/frame). Consequently, any movement detected with a velocity between 0 and 100 cm/s was classified as exploring behavior. To minimize any transitional effects between behaviors, the average speed of the last ten frames (0.33 s) was considered.

3.5. Movement Analysis

Our surveillance and tracking system can identify a “new chicken” instantly. As previously reported, there are covered regions in our footage, and we found that there are chickens that remain with the same identification for a very short time. There are also those that, during the nesting behavior, even if they maintain the identification, remain still during the entire vigil. Our objective is to develop an intelligent system capable of automatically identifying chickens in flocks whose rearing density. In this sense, we focused our attention on chickens that walked more than 300 cm and were monitored by our system for more than 200 s without losing identification, and we made the graphs shown in Figure 8.
The chicken with track_Id = 148 caught our attention, which had a greater displacement per run than the other birds. Analyzing the trajectory graph, we noticed that in the region where the chicken supposedly ran, the direction vectors were misaligned. Unlike what happened with the chicken track_Id = 33, during the peak velocity, the direction vectors were aligned. We searched the video for the exact frames of each chicken for these occurrences and verified that chicken 33 ran at that moment and chicken 148 flapped its wings. Figure 9 shows the graphs and frames, highlighting the observed differences.
As observed in Figure 9, the peaks in speed are highly similar for distinct behaviors, indicating that this measure alone is insufficient for distinguishing between these behaviors. Based on these observations, the variation in the direction of movement of the birds was analyzed and compared with their speed. The tangent angle of the chicken’s displacement vector for each analyzed frame indicates the intensity of the change of direction of the chicken’s path. It was observed that when this route change is abrupt and associated with high speed, there is a high possibility that the bird is opening its wings. When the speed is high and there is no change in route, it is assumed that the chicken is running. When the route changes but the speed is considered normal, it is assumed that the bird has simply changed direction and continued walking.
For the running chicken, we used the measurement of the distance between the centroids of the extreme points during the last ten frames. This approach allows the detection of the directionality of the bird’s movement. Consideration of speed is of fundamental importance, as it constitutes a discriminating factor between the “Exploring” and “Running” states. In Figure 10, during flapping, the chicken identification track_Id = 79 is segregated into two identifications (track_Id = 79 and track_Id = 97). After the expression of the behavior, identification 97 ceases to exist. During flapping, there is a rapid change in the positioning of the centroid of the original identification (track_Id = 79), resulting in a speed that falls within the predefined limits for the “Running” and “Exploring” states. The generation of new identifications in different bird regions during wing flapping can also cause deviations in the centroids, mimicking the presence of another bird. The finding of a distance between the centroids of these identifications above 20 cm characterizes the “Running” behavior. To mitigate the influence of spurious identifications, we adopted a rule requiring a minimum number of 18 frames (called “lifetime”) in which the bird remains in the video. The limit of 18 frames was chosen based on observations since birds frequently performed movements that caused abrupt changes in the image centroid. This strategy aims to reduce confusion between genuine behaviors and artifactual occurrences.
We implemented these rules in our code (pseudo-code in Appendix A). The processed video that classifies bird movement with all these metric considerations is shown in the Supplementary Material.
In Table 2, we show a summary of the time spent by the birds resting, exploring, and running, which can be used to analyze the state of welfare or health of the birds in time intervals of interest.
Table 2 presents a summary of data obtained from the entire 15-minute video. This summary can be generated for any desired time interval. It was observed that the birds spend most of their time stationary, resting or engaging in other natural behaviors that do not involve movement. The majority of the route traveled by the bird is spent exploring. A few instances of running behavior were observed, and it was verified that this behavior is expressed for very short periods.
We found no reference values for these behaviors in the literature. However, we hypothesize that by extracting precise measurements of these behaviors, it will be possible to establish reference values for each lineage, allowing the welfare of chickens submitted to different housing environments to be compared.

4. Discussion

Proposing automatic, accurate, and non-invasive approaches to monitoring animals in production is necessary to improve the efficiency and welfare of animals in housing [32]. In this sense, several studies have used convolutional neural networks (CNN) to detect and classify chicken behavior. Neethirajan [19] and Yang et al. [20] demonstrated the feasibility of using Yolo to detect chickens in several videos, suggesting applications such as counting and tracking. Yang et al. [20] classified six behaviors using Yolo-v5 with accuracies ranging from 72.3% to 95.3%. Li et al. [33] developed a computer vision system to detect chickens in feeders and drinkers. Nasiri et al. [32] estimated feeding time for broilers using Yolo-v3 to detect when heads were within the feeder area.
Individual and group behavior are important indicators of the welfare and health of birds [34,35,36]. Our work provides a breakthrough for tracking chickens, demonstrating that the Kalman filter and the BoT-SORT algorithm efficiently maintain the identification of birds in our videos, where the density and overlapping of bodies were a challenge for computer vision.
The BoT-SORT algorithm is highly effective in maintaining accurate identification of chickens throughout the tracking process. With our tracking algorithm, we could carry out a detailed analysis of the distances covered and the movement speeds of the chickens. This ability to identify and categorize movement behaviors makes it possible to analyze bird behavior in different environmental conditions.
Measuring the distances covered individually by the hens can indicate the activity level of the flock of individuals and can also be used to assess the gait score [37]. Campbell et al. [2] found that aviary resources were used differently by individual hens and that understanding these usage patterns by both individuals and the group will allow the optimization of cageless housing system designs. Jaihumi et al. [13] developed a Yolo v5 model to assess the mobility of broilers, and Fernández et al. [6] found an association between activity level and patterns of aviary occupancy with hock and leg injuries in broilers using computer vision.
By observing movement patterns, we could detect significant differences between individuals in the monitored group of chickens. These individual distinctions in movements are necessary to assess bird welfare and health. For example, we can identify birds exhibiting anomalous behaviors indicative of health problems or discomfort, allowing for early intervention to ensure appropriate treatment.
Collins [38] observed that some chickens walked greater distances than others. The motivation for moving laying hens may differ from that of broilers. However, in our results, we also observed that there are hens that moved more and at greater speeds than others. Taylor et al. [39] found a relationship between chickens that covered greater distances and increased welfare, and these animals had lower weight, better gait scores, and lower corticosterone responses. Considering chickens under the same rearing model, the observed differences in movement measured by our tracking system may indicate more adapted individuals.
The movement measurements obtained and the tracking algorithm developed in this study provide a solid basis for future investigations. This model can assess the welfare and health of chickens and classify and understand other natural behaviors, thus contributing to significant advances in poultry farming and animal welfare research. Such information is essential to improve poultry farming practices, ensuring a healthier and more comfortable environment for these animals.

Limitations and Suggestions for Future Studies

Our tracking method is limited in regions where the camera is obstructed, such as behind equipment, edges of images, and inside nests. Obstruction of the image by equipment was also observed in other studies [21]. In our tests, we preferred not to deal with this problem because, in commercial situations, there will be regions where the bird will leave the camera’s field of view. We understand it is better to use strategies to analyze the data recorded this way, as already discussed in other works.
Our footage was low resolution and heavily distorted around the edges. The use of high-resolution cameras with less edge distortion can improve the detection accuracy, the conversion scale from pixels to centimeters, and, consequently, the measurements of the distances covered by the birds. Addressing these distortions can give greater accuracy in displacement measurements. More complex images are subject to greater chances of computational model confusion [20]. In this field, it is still necessary for work to demonstrate the stability of a flock tracking system and longer filming times.
We adopted criteria to reduce confusion in classifying the running behavior with other natural behaviors. We raised the hypothesis that these criteria can be better worked to contribute to the classification of natural behaviors. Dawkins [40] and Kashima et al. [41] proposed that behavior can be used to estimate the need and health of animals, highlighting that behavior analysis should have a more prominent role when used with new technologies. Thus, other studies that seek to classify individual or group behaviors autonomously are necessary and will constitute the future of industrial poultry for monitoring the welfare and health of chickens.

5. Conclusions

Our model obtained a mean average precision of 98.5% in detecting chickens, and the BoT-SORT algorithm was efficient in maintaining the identification of these birds during tracking. From the tracking, it was possible to analyze the distances covered and the speeds of the chickens, which made it possible to classify their movement behaviors. Movement speeds above 100 cm/s of chickens with a lifetime of more than 18 frames were sufficient to differentiate running behavior from exploring behavior. In this study, the tests showed that the chickens spent approximately 85% of their time resting, 10% of their time exploring the environment, and 6% running. Our algorithm and the measures extracted to classify chicken movement contribute to the assessment of chicken welfare and health.

Supplementary Materials

The video processed with the proposed algorithm can be downloaded at: https://www.mdpi.com/article/10.3390/agriengineering5040104/s1.

Author Contributions

The Conceptualization, Formal and Statistical Analysis, and Data Curation were made by A.L.R.S. and D.F.P.; The Software and Investigation were made by I.B.d.C.M. and D.F.P.; The Methodology, Validation, the Original Draft, Proofreading and Editing of the manuscript was carried out by A.L.R.S., S.A.M. and D.F.P.; Visualization, Supervision and Funding acquisition was made under D.F.P. All authors have read and agreed to the published version of the manuscript.

Funding

Funding was provided by the National Council for Scientific and Technological Development—CNPq (Grant # 304085/2021-9).

Institutional Review Board Statement

This study was conducted according to the guidelines of the Brazilian National Council for the Control of Animal Experimentation (CONCEA) and approved by the Sao Paulo State University’s Animal Ethics Committee (protocol number 02/2020, CEUA-UNESP), of Comfort Environmental Laboratory at the School of Science and Engineering from the Sao Paulo State University (UNESP, Brazil).

Data Availability Statement

Data will be available upon request to the corresponding author.

Acknowledgments

We thank the support of the technicians of the Precision Livestock Laboratory of the School of Sciences and Engineering of UNESP, Campus at Tupã.

Conflicts of Interest

The authors declare no conflict of interest.

Appendix A

Algorithm: Chicken tracking code and movement classification
Input: Video or stream of video
Output: Video with detections and file of data about this experiment
Agriengineering 05 00104 i001

References

  1. van Veen, L.A.; van den Oever, A.C.M.; Kemp, B.; van den Brand, H. Perception of laying hen farmers, poultry veterinarians, and poultry experts regarding sensor-based continuous monitoring of laying hen health and welfare. Poult. Sci. 2023, 102, 102581. [Google Scholar] [CrossRef] [PubMed]
  2. Campbell, D.; Karcher, D.M.; Siegford, J.M. Location tracking of individual laying hens housed in aviaries with different litter substrates. Appl. Anim. Behav. Sci. 2016, 184, 74–79. [Google Scholar] [CrossRef]
  3. Grebey, T.C.; Ali, A.B.A.; Swanson, J.C.; Widowski, T.M.; Siegford, J.M. Dust bathing in laying hens: Strain, proximity to, and number of conspecifics matter. Poult. Sci. 2020, 99, 4103–4112. [Google Scholar] [CrossRef]
  4. Vasdal, G.; Muri, K.; Stubsjøen, S.M.; Moe, R.O.; Kittelsen, K. Qualitative behaviour assessment as part of a welfare assessment in flocks of laying hens. Appl. Anim. Behav. Sci. 2022, 246, 105535. [Google Scholar] [CrossRef]
  5. Geffen, O.; Yitzhaky, Y.; Barchilon, N.; Druyan, S.; Halachmi, I. A machine vision system to detect and count laying hens in battery cages. Animal 2020, 14, 2628–2634. [Google Scholar] [CrossRef] [PubMed]
  6. Fernandez, A.P.; Norton, T.; Tullo, E.; van Hertem, T.; Youssef, A.; Exadaktylos, V.; Vranken, E.; Guarino, M.; Berckmans, D. Real-time monitoring of broiler flock’s welfare status using camera-based technology. Biosyst. Eng. 2018, 173, 103–114. [Google Scholar] [CrossRef]
  7. Li, G.; Li, B.; Shi, Z.X.; Lu, G.; Chai, L.; Rasheed, K.M.; Regmi, P.; Banakar, A. Inter-Individual Distances and Orientations of Laying Hens under Eight Stocking Densities Measured by Integrative Deep Learning Techniques. Poult. Sci. 2023, 102, 103076. [Google Scholar] [CrossRef] [PubMed]
  8. Yang, X.; Zhao, Y.; Gan, H.; Hawkins, S.; Eckelkamp, L.; Prado, M.; Burns, R.; Purswell, J.; Tabler, T. Modeling gait score of broiler chicken via production and behavioral data. Animal 2023, 17, 100692. [Google Scholar] [CrossRef]
  9. Subedi, S.; Bist, R.; Yang, X.; Chai, L. Tracking pecking behaviors and damages of cage-free laying hens with machine vision technologies. Comput. Electron. Agric. 2023, 204, 107545. [Google Scholar] [CrossRef]
  10. Fang, C.; Huang, J.; Cuan, K.; Zhuang, X. Comparative study on poultry target tracking algorithms based on a deep regression network. Biosyst. Eng. 2020, 190, 176–183. [Google Scholar] [CrossRef]
  11. Guo, Y.; Aggrey, S.; Oladeinde, A.; Johnson, J.; Zock, G.; Chai, L. A Machine Vision-Based Method Optimized for Restoring Broiler Chicken Images Occluded by Feeding and Drinking Equipment. Animals 2021, 11, 123. [Google Scholar] [CrossRef] [PubMed]
  12. Li, N.; Ren, Z.; Li, D.; Zeng, L. Review: Automated techniques for monitoring the behaviour and welfare of broilers and laying hens: Towards the goal of precision livestock farming. Animal 2020, 14, 617–625. [Google Scholar] [CrossRef]
  13. Jaihuni, M.; Gan, H.; Tabler, T.; Prado, M.; Qi, H.; Zhao, Y. Broiler Mobility Assessment Via a Semi-Supervised Deep Learning Model and Neo-Deep Sort Algorithm. Animals 2023, 13, 2719. [Google Scholar] [CrossRef] [PubMed]
  14. Fodor, I.; van der Sluis, M.; Jacobs, M.; Klerk, B.; Bouwman, A.C.; Ellen, E.D. Automated pose estimation reveals walking characteristics associated with lameness in broilers. Poult. Sci. 2023, 102, 102787. [Google Scholar] [CrossRef] [PubMed]
  15. Nasiri, A.; Yoder, J.; Zhaob, Y.; Hawkins, S.; Prado, M.; Gana, H. Pose estimation-based lameness recognition in broiler using CNN-LSTM network. Comput. Electron. Agric. 2022, 197, 106931. [Google Scholar] [CrossRef]
  16. Fernandes, A.M.; Sartori, D.L.; Morais, F.J.O.; Salgado, D.D.; Pereira, D.F. Analysis of Cluster and Unrest Behaviors of Laying Hens Housed under Different Thermal Conditions and Light Wave Length. Animals 2021, 11, 2017. [Google Scholar] [CrossRef]
  17. Trnovszky, T.; Kamencay, P.; Orjesek, R.; Benco, M.; Sykora, P. Animal recognition system based on convolutional neural network. Adv. Electr. Electron. Eng. 2017, 15, 517–525. [Google Scholar] [CrossRef]
  18. Siriani, A.L.R.; Kodaira, V.; Mehdizadeh, S.A.; Nääs, I.A.; Moura, D.J.; Pereira, D.F. Detection and tracking of chickens in low-light images using YOLO network and Kalman filter. Neural Comput. Appl. 2022, 34, 21987–21997. [Google Scholar] [CrossRef]
  19. Neethirajan, S. ChickTrack—A quantitative tracking tool for measuring chicken activity. Measurement 2022, 191, 110819. [Google Scholar] [CrossRef]
  20. Yang, X.; Bist, R.; Subedi, S.; Wu, Z.; Liu, T.; Chai, L. An automatic classifier for monitoring applied behaviors of cage-free laying hens with deep learning. Eng. Appl. Artif. Intell. 2023, 123, 106377. [Google Scholar] [CrossRef]
  21. Yang, X.; Bist, R.; Subedi, S.; Chai, L. A deep learning method for monitoring spatial distribution of cage-free hens. Artif. Intell. Agric. 2023, 8, 20–29. [Google Scholar] [CrossRef]
  22. Cui, Y.; Kong, X.; Chen, C.; Lia, Y. Research on broiler health status recognition method based on improved YOLOv5. Smart Agric. Technol. 2023, in press. [Google Scholar] [CrossRef]
  23. Banerjee, S.C.; Khan, K.A.; Sharma, R. Deep-worm-tracker: Métodos de aprendizagem profunda para detecção e rastreamento precisos para estudos comportamentais em C. elegans. Appl. Anim. Behav. Sci. 2023, 266, 106024. [Google Scholar] [CrossRef]
  24. Young-Chul, Y.; Kim, D.Y.; Young-Min, S.; Yoon, K.; Jeon, M. Online Multiple Pedestrians Tracking using Deep Temporal Appearance Matching Association. arXiv 2020, arXiv:1907.00831. [Google Scholar] [CrossRef]
  25. Aharon, N.; Orfaig, R.; Bobrovsky, B.Z. BoT-SORT: Robust Associations Multi-Pedestrian Tracking. arXiv 2022, arXiv:2206.14651v2. [Google Scholar] [CrossRef]
  26. Wojke, N.; Bewley, A.; Paulus, D. Simple Online and Realtime Tracking with a Deep Association Metric. IEEE internation-al conference on image processing (ICIP). arXiv 2017, arXiv:1703.07402. [Google Scholar] [CrossRef]
  27. 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 (CVPR), Las Vegas, NV, USA, 27–30 June 2016; pp. 779–788. [Google Scholar] [CrossRef]
  28. Redmon, J.; Farhadi, A. Yolov3: An incremental improvement. arXiv 2018, arXiv:1804.02767. [Google Scholar] [CrossRef]
  29. Redmon, J.; Farhadi, A. Yolo9000: Better, Faster, Stronger. In Proceedings of the IEEE Conference on Computer Vision and Pattern Recognition, Honolulu, HI, USA, 21–26 July 2017; pp. 6517–6525. [Google Scholar] [CrossRef]
  30. Ge, Z.; Liu, S.; Wang, F.; Li, Z.; SUN, J. Yolox: Exceeding yolo series in 2021. arXiv 2021, arXiv:2107.08430. [Google Scholar] [CrossRef]
  31. Yang, X.; Chai, L.; Bist, R.B.; Subedi, S.; Wu, Z. A Deep Learning Model for Detecting Cage-Free Hens on the Litter Floor. Animals 2022, 12, 1983. [Google Scholar] [CrossRef]
  32. Nasiri, A.; Amirivojdan, A.; Zhao y Gan, H. Estimating the Feeding Time of Individual Broilers via Convolutional Neural Network and Image Processing. Animals 2023, 13, 2428. [Google Scholar] [CrossRef]
  33. Li, G.; Zhao, Y.; Purswell, J.L.; Du, Q.; Chesser, G.D., Jr.; Lowe, J.W. Analysis of feeding and drinking behaviors of group-reared broilers via image processing. Comput. Electron. Agric. 2020, 175, 105596. [Google Scholar] [CrossRef]
  34. Papageorgiou, M.; Goliomytis, M.; Tzamaloukas, O.; Miltiadou, D.; Simitzis, P. Positive Welfare Indicators and Their Association with Sustainable Management Systems in Poultry. Sustainability 2023, 15, 10890. [Google Scholar] [CrossRef]
  35. Jacob, F.G.; Nääs, I.A.; Salgado, D.D.; Baracho, M.S.; Lima, N.D.S.; Pereira, D.F. Does Environmental Enrichment with Music and Strobe Light Affect Broilers’ Welfare? Analyzing Their On-Farm Reaction. Agriengineering 2022, 4, 707–718. [Google Scholar] [CrossRef]
  36. Pereira, D.F.; Lopes, F.A.A.; Gabriel Filho, L.R.A.; Salgado, D.D.; Mollo Neto, M. Cluster index for estimating thermal poultry stress (gallus gallus domesticus). Comput. Electron. Agric. 2020, 177, 105704. [Google Scholar] [CrossRef]
  37. Li, G.; Gates, R.S.; Meyer, M.M.; Bobeck, E.A. Tracking and Characterizing Spatiotemporal and Three-Dimensional Locomotive Behaviors of Individual Broilers in the Three-Point Gait-Scoring System. Animals 2023, 13, 717. [Google Scholar] [CrossRef] [PubMed]
  38. Collins, L.M. Non-intrusive tracking of commercial broiler chickens in situ at different stocking densities. Appl. Anim. Behav. Sci. 2008, 112, 94–105. [Google Scholar] [CrossRef]
  39. Taylor, P.S.; Hemsworth, P.H.; Groves, P.J.; Gebhardt-Henrich, S.G.; Rault, J.L. Frequent range visits further from the shed relate positively to free-range broiler chicken welfare. Animal 2020, 14, 138–149. [Google Scholar] [CrossRef]
  40. Kashima, M.A.; Green, A.R.; Sales, T.G.; Bahr, C.; Berckmans, D.; Gates, R.S. Performance of an image analysis processing system for hen tracking in an environmental preference chamber. Poult. Sci. 2014, 93, 2439–2448. [Google Scholar] [CrossRef]
  41. Dawkins, M.S. Using behaviour to assess animal welfare. Anim. Welf. 2004, 13, 3–7. [Google Scholar] [CrossRef]
Disclaimer/Publisher’s Note: The statements, opinions, and data contained in all publications are solely those of the individual author(s) and contributor(s) and not of MDPI and/or the editor(s). MDPI and/or the editor(s) disclaim responsibility for any injury to people or property resulting from any ideas, methods, instructions, or products referred to in the content.
Figure 1. Image with the bounding boxes upper laying hens.
Figure 1. Image with the bounding boxes upper laying hens.
Agriengineering 05 00104 g001
Figure 2. Stages of the tracking system development.
Figure 2. Stages of the tracking system development.
Agriengineering 05 00104 g002
Figure 3. Graph of the evolution of the mean average precision (mAP, black line) and loss (red line) during the Yolo v8n chicken detection model training.
Figure 3. Graph of the evolution of the mean average precision (mAP, black line) and loss (red line) during the Yolo v8n chicken detection model training.
Agriengineering 05 00104 g003
Figure 4. The original frame (a) was processed with Yolo v8n (b) showing that the model’s confidence value in detecting laying hens inside the nest and behind the feeder is low.
Figure 4. The original frame (a) was processed with Yolo v8n (b) showing that the model’s confidence value in detecting laying hens inside the nest and behind the feeder is low.
Agriengineering 05 00104 g004
Figure 5. Path of the birds with the marks of the beginning and end of the path (magenta and red, respectively) and highlighting the moments when the bird walked faster (green and yellow dots) for the hen-line (a) track_Id 5 that appeared and disappeared near the feeder and (b) track_Id 45 that appeared and disappeared near the nest.
Figure 5. Path of the birds with the marks of the beginning and end of the path (magenta and red, respectively) and highlighting the moments when the bird walked faster (green and yellow dots) for the hen-line (a) track_Id 5 that appeared and disappeared near the feeder and (b) track_Id 45 that appeared and disappeared near the nest.
Agriengineering 05 00104 g005
Figure 6. Arrow chart of chicken track_id 33 (a), highlighting a moment when the bird was still (b). The red and magenta dots correspond, respectively, to the beginning and end of tracking the monitored chicken.
Figure 6. Arrow chart of chicken track_id 33 (a), highlighting a moment when the bird was still (b). The red and magenta dots correspond, respectively, to the beginning and end of tracking the monitored chicken.
Agriengineering 05 00104 g006
Figure 7. Graph of variation of the average speed of chicken track_Id 33 every ten frames, where the peak speed corresponds to this chicken running.
Figure 7. Graph of variation of the average speed of chicken track_Id 33 every ten frames, where the peak speed corresponds to this chicken running.
Agriengineering 05 00104 g007
Figure 8. Graphs of frequency of occurrences, total observation time, and total distance covered for resting, exploring, and running behaviors for birds that walked more than 300 cm and were watched for more than 200 s without losing identification.
Figure 8. Graphs of frequency of occurrences, total observation time, and total distance covered for resting, exploring, and running behaviors for birds that walked more than 300 cm and were watched for more than 200 s without losing identification.
Agriengineering 05 00104 g008
Figure 9. Graphs of paths, variation in displacement average speed, and frame of the original video highlighting the differences in measurements observed for the chicken (a) track_Id = 148, which expresses the behavior of flapping wings, and (b) track_Id = 33, which is running. The circles mark the data in the graphs corresponding to the chickens at a given moment in the video (images) expressing different behaviors.
Figure 9. Graphs of paths, variation in displacement average speed, and frame of the original video highlighting the differences in measurements observed for the chicken (a) track_Id = 148, which expresses the behavior of flapping wings, and (b) track_Id = 33, which is running. The circles mark the data in the graphs corresponding to the chickens at a given moment in the video (images) expressing different behaviors.
Agriengineering 05 00104 g009
Figure 10. Capture of frames showing flapping wings. (a) chicken 79 was divided into two birds in identification. (b) chicken 97 is ceasing to exist.
Figure 10. Capture of frames showing flapping wings. (a) chicken 79 was divided into two birds in identification. (b) chicken 97 is ceasing to exist.
Agriengineering 05 00104 g010
Table 1. Workstation hardware configuration.
Table 1. Workstation hardware configuration.
CPUCPU Intel® Core i7-10700k
CPU frequency4.85 GHz
Cores/threads number8/16
Memory RAM64 GB
GPUNvidia RTX 2070 Super, 8 GB (2.304 CUDA cores)
Table 2. Summary of occurrences and times spent by birds running, exploring, and resting, disregarding Ids with a minimum lifetime.
Table 2. Summary of occurrences and times spent by birds running, exploring, and resting, disregarding Ids with a minimum lifetime.
Behavior ClassNumber of Occurrences (N)Overall Time (T) SecondsAverage Time
(T/N)Seconds
Resting80813,53716.8
Exploring79214901.9
Running791.3
Disclaimer/Publisher’s Note: The statements, opinions and data contained in all publications are solely those of the individual author(s) and contributor(s) and not of MDPI and/or the editor(s). MDPI and/or the editor(s) disclaim responsibility for any injury to people or property resulting from any ideas, methods, instructions or products referred to in the content.

Share and Cite

MDPI and ACS Style

Siriani, A.L.R.; Miranda, I.B.d.C.; Mehdizadeh, S.A.; Pereira, D.F. Chicken Tracking and Individual Bird Activity Monitoring Using the BoT-SORT Algorithm. AgriEngineering 2023, 5, 1677-1693. https://doi.org/10.3390/agriengineering5040104

AMA Style

Siriani ALR, Miranda IBdC, Mehdizadeh SA, Pereira DF. Chicken Tracking and Individual Bird Activity Monitoring Using the BoT-SORT Algorithm. AgriEngineering. 2023; 5(4):1677-1693. https://doi.org/10.3390/agriengineering5040104

Chicago/Turabian Style

Siriani, Allan Lincoln Rodrigues, Isabelly Beatriz de Carvalho Miranda, Saman Abdanan Mehdizadeh, and Danilo Florentino Pereira. 2023. "Chicken Tracking and Individual Bird Activity Monitoring Using the BoT-SORT Algorithm" AgriEngineering 5, no. 4: 1677-1693. https://doi.org/10.3390/agriengineering5040104

APA Style

Siriani, A. L. R., Miranda, I. B. d. C., Mehdizadeh, S. A., & Pereira, D. F. (2023). Chicken Tracking and Individual Bird Activity Monitoring Using the BoT-SORT Algorithm. AgriEngineering, 5(4), 1677-1693. https://doi.org/10.3390/agriengineering5040104

Article Metrics

Back to TopTop