I am new to R.
I have a large dataset that goes over 15 years (2007-2022) (see below an example portion). Essentially, I want to create a 12-month rolling window and remove the rows within 12 months of the first collection date for each subject. For instance, subject 1002 has 3 collection time points: 1st Jan 2007, 1st June 2007 and 1st Jan 2008. Using the 12-month window criteria from the first day (1st Jan 2007), I want to remove rows that contain 1st June 2007 (less than 12 months since the first day) and keep the 1st Jan 2008 (12 months from the first day). This is also the same for 1004, where the rows with the date 1st Jan 2013 is within 12 months of the previous date 1st of Feb 2012.
df<- tribble(~Subject_ID,~Collection_ID,~Date,~Sample,~Test,~Status,
            1001,1119139,"2007-01-01","E","A","N",1001,1119139,"2007-01-01","E","A","N",1001,1119139,"2007-01-01","E","A","N",1001,1119139,"2007-01-01","E","A","N",1001,1119139,"2007-01-01","E","A","N",1002,1023347,"2007-01-01","E","A","N", 1002,1023347,"2007-01-01","E","A","N", 1002,1023347,"2007-01-01","E","A","N",1002,1023347,"2007-01-01","E","A","N",1002,1023347,"2007-01-01","E","A","N",1002,1023347,"2007-01-01","E","A","N",1002,1129086,"2007-06-01","E","A","N",1002,1129086,"2007-06-01","E","A","N",1002,1129086,"2007-06-01","E","A","N",1002,1129086,"2007-06-01","E","A","N",1002,1129086,"2007-06-01","E","A","N",1002,1105112,"2008-01-01","E","A","N",1002,1105112,"2008-01-01","E","A","N",1002,1105112,"2008-01-01","E","A","N",1002,1105112,"2008-01-01","E","A","N",1002,1105112,"2008-01-01","E","A","N",1003,1057321,"2010-03-01","E","A","N",1003,1057321,"2010-03-01","E","A","N",1003,1057321,"2010-03-01","E","A","N",1003,1057321,"2010-03-01","E","A","N",1003,1057321,"2010-03-01","E","A","N",1004,1022691,"2012-02-01","E","A","N",1004,1022691,"2012-02-01","E","A","N",1004,1022691,"2012-02-01","E","A","N",1004,1022691,"2012-02-01","E","A","N",1004,1022691,"2012-02-01","E","A","N",1004,1070101,"2013-01-01","E","A","N",1004,1070101,"2013-01-01","E","A","N",1004,1070101,"2013-01-01","E","A","N",1004,1070101,"2013-01-01","E","A","N",1004,1070101,"2013-01-01","E","A","N",1004,1070101,"2013-01-01","E","A","N",)
My desired output is the following:

Many thanks in advance!
 
                        
With package
lubridate, you can remove rows that are not in the beginning of the year: