-
-
Notifications
You must be signed in to change notification settings - Fork 56
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Introduce unit systems #116
Comments
I'm not a fan of the decorator idea just because it implies that a unit belongs to a single system. For example, the mile is used in both the British Imperial and US Customary systems. I think it makes more sense for a system to be composed of units and to have their definitions be decoupled. Also, in the case of using a "unit system" for simplification, it probably makes sense to have only a single, canonical unit for a given dimension. By the example above, it's unclear whether a distance should simplify to a mile or a foot if they're both part of the system. I'm not sure how Numbat deals with derived unit simplification, but the same argument likely applies in that case. |
I should also point out that decoupling unit definitions from systems does not address the dimension collision issue described above (e.g., between torque and energy). A system might need to arbitrarily choose exactly one representation for a given dimension. |
I guess you could allow the decorator to link to multiple systems, but the main thing I'd like to consider is allowing this to be extensible to user-specified unit systems that consist of arbitrary sets of units, potentially mixing and matching from others. |
I mean, we could say @system(Imperial, USCustomary)
unit mile: Length = … to associate a unit with multiple systems.
Not sure I am following. You would rather list all units when defining the system? Instead of listing the system each time a unit is introduced? Or add a separate "associated unit U with system s" statement to decouple it completely?
That is true. We could have an additional But I think that is the next-level problem. Right now, the problem we are facing is that we want to simplify something like
That is a interesting point I had not thought about. In this context, it might more sense to introduce systems by listing all units they contain. Do you have a particular use case in mind? Do you have an idea for a syntax? |
The latter is what I was thinking. Mostly with the idea of letting users define their own systems without causing any conflicts, and being able to tie units together at arbitrary times.
Agreed.
The use case is basically being able to use an arbitrary system as the basis for simplification. Sometimes it's better to use cgs, somteimes mks, sometimes Planck. We can bake in as many of these with the unit definitions, but without users being able to mix and match them post-hoc, we'll always be missing some useful system for somebody. Similarly, you can imagine a situation where you might want areas in acres, volume in gallons, and distance in feet (for example, if you're working on a vineyard/winery). Perhaps this is a bad example (even in the US), but this is the basic idea.
It's hard to say without existing list or collection types right now. Especially if we didn't demand that every unit system is exhaustive, then we'll need to fall back to base defaults for unspecified units/dimensions (this also makes it tricky). In my head, I was thinking of something like a heterogenous list (or tuple) of types specifying the preferred unit for a fixed set of dimensions, e.g.,
Then the checker ensures that there's at most one unique representation of each dimension in that list. (Again, not sure about fallbacks, in particular with the use of custom dimensions; this can probably just fall back to whatever is happening now.) |
It would be helpful to include systems of units (SI, Imperial, US Customary, ) as a new concept. Units could then be assigned to those systems, e.g. with a decorator:
We could think about whether or not we want to allow multiple units of the same dimension per system (e.g. both foot and mile belong to Imperial), or if we want to allow just one "canonical" unit per phys. dimension .
This would help us when performing automatic simplification. For example: we could ask: what is the canonical unit to represent lengths in system XY? (caveat: there is not always a 1:1 relationship. For example: torque has the same dimension as energy, frequency has the same dimension as activity)
If I thought this through correctly, this would also completely solve sharkdp/insect#112. Because we could do sth. like
and then we could — for example — add a new conversion syntax
expr -> System
, where we would take the type ofexpr
and then look up the canonical type in System. This would allow us to do:(see also: sharkdp/insect#184)
The text was updated successfully, but these errors were encountered: