All Downloads are FREE. Search and download functionalities are using the official Maven repository.

lucuma.catalog.BrightnessConstraints.scala Maven / Gradle / Ivy

// Copyright (c) 2016-2023 Association of Universities for Research in Astronomy, Inc. (AURA)
// For license information see LICENSE or https://opensource.org/licenses/BSD-3-Clause

package lucuma.catalog

import cats.Eq
import cats.Order
import cats.derived.*
import cats.syntax.all.*
import eu.timepit.refined.cats.*
import lucuma.core.enums.Band
import lucuma.core.math.BrightnessValue

/**
 * Constrain a target if a brightness is fainter than a threshold
 */
case class FaintnessConstraint(brightness: BrightnessValue) derives Order

/**
 * Constrain a target's if a brightness is brighter than a threshold
 */
case class SaturationConstraint(brightness: BrightnessValue) derives Order

/**
 * Describes constraints for the brightness of a target
 */
case class BrightnessConstraints(
  searchBands:          BandsList,
  faintnessConstraint:  FaintnessConstraint,
  saturationConstraint: Option[SaturationConstraint]
) derives Eq {
  def contains(band: Band, brightness: BrightnessValue): Boolean =
    searchBands.bands.contains(band) &&
      faintnessConstraint.brightness >= brightness &&
      saturationConstraint.forall(_.brightness <= brightness)

  def ∪(that: BrightnessConstraints): BrightnessConstraints =
    BrightnessConstraints(
      searchBands ∪ that.searchBands,
      FaintnessConstraint(
        faintnessConstraint.brightness.max(that.faintnessConstraint.brightness)
      ),
      (this.saturationConstraint, that.saturationConstraint) match {
        case (a @ Some(_), None) => a
        case (None, a @ Some(_)) => a
        case (Some(a), Some(b))  =>
          SaturationConstraint(a.brightness.min(b.brightness)).some
        case _                   => none
      }
    )
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy