Rozwiązałem problem, powinienem zastosować $match przed i po $unwind :
Aggregation.match(Criteria.where("alertsources.date_creation").regex(".*"+date+".*")),
Aggregation.match(Criteria.where("descA").is(alertName)),
//regex(".*"+date+".*")
Aggregation.unwind("alertsources"),
Aggregation.unwind("descA"),
Aggregation.match(Criteria.where("alertsources.date_creation").regex(".*"+date+".*")),
Aggregation.group().count().as("count")
Cała zasługa należy do @Neil Lunn , po przeprowadzeniu badań znalazłem jego oryginalną odpowiedź na temat.