(def varpars [{:symbol "x", :quantity "mass"}
              {:symbol "y", :quantity "length"}
              {:symbol "t", :quantity "time"}])
For this introductory tutorial imagine the equation derived from experimental observations is
u = (x3/y)t + xy6t20 + x3/(y3t3) + x4/t8
What are its dimensionless products?
The four steps for deriving the dimensionless products are as follows.
Let us define
p ≜ (x3/y)t, q ≜ xy6t20, r ≜ x3/(y3t3), s ≜ x4/t8
Replacing p, q, r and s for the terms in the main equation we get
u = p + q + r + s
Broadly, the task is to
generate dimensional formula for each term
insert all the generated dimensional formula into standard_formula
Define all the symbols in the parent mathematical expression that is associated with a dimension.
(def varpars [{:symbol "x", :quantity "mass"}
              {:symbol "y", :quantity "length"}
              {:symbol "t", :quantity "time"}])
Considering each term of the parent equation as some individual equation we define each of them as follows
(def p_equation {:lhs "p^(1)", :rhs {:term1 "x^(2)*y^(-1)*t^(1)"}})
(def q_equation {:lhs "q^(1)", :rhs {:term1 "x^(1)*y^(6)*t^(20)"}})
(def r_equation {:lhs "r^(1)", :rhs {:term1 "x^(3)*y^(-3)*t^(-3)"}})
(def s_equation {:lhs "s^(1)", :rhs {:term1 "x^(4)*t^(8)"}})
and then stacking the equations into a vector
(def manifold_eqn [{:name "term-p", :eqn (:rhs p_equation)}
                   {:name "term-q", :eqn (:rhs q_equation)}
                   {:name "term-r", :eqn (:rhs r_equation)}
                   {:name "term-s", :eqn (:rhs s_equation)}])
The two steps are equivalent to
(def manifold_eqn [{:name "term-p", :eqn {:term1 "x^(2)*y^(-1)*t^(1)"}}
                   {:name "term-q", :eqn {:term1 "x^(1)*y^(6)*t^(20)"}}
                   {:name "term-r", :eqn {:term1 "x^(3)*y^(-3)*t^(-3)"}}
                   {:name "term-s", :eqn {:term1 "x^(4)*t^(8)"}}])
However, the two step approach is recommended because it affords the user the flexibility to actually see the generation of individual dimensional formula and hence introspecting them.
The dimensional formula for one side of the expression (often right hand
side) for every equation in the vector of all the equations defined
earlier can be generated using the formula-eqn-side-manifold function.
=> (pprint (formula-eqn-side-manifold varpars manifold_eqn))
[{:quantity "term-p", :dimension "[L^(-1)*M^(2)*T^(1)]"}
{:quantity "term-q", :dimension "[L^(6)*M^(1)*T^(20)]"}
{:quantity "term-r", :dimension "[T^(-3)*L^(-3)*M^(3)]"}
{:quantity "term-s", :dimension "[M^(4)*T^(8)]"}]
All the dimensional formula generated from each equation in the vector
of equations is added to the standard_formula with
=> (update-sformula (formula-eqn-side-manifold varpars manifold_eqn))
[{:quantity "volume", :dimension "[L^(3)]"}
{:quantity "frequency", :dimension "[T^(-1)]"}
{:quantity "velocity", :dimension "[L^(1)*T^(-1)]"}
{:quantity "acceleration", :dimension "[L^(1)*T^(-2)]"}
{:quantity "force", :dimension "[M^(1)*L^(1)*T^(-2)]"}
...
{:quantity "term-s", :dimension "[M^(4)*T^(8)]"}
{:quantity "term-r", :dimension "[T^(-3)*L^(-3)*M^(3)]"}
{:quantity "term-q", :dimension "[L^(6)*M^(1)*T^(20)]"}
{:quantity "term-p", :dimension "[L^(-1)*M^(2)*T^(1)]"}]
Since all the dimensional formula of p, q, r and s,
representing all the terms in
the main equation are now part of the standard_formula, we can now
define all the symbols in the reduced form of the parent mathematical
expression
u = p + q + r + s
The definition will be such that each term symbol has the dimension name
as defined in the preceeding step (and hence incorporated into the
standard_formula. For instance, since the term p
(p ≜ (x3/y)t) was named "term-p" in
=> (pprint manifold_eqn)
[{:name "term-p", :eqn {:term1 "x^(2)*y^(-1)*t^(1)"}}
{:name "term-q", :eqn {:term1 "x^(1)*y^(6)*t^(20)"}}
{:name "term-r", :eqn {:term1 "x^(3)*y^(-3)*t^(-3)"}}
{:name "term-s", :eqn {:term1 "x^(4)*t^(8)"}}]
we will have {:symbol "p", :dimension "term-p"}. Therefore, we define
(def varpars2 [{:symbol "p", :quantity "term-p"}
               {:symbol "q", :quantity "term-q"}
               {:symbol "r", :quantity "term-r"}
               {:symbol "s", :quantity "term-s"}])
The dimensional matrix of the parent equation is generated with the help
of the generate-dimmat function.
=> (view-matrix (generate-dimmat varpars2)) [1N 20N -3N 8N] [2N 1N 3N 4N] [-1N 6N -3N 0] Size -> 3 x 4
This is a 3 × 4 dimensional matrix.
=> (view-matrix (get-augmented-matrix (generate-dimmat varpars2))) [-3N 8N -1N -20N] [3N 4N -2N -1N] [-3N 0 1N -6N] Size -> 3 x 4
=> (view-matrix (solve (get-augmented-matrix (generate-dimmat varpars2)))) [1N 0N -1/3 2N] [0N 1N -1/4 -7/4] [0N 0N 0N 0N] Size -> 3 x 4
=> (view-matrix (get-solution-matrix (solve (get-augmented-matrix (generate-dimmat varpars2))))) [1 0 -1/3 -1/4] [0 1 2N -7/4] Size -> 2 x 4
This is a 2 × 4 matrix. Therefore, there will be two dimensionless products.
We can put all these individual steps involving matrix into one coding step such that it returns the solution matrix.
=> (def solution_matrix (get-solution-matrix
                            (solve
                                (get-augmented-matrix
                                    (generate-dimmat varpars2)))))
=> (view-matrix solution_matrix)
[1 0 -1/3 -1/4]
[0 1 2N -7/4]
Size -> 2 x 4
The dimensionless products are generated with the help of the
get-dimensionless-products function.
=> (pprint (get-dimensionless-products solution_matrix varpars2))
[{:symbol "pi0", :expression "p^(1)*r^(-1/3)*s^(-1/4)"}
{:symbol "pi1", :expression "q^(1)*r^(2)*s^(-7/4)"}]
Since, π is the conventional symbol for dimensionless products to get
the πi th one use the
get-pi-expression function. For example, for π0
=> (def all-dimless (get-dimensionless-products solution_matrix varpars2)) => (get-pi-expression all-dimless "pi0") "p^(1)*r^(-1/3)*s^(-1/4)"
Can you improve this documentation?Edit on GitHub
cljdoc builds & hosts documentation for Clojure/Script libraries
| Ctrl+k | Jump to recent docs | 
| ← | Move to previous article | 
| → | Move to next article | 
| Ctrl+/ | Jump to the search field |