Exemple #1
0
        public Measure Divide(DerivedMeasure d)
        {
            if (d == this)
            {
                return(new BaseMeasure());
            }
            var a = new MeasureTerms();

            foreach (var e in Terms)
            {
                var c = new MeasureTerm {
                    Measure = e.Measure, Power = e.Power
                };
                a.Add(c);
            }
            foreach (var e in d.Terms)
            {
                var c = new MeasureTerm {
                    Measure = e.Measure, Power = e.Power
                };
                c.Power = -c.Power;
                a.Add(c);
            }
            a.RemoveAll(x => x.Power == 0);
            return(new DerivedMeasure(a));
        }
Exemple #2
0
 public DerivedMeasure(MeasureTerms terms, string name = null, string symbol = null)
 {
     terms       = terms ?? new MeasureTerms();
     this.terms  = terms;
     this.name   = name ?? terms.Formula();
     this.symbol = symbol ?? name;
     definition  = name;
 }
Exemple #3
0
        public Measure Reciprocal()
        {
            var t1 = new MeasureTerm(this, -1);
            var t  = new MeasureTerms {
                t1
            };

            return(new DerivedMeasure(t));
        }
Exemple #4
0
        public Measure Multiply(BaseMeasure m, bool isDivide = false)
        {
            var t1 = new MeasureTerm(this, 1);
            var t2 = isDivide? new MeasureTerm(m, -1) : new MeasureTerm(m, 1);
            var t  = new MeasureTerms {
                t1, t2
            };

            return(new DerivedMeasure(t));
        }
Exemple #5
0
        public Measure Multiply(DerivedMeasure m)
        {
            var t = new MeasureTerms();

            t.Add(new MeasureTerm(this, 1));
            foreach (var e in m.Terms)
            {
                t.Add(new MeasureTerm(e.Measure as BaseMeasure, e.Power));
            }
            return(new DerivedMeasure(t));
        }
Exemple #6
0
        public Measure Reciprocal()
        {
            var a = new MeasureTerms();

            foreach (var e in Terms)
            {
                var c = Clone(e);
                c.Power = c.Power * -1;
                a.Add(c);
            }
            return(new DerivedMeasure(a));
        }
Exemple #7
0
        public Measure Reciprocal()
        {
            var a = new MeasureTerms();

            foreach (var e in Terms)
            {
                var c = new MeasureTerm {
                    Measure = e.Measure, Power = e.Power
                };
                c.Power *= -1;
                a.Add(c);
            }
            return(new DerivedMeasure(a));
        }
Exemple #8
0
        public Measure Multiply(DerivedMeasure d)
        {
            var a = new MeasureTerms();

            foreach (var e in Terms)
            {
                var c = Clone(e);
                a.Add(c);
            }
            foreach (var e in d.Terms)
            {
                var c = Clone(e);
                a.Add(c);
            }
            return(new DerivedMeasure(a));
        }
Exemple #9
0
        public Measure Exponentiation(int i)
        {
            if (i == 0)
            {
                return(Empty);
            }
            var a = new MeasureTerms();

            foreach (var e in Terms)
            {
                var c = Clone(e);
                c.Power = c.Power * i;
                a.Add(c);
            }
            return(new DerivedMeasure(a));
        }
Exemple #10
0
        public Measure Exponentiation(int i)
        {
            if (i == 0)
            {
                return(new BaseMeasure());
            }
            var a = new MeasureTerms();

            foreach (var e in Terms)
            {
                var c = new MeasureTerm {
                    Measure = e.Measure, Power = e.Power
                };
                c.Power *= i;
                a.Add(c);
            }
            return(new DerivedMeasure(a));
        }
Exemple #11
0
        public Measure Multiply(DerivedMeasure d)
        {
            var a = new MeasureTerms();

            foreach (var e in Terms)
            {
                var c = new MeasureTerm {
                    Measure = e.Measure, Power = e.Power
                };
                a.Add(c);
            }
            foreach (var e in d.Terms)
            {
                var c = new MeasureTerm {
                    Measure = e.Measure, Power = e.Power
                };
                a.Add(c);
            }
            return(new DerivedMeasure(a));
        }
Exemple #12
0
        public Measure Divide(DerivedMeasure d)
        {
            if (d == this)
            {
                return(Empty);
            }
            var a = new MeasureTerms();

            foreach (var e in Terms)
            {
                var c = Clone(e);
                a.Add(c);
            }
            foreach (var e in d.Terms)
            {
                var c = Clone(e);
                c.Power = -c.Power;
                a.Add(c);
            }
            a.RemoveAll(x => x.Power == 0);
            return(new DerivedMeasure(a));
        }
Exemple #13
0
        public Measure Exponentiation(int i)
        {
            if (i == 0)
            {
                return(Empty);
            }
            MeasureTerm t1;

            if (i == 1)
            {
                t1 = new MeasureTerm(this);
            }
            else
            {
                t1 = new MeasureTerm(this, i);
            }
            var t = new MeasureTerms {
                t1
            };

            return(new DerivedMeasure(t));
        }
Exemple #14
0
 protected override void SetRandomValues()
 {
     base.SetRandomValues();
     terms = MeasureTerms.Random();
 }