Database

[{"_id":103,"name":"Fleta Duplantis","scores":[{"score":84.37799696030743,"type":"exam"},{"score":15.95792143439528,"type":"quiz"},{"score":77.80745176713172,"type":"homework"}]},{"_id":104,"name":"Potato","scores":[{"score":20.37799696030743,"type":"exam"},{"score":10.95792143439528,"type":"quiz"},{"score":10.80745176713172,"type":"homework"}]}]

Query

db.collection.aggregate({"$match":{"scores":{"$elemMatch":{"$or":[{"type":"exam","score":{"$gte":40}},{"type":"quiz","score":{"$gte":40}},{"type":"homework","score":{"$gte":40}}]}}}},{"$addFields":{"scoreAvg":{"$avg":"$scores.score"}}})

Result