コード例 #1
0
ファイル: Layers.cs プロジェクト: Chloe0317/ApsimX
        /// <summary>Sets the soil organic matter thickness.</summary>
        /// <param name="soilOrganicMatter">The soil organic matter.</param>
        /// <param name="thickness">Thickness to change soil water to.</param>
        private static void SetSoilOrganicMatterThickness(Organic soilOrganicMatter, double[] thickness)
        {
            if (soilOrganicMatter != null)
            {
                if (!MathUtilities.AreEqual(thickness, soilOrganicMatter.Thickness))
                {
                    soilOrganicMatter.FBiom       = MapConcentration(soilOrganicMatter.FBiom, soilOrganicMatter.Thickness, thickness, MathUtilities.LastValue(soilOrganicMatter.FBiom));
                    soilOrganicMatter.FInert      = MapConcentration(soilOrganicMatter.FInert, soilOrganicMatter.Thickness, thickness, MathUtilities.LastValue(soilOrganicMatter.FInert));
                    soilOrganicMatter.Carbon      = MapConcentration(soilOrganicMatter.Carbon, soilOrganicMatter.Thickness, thickness, MathUtilities.LastValue(soilOrganicMatter.Carbon));
                    soilOrganicMatter.SoilCNRatio = MapConcentration(soilOrganicMatter.SoilCNRatio, soilOrganicMatter.Thickness, thickness, MathUtilities.LastValue(soilOrganicMatter.SoilCNRatio));
                    soilOrganicMatter.FOM         = MapMass(soilOrganicMatter.FOM, soilOrganicMatter.Thickness, thickness, false);
                    soilOrganicMatter.Thickness   = thickness;
                }

                if (soilOrganicMatter.FBiom != null)
                {
                    MathUtilities.ReplaceMissingValues(soilOrganicMatter.FBiom, MathUtilities.LastValue(soilOrganicMatter.FBiom));
                }
                if (soilOrganicMatter.FInert != null)
                {
                    MathUtilities.ReplaceMissingValues(soilOrganicMatter.FInert, MathUtilities.LastValue(soilOrganicMatter.FInert));
                }
                if (soilOrganicMatter.Carbon != null)
                {
                    MathUtilities.ReplaceMissingValues(soilOrganicMatter.Carbon, MathUtilities.LastValue(soilOrganicMatter.Carbon));
                }
            }
        }
コード例 #2
0
 protected override void ReadData(ESPReader reader)
 {
     using (MemoryStream stream = new MemoryStream(reader.ReadBytes(size)))
         using (ESPReader subReader = new ESPReader(stream, reader.Plugin))
         {
             try
             {
                 Stone.ReadBinary(subReader);
                 Dirt.ReadBinary(subReader);
                 Grass.ReadBinary(subReader);
                 Glass.ReadBinary(subReader);
                 Metal.ReadBinary(subReader);
                 Wood.ReadBinary(subReader);
                 Organic.ReadBinary(subReader);
                 Cloth.ReadBinary(subReader);
                 Water.ReadBinary(subReader);
                 HollowMetal.ReadBinary(subReader);
                 OrganicBug.ReadBinary(subReader);
                 OrganicGlow.ReadBinary(subReader);
             }
             catch
             {
                 return;
             }
         }
 }
コード例 #3
0
ファイル: ExpAshBurns.cs プロジェクト: binkul/LabBook_WPF
        public override int GetHashCode()
        {
            int hashCode = -1002186340;

            hashCode = hashCode * -1521134295 + LabBookId.GetHashCode();
            hashCode = hashCode * -1521134295 + Solid.GetHashCode();
            hashCode = hashCode * -1521134295 + Ash450.GetHashCode();
            hashCode = hashCode * -1521134295 + Ash900.GetHashCode();
            hashCode = hashCode * -1521134295 + Organic.GetHashCode();
            hashCode = hashCode * -1521134295 + Titanium.GetHashCode();
            hashCode = hashCode * -1521134295 + Chalk.GetHashCode();
            hashCode = hashCode * -1521134295 + Others.GetHashCode();
            hashCode = hashCode * -1521134295 + VocCatId.GetHashCode();
            hashCode = hashCode * -1521134295 + EqualityComparer <string> .Default.GetHashCode(VocAmount);

            hashCode = hashCode * -1521134295 + Crucible1.GetHashCode();
            hashCode = hashCode * -1521134295 + Crucible2.GetHashCode();
            hashCode = hashCode * -1521134295 + Crucible3.GetHashCode();
            hashCode = hashCode * -1521134295 + Paint1.GetHashCode();
            hashCode = hashCode * -1521134295 + Paint2.GetHashCode();
            hashCode = hashCode * -1521134295 + Paint3.GetHashCode();
            hashCode = hashCode * -1521134295 + Crucible105_1.GetHashCode();
            hashCode = hashCode * -1521134295 + Crucible105_2.GetHashCode();
            hashCode = hashCode * -1521134295 + Crucible105_3.GetHashCode();
            hashCode = hashCode * -1521134295 + Crucible405_1.GetHashCode();
            hashCode = hashCode * -1521134295 + Crucible405_2.GetHashCode();
            hashCode = hashCode * -1521134295 + Crucible405_3.GetHashCode();
            hashCode = hashCode * -1521134295 + Crucible900_1.GetHashCode();
            hashCode = hashCode * -1521134295 + Crucible900_2.GetHashCode();
            hashCode = hashCode * -1521134295 + Crucible900_3.GetHashCode();
            hashCode = hashCode * -1521134295 + Created.GetHashCode();
            hashCode = hashCode * -1521134295 + Updated.GetHashCode();
            return(hashCode);
        }
コード例 #4
0
ファイル: ImporterTests.cs プロジェクト: markje153/ApsimX-1
        public void ImporterTests_SoilImports()
        {
            string oldXml = ReflectionUtilities.GetResourceAsString("UnitTests.ImporterTestsSoilImports.xml");

            APSIMImporter importer = new APSIMImporter();
            Simulations   sims     = importer.CreateSimulationsFromXml(oldXml);

            Soil s = sims.Children[0].Children[0] as Soil;

            Assert.AreEqual(s.Name, "Soil");

            InitialWater initWater = s.Children[0] as InitialWater;

            Assert.AreEqual(initWater.FractionFull, 0.5);
            Assert.AreEqual(initWater.PercentMethod, InitialWater.PercentMethodEnum.FilledFromTop);

            Physical w = s.Children[1] as Physical;

            Assert.AreEqual(w.Thickness, new double[] { 150, 150, 300, 300 });
            Assert.AreEqual(w.BD, new double[] { 1.02, 1.03, 1.02, 1.02 });
            Assert.AreEqual(w.LL15, new double[] { 0.29, 0.29, 0.29, 0.29 });

            SoilWater sw = s.Children[2] as SoilWater;

            Assert.AreEqual(sw.Thickness, new double[] { 150, 150, 300, 300 });
            Assert.AreEqual(sw.SWCON, new double[] { 0.3, 0.3, 0.3, 0.3 });
            Assert.AreEqual(sw.SummerCona, 3.5);
            Assert.AreEqual(sw.SummerU, 6);
            Assert.AreEqual(sw.WinterCona, 2);
            Assert.AreEqual(sw.WinterU, 2);

            Assert.IsTrue(s.Children[3] is SoilNitrogen);

            Organic som = s.Children[4] as Organic;

            Assert.AreEqual(som.Thickness, new double[] { 150, 150, 300, 300 });
            Assert.AreEqual(som.Carbon, new double[] { 1.04, 0.89, 0.89, 0.89 });
            Assert.AreEqual(som.FBiom, new double[] { 0.025, 0.02, 0.015, 0.01 });

            Chemical a = s.Children[5] as Chemical;

            Assert.AreEqual(a.Thickness, new double[] { 150, 150, 300, 300 });
            Assert.AreEqual(a.NO3N, new double[] { 6.5, 2.1, 2.1, 1.0 });
            Assert.AreEqual(a.NH4N, new double[] { 0.5, 0.1, 0.1, 0.2 });
            Assert.AreEqual(a.EC, new double[] { 0.2, 0.25, 0.31, 0.40 });
            Assert.AreEqual(a.PH, new double[] { 8.4, 8.8, 9.0, 9.2 });

            Sample sam = s.Children[6] as Sample;

            Assert.AreEqual(sam.Thickness, new double[] { 150, 150, 300 });

            SoilCrop crop = s.Children[1].Children[0] as SoilCrop;

            Assert.AreEqual(crop.LL, new double[] { 0.29, 0.29, 0.32, 0.38 });
            Assert.AreEqual(crop.KL, new double[] { 0.1, 0.1, 0.08, 0.06 });
            Assert.AreEqual(crop.XF, new double[] { 1, 1, 1, 1 });
        }
コード例 #5
0
        public void FeedShouldLowerHungerByOne()
        {
            string  fakeName    = "";
            string  fakeSpecies = "";
            Organic sut         = new Organic(fakeName, fakeSpecies);

            sut.FeedPet();
            Assert.Equal(49, sut.Hunger);
        }
コード例 #6
0
 protected override void WriteData(ESPWriter writer)
 {
     Stone.WriteBinary(writer);
     Dirt.WriteBinary(writer);
     Grass.WriteBinary(writer);
     Glass.WriteBinary(writer);
     Metal.WriteBinary(writer);
     Wood.WriteBinary(writer);
     Organic.WriteBinary(writer);
     Cloth.WriteBinary(writer);
     Water.WriteBinary(writer);
     HollowMetal.WriteBinary(writer);
     OrganicBug.WriteBinary(writer);
     OrganicGlow.WriteBinary(writer);
 }
コード例 #7
0
        public static Certification CreateCertification(CertificationTypes certificationType, DCAnalyticsObject parent)
        {
            Certification certification = null;

            switch (certificationType)
            {
            case CertificationTypes.FairTrade:
                certification = new FairTrade(parent);
                break;

            case CertificationTypes.Organic:
                certification = new Organic(parent);
                break;

            case CertificationTypes.UTZ:
                certification = new UTZ(parent);
                break;
            }
            return(certification);
        }
コード例 #8
0
        public Media(dynamic input)
        {
            try
            {
                OriginalObject = input;

                Enum.TryParse(input.type, true, out MediaType mediaType);

                MediaKey = input.media_key;
                Type     = mediaType;
                Height   = input.height;
                Width    = input.width;
                if (Helpers.HasProperty(input, "duration_ms"))
                {
                    Duration = input.duration_ms;
                }
                if (Helpers.HasProperty(input, "preview_image_url"))
                {
                    PreviewImageUrl = new Uri(input.preview_image_url);
                }

                if (Helpers.HasProperty(input, "non_public_metrics"))
                {
                    NonPublicMetrics = new NonPublic(input.non_public_metrics);
                }
                if (Helpers.HasProperty(input, "organic_metrics"))
                {
                    OrganicMetrics = new Organic(input.organic_metrics);
                }
                if (Helpers.HasProperty(input, "promoted_metrics"))
                {
                    PromotedMetrics = new Promoted(input.promoted_metrics);
                }
            }
            catch {
                // any missing properties that are not on the input object
                // and not caught with Helpers.HasProperty if statement,
                // do not fail (for now)
            }
        }
コード例 #9
0
        protected override void WriteDataXML(XElement ele, ElderScrollsPlugin master)
        {
            XElement subEle;

            ele.TryPathTo("Stone", true, out subEle);
            Stone.WriteXML(subEle, master);

            ele.TryPathTo("Dirt", true, out subEle);
            Dirt.WriteXML(subEle, master);

            ele.TryPathTo("Grass", true, out subEle);
            Grass.WriteXML(subEle, master);

            ele.TryPathTo("Glass", true, out subEle);
            Glass.WriteXML(subEle, master);

            ele.TryPathTo("Metal", true, out subEle);
            Metal.WriteXML(subEle, master);

            ele.TryPathTo("Wood", true, out subEle);
            Wood.WriteXML(subEle, master);

            ele.TryPathTo("Organic", true, out subEle);
            Organic.WriteXML(subEle, master);

            ele.TryPathTo("Cloth", true, out subEle);
            Cloth.WriteXML(subEle, master);

            ele.TryPathTo("Water", true, out subEle);
            Water.WriteXML(subEle, master);

            ele.TryPathTo("HollowMetal", true, out subEle);
            HollowMetal.WriteXML(subEle, master);

            ele.TryPathTo("OrganicBug", true, out subEle);
            OrganicBug.WriteXML(subEle, master);

            ele.TryPathTo("OrganicGlow", true, out subEle);
            OrganicGlow.WriteXML(subEle, master);
        }
コード例 #10
0
ファイル: TweetInfo.cs プロジェクト: douglas-f/BluebirdPS
        public Tweet(dynamic input)
        {
            try
            {
                OriginalObject = input;

                Id                = input.id;
                Text              = input.text;
                AuthorId          = input.author_id;
                ConversationId    = input.conversation_id;
                CreatedAt         = input.created_at;
                Entities          = BaseEntity.GetEntities(input.entities);
                InReplyToUserId   = input.in_reply_to_user_id;
                Language          = input.lang;
                PossiblySensitive = input.possibly_sensitive;
                PublicMetrics     = new Metrics.Public(input.public_metrics);
                Source            = input.source;

                if (Helpers.HasProperty(input, "attachments"))
                {
                    Attachments = new Attachments(input.attachments);
                }

                if (Helpers.HasProperty(input, "geo"))
                {
                    Geo            = input.geo;
                    OriginalObject = input;
                }

                if (Helpers.HasProperty(input, "reply_settings"))
                {
                    ReplySettings = Helpers.ToTitleCase(input.reply_settings);
                }

                if (Helpers.HasProperty(input, "withheld"))
                {
                    Withheld = new WithheldContent(input.withheld);
                }

                if (Helpers.HasProperty(input, "referenced_tweets"))
                {
                    List <ReferencedTweet> referencedTweets = new List <ReferencedTweet>();
                    foreach (dynamic refTweet in input.referenced_tweets)
                    {
                        referencedTweets.Add(new ReferencedTweet(refTweet));
                    }
                    ReferencedTweets = referencedTweets;
                }

                if (Helpers.HasProperty(input, "context_annotations"))
                {
                    List <Context.ContextAnnotation> contextAnnotations = new List <Context.ContextAnnotation>();
                }

                if (Helpers.HasProperty(input, "non_public_metrics"))
                {
                    NonPublicMetrics = new NonPublic(input.non_public_metrics);
                }
                if (Helpers.HasProperty(input, "organic_metrics"))
                {
                    OrganicMetrics = new Organic(input.organic_metrics);
                }
                if (Helpers.HasProperty(input, "promoted_metrics"))
                {
                    PromotedMetrics = new Promoted(input.promoted_metrics);
                }
            }
            catch
            {
                // any missing properties that are not on the input object
                // and not caught with Helpers.HasProperty if statement,
                // do not fail (for now)
            }
        }
コード例 #11
0
ファイル: DownloadPresenter.cs プロジェクト: RobZys/ApsimX
        /// This alternative approach for obtaining ISRIC soil data need a little bit more work, but is largely complete
        /// There are still bits of the soil organic matter initialisation that should be enhanced.
        /// We probably don't really need two different ways to get to ISRIC data, but it may be interesting to see how the
        /// two compare. The initial motiviation was what appears to be an order-of-magnitude problem with soil carbon
        /// in the World Modellers version.
        /// <summary>
        /// Gets and ISRIC soil description directly from SoilGrids
        /// </summary>
        /// <returns>True if successful</returns>
        private IEnumerable <SoilFromDataSource> GetISRICSoils()
        {
            var    soils = new List <SoilFromDataSource>();
            string url   = "https://rest.soilgrids.org/query?lon=" +
                           longitudeEditBox.Text + "&lat=" + latitudeEditBox.Text;

            try
            {
                double[] bd       = new double[7];
                double[] coarse   = new double[7];
                double[] clay     = new double[7];
                double[] silt     = new double[7];
                double[] sand     = new double[7];
                double[] thetaSat = new double[7];
                double[] awc20    = new double[7];
                double[] awc23    = new double[7];
                double[] awc25    = new double[7];
                double[] thetaWwp = new double[7];
                double[] ocdrc    = new double[7];
                double[] phWater  = new double[7];
                double[] cationEC = new double[7];
                double[] texture  = new double[7];
                string   soilType = String.Empty;
                double   maxTemp  = 0.0;
                double   minTemp  = 0.0;
                double   ppt      = 0.0;
                double   bedrock  = 2500.0;

                string[]     textureClasses = new string[] { "Clay", "Silty Clay", "Sandy Clay", "Clay Loam", "Silty Clay Loam", "Sandy Clay Loam", "Loam", "Silty Loam", "Sandy Loam", "Silt", "Loamy Sand", "Sand", "NO DATA" };
                double[]     textureToAlb   = new double[] { 0.12, 0.12, 0.13, 0.13, 0.12, 0.13, 0.13, 0.14, 0.13, 0.13, 0.16, 0.19, 0.13 };
                double[]     textureToCN2   = new double[] { 73.0, 73.0, 73.0, 73.0, 73.0, 73.0, 73.0, 73.0, 68.0, 73.0, 68.0, 68.0, 73.0 };
                double[]     textureToSwcon = new double[] { 0.25, 0.3, 0.3, 0.4, 0.5, 0.5, 0.5, 0.5, 0.6, 0.5, 0.6, 0.75, 0.5 };
                MemoryStream stream         = WebUtilities.ExtractDataFromURL(url);
                stream.Position = 0;
                JsonTextReader reader = new JsonTextReader(new StreamReader(stream));
                while (reader.Read())
                {
                    if (reader.TokenType == JsonToken.PropertyName && reader.Value.Equals("properties") && reader.Depth == 1)
                    {
                        reader.Read(); // Read the "start object" token
                        while (reader.Read())
                        {
                            if (reader.TokenType == JsonToken.PropertyName)
                            {
                                string   propName   = reader.Value.ToString();
                                double[] dest       = null;
                                double   multiplier = 1.0;
                                if (propName == "TAXNWRBMajor")
                                {
                                    soilType = reader.ReadAsString();
                                }
                                else if (propName == "TMDMOD_2011")
                                {
                                    maxTemp = 0.0;
                                    reader.Read();
                                    while (reader.Read() && reader.TokenType != JsonToken.EndObject)
                                    {
                                        if (reader.TokenType == JsonToken.PropertyName && reader.Value.Equals("M"))
                                        {
                                            reader.Read(); // Read start of object token
                                            for (int i = 0; i < 12; i++)
                                            {
                                                reader.Read(); // Read a month name
                                                maxTemp += (double)reader.ReadAsDouble();
                                            }
                                            maxTemp /= 12.0;
                                        }
                                    }
                                }
                                else if (propName == "TMNMOD_2011")
                                {
                                    minTemp = 0.0;
                                    reader.Read();
                                    while (reader.Read() && reader.TokenType != JsonToken.EndObject)
                                    {
                                        if (reader.TokenType == JsonToken.PropertyName && reader.Value.Equals("M"))
                                        {
                                            reader.Read(); // Read start of object token
                                            for (int i = 0; i < 12; i++)
                                            {
                                                reader.Read(); // Read a month name
                                                minTemp += (double)reader.ReadAsDouble();
                                            }
                                            minTemp /= 12.0;
                                        }
                                    }
                                }
                                else if (propName == "PREMRG")
                                {
                                    ppt = 0.0;
                                    reader.Read();
                                    while (reader.Read() && reader.TokenType != JsonToken.EndObject)
                                    {
                                        if (reader.TokenType == JsonToken.PropertyName && reader.Value.Equals("M"))
                                        {
                                            reader.Read(); // Read start of object token
                                            for (int i = 0; i < 12; i++)
                                            {
                                                reader.Read(); // Read a month name
                                                ppt += (double)reader.ReadAsDouble();
                                            }
                                        }
                                    }
                                }
                                else if (propName == "BDTICM")  // Is this the best metric to use for find the "bottom" of the soil?
                                {
                                    reader.Read();
                                    while (reader.Read() && reader.TokenType != JsonToken.EndObject)
                                    {
                                        if (reader.TokenType == JsonToken.PropertyName && reader.Value.Equals("M"))
                                        {
                                            reader.Read(); // Read start of object token
                                            reader.Read(); // Read property name (which ought to be BDTICM_M)
                                            bedrock = 10.0 * (double)reader.ReadAsDouble();
                                            reader.Skip();
                                        }
                                    }
                                }
                                else if (propName == "AWCh1")
                                {
                                    dest       = awc20;
                                    multiplier = 0.01;
                                }
                                else if (propName == "AWCh2")
                                {
                                    dest       = awc23;
                                    multiplier = 0.01;
                                }
                                else if (propName == "AWCh3")
                                {
                                    dest       = awc25;
                                    multiplier = 0.01;
                                }
                                else if (propName == "AWCtS")
                                {
                                    dest       = thetaSat;
                                    multiplier = 0.01;
                                }
                                else if (propName == "BLDFIE")
                                {
                                    dest       = bd;
                                    multiplier = 0.001;
                                }
                                else if (propName == "CECSOL")
                                {
                                    dest       = cationEC;
                                    multiplier = 1.0;
                                }
                                else if (propName == "CLYPPT")
                                {
                                    dest       = clay;
                                    multiplier = 1.0;
                                }
                                else if (propName == "CRFVOL")
                                {
                                    dest       = coarse;
                                    multiplier = 1.0;
                                }
                                else if (propName == "ORCDRC")
                                {
                                    dest       = ocdrc;
                                    multiplier = 0.1;
                                }
                                else if (propName == "PHIHOX")
                                {
                                    dest       = phWater;
                                    multiplier = 0.1;
                                }
                                else if (propName == "SLTPPT")
                                {
                                    dest       = silt;
                                    multiplier = 1.0;
                                }
                                else if (propName == "SNDPPT")
                                {
                                    dest       = sand;
                                    multiplier = 1.0;
                                }
                                else if (propName == "TEXMHT")
                                {
                                    dest       = texture;
                                    multiplier = 1.0;
                                }
                                else if (propName == "WWP")
                                {
                                    dest       = thetaWwp;
                                    multiplier = 0.01;
                                }

                                if (dest != null)
                                {
                                    reader.Read();
                                    while (reader.Read() && reader.TokenType != JsonToken.EndObject)
                                    {
                                        if (reader.TokenType == JsonToken.PropertyName && reader.Value.Equals("M"))
                                        {
                                            while (reader.Read() && reader.TokenType != JsonToken.EndObject)
                                            {
                                                if (reader.TokenType == JsonToken.PropertyName)
                                                {
                                                    string tokenName = reader.Value.ToString();
                                                    if (tokenName.StartsWith("sl"))
                                                    {
                                                        int index = Int32.Parse(tokenName.Substring(2)) - 1;
                                                        dest[index] = (double)reader.ReadAsDouble() * multiplier;
                                                    }
                                                }
                                            }
                                        }
                                    }
                                }
                                else
                                {
                                    reader.Skip();
                                }
                            }
                        }
                    }
                }

                var          newSoil         = new Soil();
                Chemical     analysis        = new Chemical();
                Physical     waterNode       = new Physical();
                Organic      organicMatter   = new Organic();
                WaterBalance soilWater       = new WaterBalance();
                InitialWater initialWater    = new InitialWater();
                Sample       initialNitrogen = new Sample();
                SoilNitrogen soilN           = new SoilNitrogen();

                SoilCrop wheat = new SoilCrop();
                waterNode.Children.Add(wheat);
                wheat.Name = "WheatSoil";
                waterNode.ParentAllDescendants();

                Model nh4 = new SoilNitrogenNH4();
                nh4.Name = "NH4";
                soilN.Children.Add(nh4);
                Model no3 = new SoilNitrogenNO3();
                no3.Name = "NO3";
                soilN.Children.Add(no3);
                Model urea = new SoilNitrogenUrea();
                urea.Name = "Urea";
                soilN.Children.Add(urea);
                Model plantAvailNH4 = new SoilNitrogenPlantAvailableNH4();
                plantAvailNH4.Name = "PlantAvailableNH4";
                soilN.Children.Add(plantAvailNH4);
                Model plantAvailNO3 = new SoilNitrogenPlantAvailableNO3();
                plantAvailNO3.Name = "PlantAvailableNO3";
                soilN.Children.Add(plantAvailNO3);
                soilN.ParentAllDescendants();

                newSoil.Children.Add(waterNode);
                newSoil.Children.Add(soilWater);
                newSoil.Children.Add(soilN);
                newSoil.Children.Add(organicMatter);
                newSoil.Children.Add(analysis);
                newSoil.Children.Add(initialWater);
                newSoil.Children.Add(initialNitrogen);
                newSoil.Children.Add(new CERESSoilTemperature());
                newSoil.ParentAllDescendants();
                newSoil.OnCreated();

                newSoil.Name       = "Synthetic soil derived from ISRIC SoilGrids REST API";
                newSoil.DataSource = "ISRIC SoilGrids";
                newSoil.SoilType   = soilType;
                newSoil.Latitude   = Convert.ToDouble(latitudeEditBox.Text, System.Globalization.CultureInfo.InvariantCulture);
                newSoil.Longitude  = Convert.ToDouble(longitudeEditBox.Text, System.Globalization.CultureInfo.InvariantCulture);

                // ISRIC values are for "levels", not "intervals", so we need to convert to layers
                // Following Andrew Moore's lead on layer thickness and weightings.

                double[] thickness  = new double[] { 150.0, 150.0, 150.0, 150.0, 200.0, 200.0, 200.0, 200.0, 300.0, 300.0 };
                double[] depth      = new double[thickness.Length];
                int      layerCount = thickness.Length;
                for (int i = 0; i < thickness.Length; i++)
                {
                    depth[i] = thickness[i] + (i > 0 ? depth[i - 1] : 0.0);
                    if ((i > 0) && (layerCount == thickness.Length) && (bedrock < depth[i] + 20.0))
                    {
                        layerCount   = i + 1;
                        thickness[i] = Math.Min(thickness[i], Math.Max(0.0, bedrock - (depth[i] - thickness[i])));
                        if (i == 1)
                        {
                            thickness[i] = Math.Max(50.0, thickness[i]);
                        }
                        Array.Resize(ref thickness, layerCount);
                    }
                }

                analysis.Thickness      = thickness;
                waterNode.Thickness     = thickness;
                soilWater.Thickness     = thickness;
                organicMatter.Thickness = thickness;

                initialWater.Name          = "Initial water";
                initialWater.PercentMethod = InitialWater.PercentMethodEnum.FilledFromTop;
                initialWater.FractionFull  = 0.0;

                // Initialise nitrogen to 0.0
                initialNitrogen.Name = "Initial nitrogen";
                initialNitrogen.NH4  = new double[layerCount];
                initialNitrogen.NO3  = new double[layerCount];

                double tAvg = (maxTemp + minTemp) / 2.0;
                soilWater.CNCov      = 0.0;
                soilWater.CNRed      = 20.0;
                soilWater.SummerDate = newSoil.Latitude <= 0.0 ? "1-nov" : "1-may";
                soilWater.WinterDate = newSoil.Latitude <= 0.0 ? "1-apr" : "1-oct";
                soilWater.SummerCona = 6.0;
                soilWater.SummerU    = 6.0;
                soilWater.WinterCona = tAvg < 21.0 ? 2.5 : 6.0;
                soilWater.WinterU    = tAvg < 21.0 ? 4.0 : 6.0;
                soilWater.Salb       = textureToAlb[(int)Math.Round(texture[0] - 1)];
                soilWater.CN2Bare    = textureToCN2[(int)Math.Round(texture[0] - 1)];
                double[] swcon = new double[7];
                for (int i = 0; i < 7; i++)
                {
                    swcon[i] = textureToSwcon[(int)Math.Round(texture[i] - 1)];
                }
                soilWater.SWCON = ConvertLayers(swcon, layerCount);

                waterNode.BD     = ConvertLayers(bd, layerCount);
                waterNode.LL15   = ConvertLayers(thetaWwp, layerCount);
                waterNode.SAT    = ConvertLayers(thetaSat, layerCount);
                waterNode.AirDry = ConvertLayers(MathUtilities.Divide_Value(thetaWwp, 3.0), layerCount);
                double[] dul = new double[7];
                for (int i = 0; i < 7; i++)
                {
                    dul[i] = thetaWwp[i] + awc20[i];  // This could be made Moore complex
                }
                waterNode.DUL = ConvertLayers(dul, layerCount);

                waterNode.ParticleSizeSand = ConvertLayers(sand, layerCount);
                waterNode.ParticleSizeSilt = ConvertLayers(silt, layerCount);
                waterNode.ParticleSizeClay = ConvertLayers(clay, layerCount);
                // waterNode.Rocks = ConvertLayers(coarse, layerCount);
                analysis.PH = ConvertLayers(phWater, layerCount);
                // Obviously using the averaging in "ConvertLayers" for texture classes is not really correct, but should be OK as a first pass if we don't have sharply contrasting layers
                double[] classes  = ConvertLayers(texture, layerCount);
                string[] textures = new string[layerCount];
                for (int i = 0; i < layerCount; i++)
                {
                    textures[i] = textureClasses[(int)Math.Round(classes[i]) - 1];
                }


                double[] xf          = new double[layerCount];
                double[] kl          = new double[layerCount];
                double[] ll          = new double[layerCount];
                double   p1          = 1.4;
                double   p2          = 1.60 - p1;
                double   p3          = 1.80 - p1;
                double   topEffDepth = 0.0;
                double   klMax       = 0.06;
                double   depthKl     = 900.0;
                double   depthRoot   = 1900.0;

                for (int i = 0; i < layerCount; i++)
                {
                    xf[i] = 1.0 - (waterNode.BD[i] - (p1 + p2 * 0.01 * waterNode.ParticleSizeSand[i])) / p3;
                    xf[i] = Math.Max(0.1, Math.Min(1.0, xf[i]));
                    double effectiveThickness = thickness[i] * xf[i];
                    double bottomEffDepth     = topEffDepth + effectiveThickness;
                    double propMaxKl          = Math.Max(0.0, Math.Min(bottomEffDepth, depthKl) - topEffDepth) / effectiveThickness;
                    double propDecrKl         = Math.Max(Math.Max(0.0, Math.Min(bottomEffDepth, depthRoot) - topEffDepth) / effectiveThickness - propMaxKl, 0.0);
                    double propZeroKl         = 1.0 - propMaxKl - propDecrKl;
                    double ratioTopDepth      = Math.Max(0.0, Math.Min((depthRoot - topEffDepth) / (depthRoot - depthKl), 1.0));
                    double ratioBottomDepth   = Math.Max(0.0, Math.Min((depthRoot - bottomEffDepth) / (depthRoot - depthKl), 1.0));
                    double meanDecrRatio      = 0.5 * (ratioTopDepth + ratioBottomDepth);
                    double weightedRatio      = propMaxKl * 1.0 + propDecrKl * meanDecrRatio + propZeroKl * 0.0;
                    kl[i] = klMax * weightedRatio;
                    ll[i] = waterNode.LL15[i] + (waterNode.DUL[i] - waterNode.LL15[i]) * (1.0 - weightedRatio);
                    if (kl[i] <= 0.0)
                    {
                        xf[i] = 0.0;
                    }
                    topEffDepth = bottomEffDepth;
                }
                wheat.XF = xf;
                wheat.KL = kl;
                wheat.LL = ll;

                organicMatter.Carbon = ConvertLayers(ocdrc, layerCount);

                double rootWt = Math.Max(0.0, Math.Min(3000.0, 2.5 * (ppt - 100.0)));
                // For AosimX, root wt needs to be distributed across layers. This conversion logic is adapted from that used in UpgradeToVersion52
                double[] rootWtFraction = new double[layerCount];
                double   profileDepth   = depth[layerCount - 1];
                double   cumDepth       = 0.0;
                for (int layer = 0; layer < layerCount; layer++)
                {
                    double fracLayer = Math.Min(1.0, MathUtilities.Divide(profileDepth - cumDepth, thickness[layer], 0.0));
                    cumDepth += thickness[layer];
                    rootWtFraction[layer] = fracLayer * Math.Exp(-3.0 * Math.Min(1.0, MathUtilities.Divide(cumDepth, profileDepth, 0.0)));
                }
                // get the actuall FOM distribution through layers (adds up to one)
                double totFOMfraction = MathUtilities.Sum(rootWtFraction);
                for (int layer = 0; layer < thickness.Length; layer++)
                {
                    rootWtFraction[layer] /= totFOMfraction;
                }
                organicMatter.FOM = MathUtilities.Multiply_Value(rootWtFraction, rootWt);

                double[] fBiom = { 0.04,                                                                                                                             0.04 - 0.03 * (225.0 - 150.0) / (400.0 - 150.0),
                                   (400.0 - 300.0) / (450.0 - 300.0) * (0.04 - 0.03 * (350.0 - 150.0) / (400.0 - 150.0)) + (450.0 - 400.0) / (450.0 - 300.0) * 0.01,
                                   0.01,                                                                                                                                                                        0.01,0.01, 0.01, 0.01, 0.01, 0.01 };
                Array.Resize(ref fBiom, layerCount);
                double   inert_c = 0.95 * ocdrc[4];
                double[] fInert  = new double[7];
                for (int layer = 0; layer < 7; layer++)
                {
                    fInert[layer] = Math.Min(0.99, inert_c / ocdrc[layer]);
                }
                organicMatter.FInert      = ConvertLayers(fInert, layerCount); // Not perfect, but should be good enough
                organicMatter.FBiom       = fBiom;
                organicMatter.FOMCNRatio  = 40.0;
                organicMatter.SoilCNRatio = Enumerable.Repeat(11.0, layerCount).ToArray(); // Is there any good way to estimate this? ISRIC provides no N data

                newSoil.Children.Add(new CERESSoilTemperature());
                newSoil.OnCreated();

                soils.Add(new SoilFromDataSource()
                {
                    DataSource = "ISRIC",
                    Soil       = newSoil
                });
            }
            catch (Exception)
            {
            }
            return(soils);
        }
コード例 #12
0
ファイル: Main.cs プロジェクト: lulzzz/DCAnalytics
        private void AddMore()
        {
            EnumList prices = _configuration.EnumerationLists.Add();

            prices.Name = "Prices";

            EnumListValue val = prices.EnumValues.Add();

            val.Code        = 2000;
            val.Description = "Coffee";

            val             = prices.EnumValues.Add();
            val.Code        = 2000;
            val.Description = "Cotton";

            val             = prices.EnumValues.Add();
            val.Code        = 2000;
            val.Description = "Vanilla";


            //Certifications
            FairTrade fairTrade = _configuration.Certifications.Add(CertificationTypes.FairTrade) as FairTrade;

            fairTrade.Farmer = new Questionaire(null);
            fairTrade.Name   = "fairTrade";
            Section section = fairTrade.Sections.Add();

            section.Name = "Section1";
            SubSection sb2 = section.SubSections.Add();

            sb2.Name = "SubSection1";
            var openQuestion1 = sb2.Questions.AddOpenQuestion();

            openQuestion1.QuestionText = "Where do you stay";
            openQuestion1.Name         = "Residence";

            var openQuestion = section.Questions.AddOpenQuestion();

            openQuestion.QuestionText = "Where do you stay";
            openQuestion.Name         = "Residence";


            openQuestion = fairTrade.Questions.AddOpenQuestion();
            openQuestion.QuestionText = "Where do you stay";
            openQuestion.Name         = "Residence";



            //organic
            Organic organic = _configuration.Certifications.Add(CertificationTypes.Organic) as Organic;

            organic.Farmer = new Questionaire(null);
            fairTrade.Name = "fairTrade";
            section        = fairTrade.Sections.Add();
            organic.Name   = "Section1";
            SubSection sb1 = section.SubSections.Add();

            sb1.Name     = "SubSection1";
            openQuestion = sb1.Questions.AddOpenQuestion();
            openQuestion.QuestionText = "Where do you stay";
            openQuestion.Name         = "Residence";

            openQuestion = section.Questions.AddOpenQuestion();
            openQuestion.QuestionText = "Where do you stay";
            openQuestion.Name         = "Residence";

            openQuestion = organic.Questions.AddOpenQuestion();
            openQuestion.QuestionText = "Where do you stay";
            openQuestion.Name         = "Residence";



            //
            UTZ utz = _configuration.Certifications.Add(CertificationTypes.UTZ) as UTZ;

            utz.Farmer = new Questionaire(null);
            utz.Name   = "fairTrade";


            section      = utz.Sections.Add();
            organic.Name = "Section1";
            SubSection sb = section.SubSections.Add();

            sb.Name      = "SubSection1";
            openQuestion = sb.Questions.AddOpenQuestion();
            openQuestion.QuestionText = "Where do you stay";
            openQuestion.Name         = "Residence";

            openQuestion = section.Questions.AddOpenQuestion();
            openQuestion.QuestionText = "Where do you stay";
            openQuestion.Name         = "Residence";


            openQuestion = utz.Questions.AddOpenQuestion();
            openQuestion.QuestionText = "Where do you stay";
            openQuestion.Name         = "Residence";



            //Trainings
            Training training = _configuration.Trainings.Add();

            training.Name      = "Training1";
            training.StartDate = DateTime.Now;
            training.EndDate   = DateTime.Now;


            //trainees
            var tra = training.Trainees.Add();

            tra.Name = "Nana";

            var topic = training.Topics.Add();

            topic.Name = "Topic1";

            var trainer = training.Trainers.Add();

            trainer.Name = "Kato";

            //Purchases
            Purchase purchase = _configuration.Purchases.Add();

            purchase.DateOfPurchase = DateTime.Now;
            purchase.Quantity       = 50;
            purchase.Prices         = _configuration.EnumerationLists.ByName("Prices");
            purchase.ProductPrice   = purchase.Prices.EnumValues.ByDescription("Coffee");
            purchase.Lotid          = "Lot90343";
            purchase.Products       = _configuration.EnumerationLists.ByName("Products");
            purchase.Product        = purchase.Products.EnumValues.ByDescription("Coffee");
            purchase.Farmer         = new Questionaire(null);

            Questionaire questionaire = _configuration.Questionaires[0];
            Section      section_o    = questionaire.Sections[0];
            OpenQuestion question     = section_o.Questions.AddOpenQuestion();

            question.QuestionText = "What's your name";
            question.Name         = "Name";
            Dependency dependency = question.Dependencies.Add();

            dependency.Target = questionaire.Sections[1];


            //inspection
            FieldInspection inspection = _configuration.Inspections.Add();

            inspection.FieldName = "Kasese 1";
            var fieldSection = inspection.Sections.Add();

            fieldSection.Name = "Field Section";

            var qn = fieldSection.Questions.Add(QuestionTypes.Open);

            qn.QuestionText = "Whats your name?";

            inspection.Farmer = _configuration.Questionaires[0];

            inspection.Coordinates.Add("Lat:78834;Long:459");


            //adding clients
            _configuration.Client.Contact   = "0775407583";
            _configuration.Client.CreatedBy = "Admin";
            _configuration.Client.Email     = "*****@*****.**";
            _configuration.Client.Name      = "Kakembo";
            User user = _configuration.Client.Users.Add(UserTypes.ClientUser);

            user.UserName  = "******";
            user.Password  = "******";
            user.Email     = "*****@*****.**";
            user.Firstname = "Nanana";
            user.IsAdmin   = true;
            user.Lastname  = "Nanana";
            user.Usercode  = "N009";
        }
コード例 #13
0
 public OrganicTests()
 {
     testOrganic = new Organic();
 }
コード例 #14
0
        protected override void ReadDataXML(XElement ele, ElderScrollsPlugin master)
        {
            XElement subEle;

            if (ele.TryPathTo("Stone", false, out subEle))
            {
                Stone.ReadXML(subEle, master);
            }

            if (ele.TryPathTo("Dirt", false, out subEle))
            {
                Dirt.ReadXML(subEle, master);
            }

            if (ele.TryPathTo("Grass", false, out subEle))
            {
                Grass.ReadXML(subEle, master);
            }

            if (ele.TryPathTo("Glass", false, out subEle))
            {
                Glass.ReadXML(subEle, master);
            }

            if (ele.TryPathTo("Metal", false, out subEle))
            {
                Metal.ReadXML(subEle, master);
            }

            if (ele.TryPathTo("Wood", false, out subEle))
            {
                Wood.ReadXML(subEle, master);
            }

            if (ele.TryPathTo("Organic", false, out subEle))
            {
                Organic.ReadXML(subEle, master);
            }

            if (ele.TryPathTo("Cloth", false, out subEle))
            {
                Cloth.ReadXML(subEle, master);
            }

            if (ele.TryPathTo("Water", false, out subEle))
            {
                Water.ReadXML(subEle, master);
            }

            if (ele.TryPathTo("HollowMetal", false, out subEle))
            {
                HollowMetal.ReadXML(subEle, master);
            }

            if (ele.TryPathTo("OrganicBug", false, out subEle))
            {
                OrganicBug.ReadXML(subEle, master);
            }

            if (ele.TryPathTo("OrganicGlow", false, out subEle))
            {
                OrganicGlow.ReadXML(subEle, master);
            }
        }
コード例 #15
0
        public async Task <List <SerpPost> > TrackSomething(string keyword, string userAgent, string location, string enteredpage, string username)
        {
            Organic.Clear();
            OrganicFound.Clear();
            Reklame.Clear();
            Position = 0;

            var responses = Engine.GetGooglePages(keyword, userAgent, location, 4, 5000);

            await foreach (var response in responses)
            {
                GiveAds(response);

                var resultsOnly = response.Doc.GetElementbyId("rso").SelectNodes(".//div[@class='g']");//kw, position, datetime, url
                if (resultsOnly == null)
                {
                    return(null);
                }
                foreach (var result in resultsOnly)
                {
                    Position++;
                    var divClass = result.GetAttributeValue("class", "");
                    if (divClass != "g")
                    {
                        continue;
                    }

                    var a     = result.SelectSingleNode(".//a");
                    var url   = a.Attributes["href"].Value;
                    var title = a.SelectSingleNode(".//h3").InnerText;
                    Organic.Add(new Result(url, title, Position));
                    StateHasChangedDelegate?.Invoke();

                    if (enteredpage != null)                        //Checks if entered URL is on Google search
                    {
                        if (!enteredpage.StartsWith("https://"))    //if http || wwww
                        {
                            if (!enteredpage.StartsWith("http://")) //uri needs http
                            {
                                enteredpage = "http://" + enteredpage;
                            }
                            Uri uri  = new Uri(enteredpage);
                            var temp = uri.Host;
                            if (temp.Contains("www."))
                            {
                                temp = temp.Substring(4);
                            }

                            if (url.Contains(temp))
                            {
                                Found = true;
                                string date = DateTime.Now.ToString("yyyy-MM-dd");
                                Organic[Organic.Count - 1].Found = true;
                                OrganicFound.Add(new SerpPost(date, keyword, enteredpage, Position, username));
                            }
                        }
                        else //if https
                        {
                            enteredpage = enteredpage.Substring(8); //remove https part bcs uri needs http
                            enteredpage = "http://" + enteredpage;
                            Uri uri  = new Uri(enteredpage);
                            var temp = uri.Host;
                            if (temp.Contains("www."))
                            {
                                temp = temp.Substring(4);
                            }
                            if (url.Contains(temp))
                            {
                                Found = true;
                                string date = DateTime.Now.ToString("yyyy-MM-dd");
                                Organic[Organic.Count - 1].Found = true;
                                OrganicFound.Add(new SerpPost(date, keyword, enteredpage, Position, username));
                            }
                        }
                    }
                }
            }
            if (OrganicFound.Count == 0)
            {
                string date = DateTime.Now.ToString("yyyy-MM-dd");
                OrganicFound.Add(new SerpPost(date, keyword, enteredpage, 101, username));
            }
            return(OrganicFound);
        }
コード例 #16
0
 public OrganicTests()
 {
     organicPet = new Organic();
 }