Skip to content

Instantly share code, notes, and snippets.

@pjazdzewski1990
Created February 25, 2016 09:17
Embed
What would you like to do?
case class Power(first: Component, second: Component) extends Component {
override def toTree(implicit c: blackbox.Context): c.Tree = {
import c.universe._
q"Math.pow(${first.toTree}, ${second.toTree})"
}
override def derive: Component = this match {
case Power(Variable(_), DoubleConstant(b)) =>
Multiply(second, Power(first, DoubleConstant(b - 1)))
}
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment