Я столкнулся с проблемой при работе с функциональностью Units of Measurements в metascala , определенной в файле Units.scala .
В оставшейся части этого вопроса я буду использовать упрощенную схему только с одним типом юнитов, длиной.
Так, где на самом деле тип выглядит как
Quantity[_1, _0, _0, _0, _0, _0, _0]
^ ^ ^ ^ ^ ^ ^
| | | | | | |
| Mass | Crncy.| Mol |
Length Time Temp. Lum.Intensity
этого будет достаточно для демонстрации проблемы:
Quantity[_1]
^
|
Length
Как только тип должен быть выведен, проблема начинается.
Рассмотрим этот пример (также взгляните на код из UnitsTest.scala ):
val length: Quantity[_1] = m(5)
val area: Quantity[_2] = length * length // (1) Works
val dist: Quantity[_1] = area / length // (2) Doesn't work!
В последней строке появляется ошибка:
type mismatch;
found :
scalax.units.Units.Quantity[
scalax.units.Subtractables.-[
scalax.units.Integers._2,
scalax.units.Integers._1
]
]
required:
scalax.units.Units.Quantity[
scalax.units.Integers._1
]
Похоже, что компилятор не может понять, что тип под рукой равен Quantity[_1]
при "вычитании измерения", e. г. переходя из района в расстояние, как в (1)
:
Quantity[_2 - _1] <<not equal to>> Quantity[_1]
Смущает то, что это работает при "добавлении измерения" e. г. переходя от длины к области, как в (2)
:
Quantity[_1 + _1] <<equal to>> Quantity[_2]
(Извините, что не вставил здесь весь код, это слишком много. Я пытался свернуть пример, но потерпел неудачу. Вот почему я просто ссылаюсь на него.)