Sample source code for the agents in C# 1. Sample code of Experiment Design Agent Design Method Interface public interface IdesignMethods { experiment sample{get;set;} List<experiment> workingexps{get;set;} bool finish {get;set;} int iteration_count{get;set;} string name{ get; set; } void method(); } Simplex Search Method using using using using System; System.Collections.Generic; System.Text; utilities; namespace design_agent { class simplex_alg : IdesignMethods { //****************************** private double accurate_index = 0.0005; private double reflection_rate=1; private double expansion_rate=2; private double contraction_rate=-0.5; private double reduction_rate=0.5; //****************************** //******INTERFACE********** public List<experiment> workingexps { get; set; } public int iteration_count { get; set; } public experiment sample { get; set; } public bool finish { get; set; } public string name { get; set; } public double currentobj { get; set; } //************************* private private private private experiment[] simplex; bool firstrun = true; int inputnum; experiment gravity_exp; public simplex_alg() { finish=false; workingexps = new List<experiment>(); name="simplex"; } private void init_exps() { Random rand = new Random(); inputnum = 0; foreach (parameter p in sample.exp_settting.paras) { if (p.isInput) inputnum++; } simplex = new experiment[inputnum+1]; experiment e = new experiment(); for (int i = 0; i < inputnum+1; i++) { e = new experiment(); e =sample.clone(); e.ID = Guid.NewGuid(); e.name="simplex_"+iteration_count; foreach (parameter x in e.exp_settting.paras) { if (x.isInput) { int value=rand.Next(0,100); x.setvalue((double)value / 100 * (x.max - x.min) + x.min); } else x.value = -1; } e.done = false; workingexps.Add(e); simplex[i] = e; } } private void stepalg() { for (int i = 0; i < inputnum + 1;i++ ) { experiment temp = new experiment(); temp = ifready_exp(simplex[i]); if (temp == null) { return; } simplex[i] = temp; } if (this.ss() <= accurate_index) { finish = true; List<experiment> finallist=new List<experiment>(); for(int i=0;i<=inputnum;i++) { finallist.Add(simplex[i]); } util.exportExperiments(finallist, "final simplex", "simplex result"); return; } Console.WriteLine(iteration_count+" this.ss()); simplex=util.sort_exparray(simplex); gravity_exp = this.gravity(); experiment r = this.reflection(); experiment c = this.contraction(); experiment e = this.expansion(); experiment x1=simplex[0]; Current best: {0}; ss={1}", simplex[0].obj_value, experiment xn=simplex[inputnum-1]; experiment tempr = this.ifready_exp(r); if (tempr!=null) { r = tempr; if (r.obj_value >= x1.obj_value && r.obj_value <= xn.obj_value) { Console.WriteLine(" reflection"); simplex[inputnum] = r; iteration_count++; stepalg(); } else if (r.obj_value < x1.obj_value) { experiment tempe = this.ifready_exp(e); if (tempe!=null) { e = tempe; if (e.obj_value > r.obj_value) { Console.WriteLine(" espansion"); simplex[inputnum]=e; iteration_count++; stepalg(); } else { Console.WriteLine(" reflection"); simplex[inputnum]=r; iteration_count++; stepalg(); } } else { //Console.WriteLine(" espansion not finish."); return; } } else { experiment tempc = this.ifready_exp(c); if (tempc!=null) { c = tempc; if (c.obj_value < simplex[inputnum].obj_value) { Console.WriteLine(" constraction"); simplex[inputnum] = c; iteration_count++; stepalg(); } else { Console.WriteLine(" reduction"); this.reduction(); iteration_count++; stepalg(); } } else { //Console.WriteLine("constraction not finish."); return; } } } else { //Console.WriteLine("reflection not finish."); return; } } private bool ifready(experiment e) { bool add = false; foreach (experiment s in workingexps) { if (s.compare_ignore_result(e)) { if (s.done) { e = s; return true; } } else add = true; } if (add) workingexps.Add(e); return false; } private experiment ifready_exp(experiment e) { bool add = false; foreach (experiment s in workingexps) { if (s.compare_ignore_result(e)) { if (s.done) { return s; } } else add = true; } if (add) workingexps.Add(e); return null; } private experiment reflection() { experiment e = sample.clone(); e.ID = Guid.NewGuid(); e.name = "simplex_" + iteration_count; List<parameter> x0 = gravity_exp.exp_settting.paras; List<parameter> xnplus = simplex [inputnum].exp_settting.paras; for (int i = 0; i < e.exp_settting.paras.Count; i++) { e.exp_settting.paras[i].setvalue(x0[i].value+reflection_rate*(x0[i].valuexnplus[i].value)); } return e; } private experiment contraction() { experiment e = sample.clone(); e.ID = Guid.NewGuid(); e.name = "simplex_" + iteration_count; List<parameter> x0 = gravity_exp.exp_settting.paras; List<parameter> xnplus = simplex[inputnum+1-1].exp_settting.paras; for (int i = 0; i < e.exp_settting.paras.Count; i++) { e.exp_settting.paras[i].setvalue(x0[i].value + contraction_rate * (x0[i].value xnplus[i].value)); } return e; } private experiment expansion() { experiment e = sample.clone(); e.ID = Guid.NewGuid(); e.name = "simplex_" + iteration_count; List<parameter> x0 = gravity_exp.exp_settting.paras; List<parameter> xnplus = simplex[inputnum+1-1].exp_settting.paras; for (int i = 0; i < e.exp_settting.paras.Count; i++) { e.exp_settting.paras[i].setvalue(x0[i].value + expansion_rate * (x0[i].value xnplus[i].value)); } return e; } private void reduction() { for (int j = 1; j < inputnum+1; j++ ) { for (int i = 0; i < simplex[j].exp_settting.paras.Count; i++) { if(simplex[j].exp_settting.paras[i].isInput) simplex[j].exp_settting.paras[i].setvalue(simplex[j].exp_settting.paras[i].value + reduction_rate * (simplex[j].exp_settting.paras[i].value - simplex[0].exp_settting.paras[i].value)); } simplex[j].ID = Guid.NewGuid(); } } private experiment gravity() { experiment g = sample.clone(); g.name = "simplex_" + iteration_count; foreach(parameter p in g.exp_settting.paras) { if (p.isInput) p.value = 0; } for(int j=0; j<inputnum; j++) { experiment e = simplex[j]; for (int i = 0; i < inputnum; i++) { if(g.exp_settting.paras[i].isInput) g.exp_settting.paras[i].value = g.exp_settting.paras[i].value + e.exp_settting.paras[i].value; } } foreach (parameter p in g.exp_settting.paras) { if (p.isInput) p.setvalue(p.value / (inputnum)); } return g; } public void method() { if (firstrun) { init_exps(); firstrun = false; return; } stepalg (); } private double ss() { double s = 0; double avg = 0; double sum = 0; foreach (experiment x in simplex) { double r = x.obj_value; sum = sum + r; } avg = sum / (inputnum+1); foreach (experiment x in simplex) { double r = x.obj_value; s = s + (r - avg) * (r - avg); } return Math.Pow(s,0.5); } } } Artificial Neural Network Method using using using using using using using using System; System.Collections.Generic; System.Text; NeuronDotNet.Core; NeuronDotNet.Core.Backpropagation; NeuronDotNet.Core.Initializers; Util; utilities; namespace design_agent { class ann_alg : IdesignMethods { //******INTERFACE********** public List<experiment> workingexps { get; set; } public int iteration_count { get; set; } public experiment sample { get; set; } public bool finish { get; set; } public string name { get; set; } public double currentobj { get; set; } //************************* List<experiment> ReadyToExcuteExps; private bool firstrun = true; private double accurate_index = 0.005; private int numOfParameter = 0; private int batchsize = 5; //ann private private private private private private private private private List<experiment> testexps; LinearLayer inputlayer; SigmoidLayer hiddenlayer; SigmoidLayer outputlayer; BackpropagationNetwork network; int neuronCount = 10; double learningRate = 0.25; int cycles = 1000; TrainingSet trainingset; public ann_alg() { foreach (parameter p in sample.exp_settting.paras) { if(p.isInput) numOfParameter ++; } } private void method() { if (firstrun) { init(); firstrun = false; return; } annalg(); } private void init() { Random rand = new Random(); experiment e = new experiment(); for (int i = 0; i < batchsize; i++) { e = new experiment(); e = sample.clone(); e.ID = Guid.NewGuid(); e.name = "ann_" + iteration_count; foreach (parameter x in e.exp_settting.paras) { if (x.isInput) { int value = rand.Next(0, 100); x.setvalue((double)value / 100 * (x.max - x.min) + x.min); } else x.value = -1; } e.done = false; workingexps.Add(e); } inputlayer = new LinearLayer(numOfParameter); hiddenlayer = new SigmoidLayer(neuronCount); new BackpropagationConnector(inputlayer, hiddenlayer).Initializer = new RandomFunction(0d, 0.3d); new BackpropagationConnector(hiddenlayer, outputlayer).Initializer = new RandomFunction(0d, 0.3d); network = new BackpropagationNetwork(inputlayer, outputlayer); network.SetLearningRate(learningRate); trainingset = new TrainingSet(numOfParameter, 1); } private void annalg() { for (int i = 0; i < batchsize; i++) { experiment temp = new experiment(); temp = ifready_exp(testexps[i]); if (temp == null) { return; } testexps[i] = temp; } testfinish(); if (finish) return; testexps = new List<experiment>(); for (int i = 0; i < workingexps.Count; i++) { experiment temp = new experiment(); temp = ifready_exp(testexps[i]); if (temp == null) { return; } workingexps[i] = temp; double[] input = new double[numOfParameter]; int j = 0; foreach (parameter p in workingexps[i].exp_settting.paras) { if (p.isInput) { input[j] = p.value / p.max; j++; } } double[] output={workingexps[i].calobj()}; trainingset.Add(new TrainingSample(input, output)); } network.Learn(trainingset, cycles); Random rand = new Random(); experiment e = new experiment(); for (int i = 0; i < batchsize; i++) { e = new experiment(); e = sample.clone(); e.ID = Guid.NewGuid(); e.name = "ann_" + iteration_count; foreach (parameter x in e.exp_settting.paras) { if (x.isInput) { int value = rand.Next(0, 100); x.setvalue((double)value / 100 * (x.max - x.min) + x.min); } else x.value = -1; } e.done = false; workingexps.Add(e); testexps.Add(e); } } private void testfinish() { double ss = 0; for (int i = 0; i < batchsize;i++ ) { double[] input=new double[numOfParameter]; int j = 0; foreach (parameter p in testexps[i].exp_settting.paras) { if (p.isInput) { input[j] = p.value / p.max; j++; } } double[] output; output = network.Run(input); testexps[i].calobj(); ss = ss + (output[0] - testexps[i].obj_value) * (output[0] - testexps[i].obj_value); } ss = ss / batchsize; if (ss <= accurate_index) finish = true; } private experiment ifready_exp(experiment e) { bool add = false; foreach (experiment s in workingexps) { if (s.compare_ignore_result(e)) { if (s.done) { return s; } } else add = true; } if (add) workingexps.Add(e); return null; } } } 2. Sample code for Execution Agent Experimentation Interface public interface IExperimentation { List<experiment> exps { set; get; } experimentSetting standardset { set; get; } plate[] exp_plates { get; set; } void start(); } Script Composing code public Script precip_script(Script scr, layout ly, operations op) { //gettips string trans = ""; bool[] tips = new bool[8]; for (int i = 0; i < 8; i++) { tips[i] = false; } for (int i = 0; i < experiments.Length; i++) { tips[i] = true; } trans = op.getditi2(tips, "DiTi 1000ul"); scr.AddScriptLine(trans); //explocation[] currentlocs = this.allocate(); //add salt double[] saltcon = new double[experiments.Length]; double[] volumn = new double[12]; string[] wells = new string[experiments.Length]; for (int i = 0; i < experiments.Length; i++) { foreach (parameter x in experiments[i].exp_settting.paras) { if (x.name.Contains("salt")) saltcon[i] = x.value; } volumn[i] = saltcon[i] * totalvolumn / salt_init_con; wells[i] = currentlocs[i].wells; } trans = op.aspirate(tips, "ZZ Water", volumn, salt_grid, salt_site, salt_location); scr.AddScriptLine(trans); trans = op.dispense(tips, "ZZ Water", volumn, currentlocs[0].grid, currentlocs[0].site, op.wellselection_96(wells)); scr.AddScriptLine(trans); //change tips trans = op.drop_tips(tips, ly.getditiwastegrid(), ly.getditiwastesite(), 70, 10, 0); scr.AddScriptLine(trans); trans = op.getditi2(tips, "DiTi 1000ul"); scr.AddScriptLine(trans); //add buffer buffer bf = new buffer(); double min = 0; double max = 0; foreach (parameter x in standardset.paras) { if (x.name == "ph") { min = x.min; max = x.max; } } bf.conn(buffertype, max, min); double[] ph = new double[experiments.Length]; double[] ratio = new double[experiments.Length]; double[] chemicalA = new double[12]; double[] chemicalB = new double[12]; for (int i = 0; i < experiments.Length; i++) { foreach (parameter x in experiments[i].exp_settting.paras) { if (x.name.Contains( "ph")) { ph[i] = x.value; } } ratio[i] = bf.getRatio(initAcon, ph[i]); chemicalA[i] = totalvolumn * bufferstrength / initAcon * (1 - (1 / (ratio[i] + 1))); chemicalB[i] = totalvolumn * bufferstrength / initBcon * (1 / (ratio[i] + 1)); } //add chemicalA trans = op.aspirate(tips, "ZZ Water", chemicalA, bufferA_grid, bufferA_site, bufferA_location); scr.AddScriptLine(trans); trans = op.dispense(tips, "ZZ Water", chemicalA, currentlocs[0].grid, currentlocs[0].site, op.wellselection_96(wells)); scr.AddScriptLine(trans); //change tips trans = op.drop_tips(tips, ly.getditiwastegrid(), ly.getditiwastesite(), 70, 10, 0); scr.AddScriptLine(trans); trans = op.getditi2(tips, "DiTi 1000ul"); scr.AddScriptLine(trans); //add chemicalB trans = op.aspirate(tips, "ZZ Water", chemicalB, bufferB_grid, bufferB_site, bufferB_location); scr.AddScriptLine(trans); trans = op.dispense(tips, "ZZ Water", chemicalB, currentlocs[0].grid, currentlocs[0].site, op.wellselection_96(wells)); scr.AddScriptLine(trans); //change tips trans = op.drop_tips(tips, ly.getditiwastegrid(), ly.getditiwastesite(), 70, 10, 0); scr.AddScriptLine(trans); trans = op.getditi2(tips, "DiTi 1000ul"); scr.AddScriptLine(trans); //add sample double[] tempsamplevolume = new double[12]; for (int i = 0; i < experiments.Length; i++) { tempsamplevolume[i] = samplevolume; } trans = op.aspirate(tips, "ZZ Water", tempsamplevolume, samplegrid, samplesite, samplelocation); scr.AddScriptLine(trans); trans = op.dispense(tips, "ZZ Water", tempsamplevolume, currentlocs[0].grid, currentlocs[0].site, op.wellselection_96(wells)); scr.AddScriptLine(trans); //change tips trans = op.drop_tips(tips, ly.getditiwastegrid(), ly.getditiwastesite(), 70, 10, 0); scr.AddScriptLine(trans); trans = op.getditi2(tips, "DiTi 1000ul"); scr.AddScriptLine(trans); //add Water double[] Watervolume = new double[12]; for (int i = 0; i < experiments.Length; i++) { Watervolume[i] = totalvolumn - samplevolume - chemicalA[i] - chemicalB[i] - volumn[i]; } trans = op.aspirate(tips, "ZZ Water", Watervolume, Watergrid, Watersite, Waterlocation); scr.AddScriptLine(trans); trans = op.dispense(tips, "ZZ Water", Watervolume, currentlocs[0].grid, currentlocs[0].site, op.wellselection_96(wells)); scr.AddScriptLine(trans); //change tips trans = op.drop_tips(tips, ly.getditiwastegrid(), ly.getditiwastesite(), 70, 10, 0); scr.AddScriptLine(trans); trans = op.getditi2(tips, "DiTi 1000ul"); scr.AddScriptLine(trans); //mix double[] mixvolume = new double[12]; for (int i = 0; i < experiments.Length; i++) { mixvolume[i] = totalvolumn / 4; } trans = op.mix(tips, "ZZ Water", mixvolume, currentlocs[0].grid, currentlocs[0].site, op.wellselection_96(wells), 3); scr.AddScriptLine(trans); trans = op.drop_tips(tips, ly.getditiwastegrid(), ly.getditiwastesite(), 70, 10, 0); scr.AddScriptLine(trans); //transfer explabware to reader for shaking scr.AddScriptLine("FACTS(\"ReaderNETwork\",\"ReaderNETwork_Open\",\"\",\"0\",\"\");"); trans = op.transfer(currentlocs[0].grid, 45, currentlocs[0].site + 1, 1, "MP 3Pos", "Infinite 200", "ZZ 96 Well Microplate tianyi"); scr.AddScriptLine(trans); scr.AddScriptLine("FACTS(\"ReaderNETwork\",\"ReaderNETwork_Close\",\"\",\"0\",\"\");"); //shake shaker s = new shaker(); scr.AddScriptLine(s.scr); //transfer plateback scr.AddScriptLine("FACTS(\"ReaderNETwork\",\"ReaderNETwork_Open\",\"\",\"0\",\"\");"); trans = op.transfer(45, currentlocs[0].grid, 1, currentlocs[0].site + 1, "Infinite 200", "MP 3Pos", "ZZ 96 Well Microplate tianyi"); scr.AddScriptLine(trans); scr.AddScriptLine("FACTS(\"ReaderNETwork\",\"ReaderNETwork_Close\",\"\",\"0\",\"\");"); //dilute solution 30 fold if (first) { filterlocs = currentlocs; first = false; } this.allocate(); //change tips trans = op.drop_tips(tips, ly.getditiwastegrid(), ly.getditiwastesite(), 70, 10, 0); scr.AddScriptLine(trans); trans = op.getditi2(tips, "DiTi 1000ul"); scr.AddScriptLine(trans); //first for (int i = 0; i < experiments.Length; i++) { volumn[i] = totalvolumn / 6; wells[i] = filterlocs[i].wells; } trans = op.aspirate(tips, "ZZ Water", volumn, filterlocs[0].grid, filterlocs[0].site, op.wellselection_96(wells)); scr.AddScriptLine(trans); for (int i = 0; i < experiments.Length; i++) { wells[i] = currentlocs[i].wells; } trans = op.dispense(tips, "ZZ Water", volumn, currentlocs[0].grid, currentlocs[0].site, op.wellselection_96(wells)); scr.AddScriptLine(trans); for (int i = 0; i < experiments.Length; i++) { Watervolume[i] = totalvolumn * 5 / 6; } trans = op.aspirate(tips, "ZZ Water", Watervolume, Watergrid, Watersite, Waterlocation); scr.AddScriptLine(trans); trans = op.dispense(tips, "ZZ Water", Watervolume, currentlocs[0].grid, currentlocs[0].site, op.wellselection_96(wells)); scr.AddScriptLine(trans); explocation[] filterlocs_2 = currentlocs; this.allocate(); //second for (int i = 0; i < experiments.Length; i++) { volumn[i] = totalvolumn / 6; wells[i] = filterlocs_2[i].wells; } trans = op.aspirate(tips, "ZZ Water", volumn, filterlocs_2[0].grid, filterlocs_2[0].site, op.wellselection_96(wells)); scr.AddScriptLine(trans); for (int i = 0; i < experiments.Length; i++) { wells[i] = currentlocs[i].wells; } trans = op.dispense(tips, "ZZ Water", volumn, currentlocs[0].grid, currentlocs[0].site, op.wellselection_96(wells)); scr.AddScriptLine(trans); for (int i = 0; i < experiments.Length; i++) { Watervolume[i] = totalvolumn * 5 / 6; } trans = op.aspirate(tips, "ZZ Water", Watervolume, Watergrid, Watersite, Waterlocation); scr.AddScriptLine(trans); trans = op.dispense(tips, "ZZ Water", Watervolume, currentlocs[0].grid, currentlocs[0].site, op.wellselection_96(wells)); scr.AddScriptLine(trans); //transfer liquid to filter plate trans = op.drop_tips(tips, ly.getditiwastegrid(), ly.getditiwastesite(), 70, 10, 0); scr.AddScriptLine(trans); trans = op.getditi2(tips, "DiTi 1000ul"); scr.AddScriptLine(trans); for (int i = 0; i < experiments.Length; i++) { volumn[i] = totalvolumn * 0.9; wells[i] = currentlocs[i].wells; } trans = op.aspirate(tips, "ZZ Water", volumn, currentlocs[0].grid, currentlocs[0].site, op.wellselection_96(wells)); scr.AddScriptLine(trans); for (int i = 0; i < experiments.Length; i++) { wells[i] = filterlocs[i].wells; } trans = op.dispense(tips, "ZZ Water", volumn, filtergrid, filtersite, op.wellselection_96(wells)); scr.AddScriptLine(trans); trans = op.drop_tips(tips, ly.getditiwastegrid(), ly.getditiwastesite(), 70, 10, 0); scr.AddScriptLine(trans); //transfer to vaccum pump trans = op.transfer(filtergrid, 36, filtersite + 1, 4, "MP 3Pos", "Te-VacS SC", "ZZ 96 Well Microplate tianyi"); scr.AddScriptLine(trans); //do filtration VacS v = new VacS(); scr.AddScriptLine(v.setpressdiff(700)); scr.AddScriptLine(v.applyvaccumfront(700)); scr = v.setduration(60, scr); scr.AddScriptLine(v.ventfront()); scr.AddScriptLine(v.deactive()); //move explabware back trans = op.transfer(36, filtergrid, 4, filtersite + 1, "Te-VacS SC", "MP 3Pos", "ZZ 96 Well Microplate tianyi"); scr.AddScriptLine(trans); //remove VacS cap scr = op.moveVaScap(scr, 36); explabwaresite = currentlocs[0].site; explabwaregrid = currentlocs[0].grid; filterlocs = currentlocs; return scr; } 3. Sample code for assay agent Sample code for controlling platereader public void fixed_uvab(string label, int numofreads, int settletime, int wavelength) { if (m_oHelper.HasAbsorbanceFixed()) { // ---------------------------------------// ATTENTION: For script creators // The ID´s must be unique and ascending!!! // ---------------------------------------int nInnerID = 1000; bool bDeviceIsM1000 = (m_oServer.ConnectedReader.Information.GetInstrumentName().Equals("S3")); assay_agent.platereaderUtil.Absorbance oAbs = new assay_agent.platereaderUtil.Absorbance(m_oHelper, nInnerID, bDeviceIsM1000); oAbs.composescript(label, numofreads, settletime, wavelength); // Get the measurement reading object MeasurementReading oMeasurementReading = oAbs.MeasurementReading; int nID = 0; // Build measurement script file TecanFile oFile = Helper.CreateTecanFile(); TecanMeasurement oMeasurement = Helper.CreateTecanMeasurement(++nID); MeasurementManualCycle oCycle = Helper.CreateManualCycle(++nID); String sPlateName = m_oPlate.FilenameWithoutExtension; CyclePlate oPlate = Helper.CreatePlate(sPlateName, ++nID); string sRange = m_sAvailablePlateRange; PlateRange oRange = Helper.CreateRange(sRange, ++nID); MeasurementAbsorbance oAbsMeas = new MeasurementAbsorbance(); oAbsMeas.Name = "ABS"; oAbsMeas.ID = ++nID; Well oWell = Helper.CreateWell(++nID); oWell.Actions.Add(oMeasurementReading); oAbsMeas.Actions.Add(oWell); oPlate.Actions.Add(oRange); oRange.Actions.Add(oAbsMeas); oCycle.Actions.Add(oPlate); oMeasurement.Actions.Add(oCycle); oFile.DocumentContent = oMeasurement; m_oCurrentMeasurementFile = oFile; string filepath = utilities.util.getfilepath("abs.xml"); FileHandling.Save(oFile, filepath); // Convert the Tecan file object to a string XmlSupport objXML = new XmlSupport(); XmlNode objNode = oFile.GetXmlNode(objXML); objXML.AddXmlNode(objNode); m_sScript = objXML.XmlDocumentAsString(); } } Sample code for HPLC peaks clustering class hplc { class CSVparser { const double maxRET = 10; const double minRET = 5; const int init_cluster_num = 10; const bool reduce_cluster = true; //for calibration curve List<string[]> parseCSV(string path) { List<string[]> parsedData = new List<string[]>(); try { using (StreamReader readFile = new StreamReader(path)) { string line; string[] row; while ((line = readFile.ReadLine()) != null) { row = line.Split(','); parsedData.Add(row); } } } catch (Exception e) { Console.Write(e.ToString()); Console.Read(); } return parsedData; } //int[0]: RetTime //int[1]: Area //int[2]: Area(%) List<double[]> retrievedata() { string aPath = Environment.CurrentDirectory; aPath = aPath + "\\hplc"; DirectoryInfo dir = new DirectoryInfo(aPath); DirectoryInfo[] subdir = dir.GetDirectories(); List<double[]> hplcdata = new List<double[]>(); int index = 0; foreach (DirectoryInfo d in subdir) { String temp = aPath + "\\" + d.Name + "\\REPORT02.CSV"; List<string[]> csvdata = this.parseCSV(temp); String[] getid = d.Name.Split(new char[] { '.' }); index = int.Parse(getid[0].Substring(6)); //Console.WriteLine(d.Name+" "+index); foreach (string[] s in csvdata) { double[] data = new double[4]; data[0] = Double.Parse(s[1]); data[1] = Double.Parse(s[4]); data[2] = index; data[3] = 0; if (data[0] > minRET && data[0] < maxRET) hplcdata.Add(data); } //index++; } return hplcdata; } //double[0] cluster center //double[1] x //double[2] c public List<double[]> concentrations(double[] s) { List<double[]> hplcdata = this.retrievedata(); cluster_alg cluster = new cluster_alg(hplcdata, s); return hplcdata; } public static int idforsearch; private static bool getdatabyid(double[] hplcdata) { bool b = false; if (hplcdata[2] == idforsearch) { } return b; } } class cluster_alg { int k; List<double[]> data; double[] centers; double[] number; public cluster_alg(int k1, List<double[]> data1, bool reduce) { this.k = k1; this.data = data1; data.TrimExcess(); centers = new double[k]; data.Sort ( delegate(double[] a1, double[] a2) { return a1[0].CompareTo(a2[0]); } ); this.cluster_init(); double before = 99999; double after = 0; while (before != after) { before = sd(data); this.cluster_main(); after = sd(data); } if (reduce) { for (int i = 0; i < 1000; i++) { optcluster(); before = 99999; after = 0; while (before != after) { before = sd(data); this.cluster_main(); after = sd(data); } } } } public cluster_alg(List<double[]> data1, double[] c) { this.k = c.Length; this.data = data1; data.TrimExcess(); centers = new double[k]; data.Sort ( delegate(double[] a1, double[] a2) { return a1[0].CompareTo(a2[0]); } ); centers = c; double before = 99999; double after = 0; while (before != after) { before = sd(data); this.cluster_main(); after = sd(data); } } void cluster_init() { Random r = new Random(); for (int i = 0; i < k; i++) { int index = (int)r.Next(data.Count / k * (i), data.Count / k * (i + 1)); double[] temp = data[index]; temp[3] = i; centers[i] = temp[0]; } } void cluster_main() { for (int i = 0; i < data.Count; i++) { double[] aRecord = data[i]; double distance = 9999999999; for (int j = 0; j < k; j++) { if (distance > (Math.Abs(centers[j] - aRecord[0]))) { distance = Math.Abs(centers[j] - aRecord[0]); aRecord[3] = j; } } } number = new double[k]; for (int j = 0; j < k; j++) { double[] sum = new double[k]; sum[j] = 0; int n = 0; for (int i = 0; i < data.Count; i++) { double[] aRecord = data[i]; if (aRecord[3] == j) { sum[j] = sum[j] + aRecord[0]; n++; } } centers[j] = sum[j] / n; number[j] = n; } } double sd(List<double[]> sample) { double sdd = 0; for (int i = 0; i < k; i++) { double temp = 0; for (int j = 0; j < sample.Count; j++) { double[] aRecord = sample[j]; if ((int)aRecord[3] == i) { temp = temp + (centers[i] - aRecord[0]) * (centers[i] - aRecord[0]); } } sdd = temp + sdd; } return sdd; } void optcluster() { List<double[]> centerinfo = new List<double[]>(); for (int i = 0; i < k; i++) { double[] temp = new double[2]; temp[0] = centers[i]; temp[1] = number[i]; centerinfo.Add(temp); } centerinfo.TrimExcess(); centerinfo.Sort( delegate(double[] a1, double[] a2) { return (a2[1].CompareTo(a1[1])); } ); int count = 0; int n = 0; for (int i = 0; i < k; i++) { if (n < 0.8 * data.Count) { double[] aInfo = centerinfo[i]; n = n + (int)aInfo[1]; count = i + 1; } } centers = new double[count]; for (int i = 0; i < count; i++) { double[] aInfo = centerinfo[i]; centers[i] = aInfo[0]; } k = count; number = new double[k]; } } 4. Sample code for Coordinate Agent Defining experiment public class experiment { public Guid ID; public double obj_value; public string name; public experimentSetting exp_settting; public bool done; public experiment clone() { experiment e = new experiment(); e.ID = this.ID; e.name = this.name; e.obj_value = this.obj_value; ; e.exp_settting.obj_function = this.exp_settting.obj_function; e.exp_settting.paras = new List<parameter>(); e.exp_settting.proteins = new List<protein>(); foreach (parameter p in this.exp_settting.paras) { parameter ap = new parameter(); ap.alias = p.alias; ap.interval = p.interval; ap.isInput = p.isInput; ap.max = p.max; ap.min = p.min; ap.name = p.name; ap.value = p.value; e.exp_settting.paras.Add(ap); } foreach (protein p in this.exp_settting.proteins) { protein ap = new protein(); ap.name = p.name; ap.retentiontime = p.retentiontime; e.exp_settting.proteins.Add(ap); } return e; } public experiment clone(experiment e) { e = new experiment(); e.ID = this.ID; e.name = this.name; e.obj_value = this.obj_value; ; e.exp_settting.obj_function = this.exp_settting.obj_function; e.exp_settting.paras = new List<parameter>(); e.exp_settting.proteins = new List<protein>(); foreach (parameter p in this.exp_settting.paras) { parameter ap = new parameter(); ap.alias = p.alias; ap.interval = p.interval; ap.isInput = p.isInput; ap.max = p.max; ap.min = p.min; ap.name = p.name; ap.value = p.value; e.exp_settting.paras.Add(ap); } foreach (protein p in this.exp_settting.proteins) { protein ap = new protein(); ap.name = p.name; ap.retentiontime = p.retentiontime; e.exp_settting.proteins.Add(ap); } return e; } public experiment () { //ID=999999999; obj_value=-9999999999; exp_settting=new experimentSetting(); done=false; ID = new Guid(); } public XmlElement getXmlElement (XmlDocument temp) { if (this.done) this.obj_value=this.calobj(); XmlElement exp=temp.CreateElement("experiment"); exp.SetAttribute("ID", this.ID.ToString()); exp.SetAttribute("obj_value", this.obj_value.ToString()); exp.SetAttribute("name", this.name); exp.SetAttribute("done", this.done.ToString()); exp.AppendChild(this.exp_settting.getXmlElement(temp)); return exp; } public bool compare(experiment e) { if (e.exp_settting.compare(this.exp_settting)) return true; else return false; } public bool compare_ignore_result(experiment e) { if(e.exp_settting.compare_ignore_result(this.exp_settting)) return true; else return false; } public double calobj () { Assembly code=this.objclass(); Type tp=code.GetType("objcalculation.calobj"); MethodInfo mi=tp.GetMethod("cal"); double objvalue=(double)mi.Invoke(null,null); this.obj_value = Math.Round(objvalue, 2); return this.obj_value; } private string trans_objfunc() { string code = "using System;\n"+ "namespace objcalculation\n"+ "{\n"+ "public static class calobj \n"+ "{ \n"; code = code + "\n" + "public static double cal() \n" + "{\n" ; foreach (parameter p in this.exp_settting.paras) { if (p.isInput) { code = code + "double " + p.alias +"="+ p.value +";\n"; } } code = code + "return " + this.exp_settting.obj_function + ";\n" + "}\n"+ "}\n"+ "}\n"; return code; } private Assembly objclass () { CSharpCodeProvider provider = new CSharpCodeProvider (); CompilerParameters ps = new CompilerParameters (); ps.GenerateExecutable = false; ps.GenerateInMemory = true; StringBuilder classSource = new StringBuilder (); classSource.Append (this.trans_objfunc ()); //Console.WriteLine (classSource.ToString ()); CompilerResults result = provider.CompileAssemblyFromSource (ps, classSource.ToString ()); //Console.WriteLine(result.Errors.Count); Assembly assembly = result.CompiledAssembly; return assembly; } public void writetodatabase() { if (!this.done) { Console.WriteLine("Write experiment data failed! The experiment has not been finished!"); return; } List<experiment> exps = new List<experiment>(); String conn_string = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=|DataDirectory|\\tecan_database.mdb"; System.Data.OleDb.OleDbConnection dataCon = new System.Data.OleDb.OleDbConnection(); dataCon.ConnectionString = conn_string; dataCon.Open(); String query_string; OleDbCommand query=null; OleDbDataReader reader; //parameters List<int> paraids = new List<int>(); List<double> values = new List<double>(); foreach (parameter p in this.exp_settting.paras) { query_string = "select * from [paras] where name='" + p.name + "'"; query = new OleDbCommand(query_string, dataCon); reader = query.ExecuteReader(); if (reader.Read()) { paraids.Add((int)reader.GetValue(0)); values.Add(p.value); } else { query_string = "insert into" + "[paras] ([name], [max], [min], [interval],[isinput],[alias]) values (" + "'" + p.name + "', " + p.max + ", " + p.min + ", " + p.interval + ", " + p.isInput + ", '" + p.alias + "')"; query = new OleDbCommand(query_string, dataCon); query.ExecuteNonQuery(); query = new OleDbCommand("SELECT @@IDENTITY", dataCon); reader = query.ExecuteReader(); reader.Read(); int id = (int)reader.GetValue(0); paraids.Add(id); values.Add(p.value); } } //proteins List<int> proids=new List<int>(); foreach (protein p in this.exp_settting.proteins) { //reader = new OleDbDataReader(); query_string = "select * from [protein] where name='" + p.name + "'"; query = new OleDbCommand(query_string, dataCon); reader = query.ExecuteReader(); if (reader.Read()) { proids.Add((int)reader.GetValue(0)); } else { query_string = "insert into" + "[protein] ([name], [retention]) values (" + "'" + p.name + "', " + p.retentiontime + ")"; query = new OleDbCommand(query_string, dataCon); query.ExecuteNonQuery(); query = new OleDbCommand("SELECT @@IDENTITY", dataCon); reader = query.ExecuteReader(); reader.Read(); int id = (int)reader.GetValue(0); proids.Add(id); } } //exp-setting int setid; query_string = "select * from [exp_setting] where obj='" + this.exp_settting.obj_function + "'"; query = new OleDbCommand(query_string, dataCon); reader = query.ExecuteReader(); if (reader.Read()) { setid = (int)reader.GetValue(0); } else { query_string = "insert into" + "[exp_setting] ([obj]) values (" + "'" + this.exp_settting.obj_function + "' " + ")"; query = new OleDbCommand(query_string, dataCon); query.ExecuteNonQuery(); query = new OleDbCommand("SELECT @@IDENTITY", dataCon); //reader = new OleDbDataReader(); reader = query.ExecuteReader(); reader.Read(); setid = (int)reader.GetValue(0); //setting-protein for (int i = 0; i < proids.Count; i++) { query_string = "insert into" + "[setting-proteins] ([proid],[setid]) values (" + proids[i] + "," + setid + ")"; query = new OleDbCommand(query_string, dataCon); query.ExecuteNonQuery(); } } //exp query_string = "insert into" + "[exp] ([name],[exp_setting_id],[obj_value]) values (" + "'" + this.name + "', " + setid + ", " + this.calobj() + ")"; query = new OleDbCommand(query_string, dataCon); query.ExecuteNonQuery(); query = new OleDbCommand("SELECT @@IDENTITY", dataCon); reader = query.ExecuteReader(); reader.Read(); int expid = (int)reader.GetValue(0); //para-exp for (int i=0;i<paraids.Count;i++) { query_string = "insert into" + "[para-exp] ([exp_id],[para_id],[value]) values (" + expid + "," + paraids[i] +","+ values[i] + ")"; query = new OleDbCommand(query_string, dataCon); query.ExecuteNonQuery(); } query.Dispose(); reader.Dispose(); dataCon.Dispose(); } } public class experimentSetting { public string obj_function; public List<parameter> paras; public List<protein> proteins; public experimentSetting () { paras=new List<parameter>(); proteins=new List<protein>(); } public XmlElement getXmlElement (XmlDocument temp) { XmlElement setting=temp.CreateElement("setting"); foreach (parameter p in paras) { setting.AppendChild (p.getXmlElement (temp)); } foreach (protein p in proteins) { setting.AppendChild (p.getXmlElement(temp)); } setting.SetAttribute("obj_function", obj_function); return setting; } public bool compare(experimentSetting es) { if (es.obj_function == this.obj_function && this.compare_paras(es.paras) && this.compare_proteins(es.proteins)) { return true; } return false; } public bool compare_ignore_result(experimentSetting es) { if (es.obj_function == this.obj_function && this.compare_paras_ignore_result(es.paras) && this.compare_proteins(es.proteins)) { return true; } return false; } public bool compare_paras(List<parameter> ps) { if (this.paras.Count == ps.Count) { foreach (parameter pa in ps) { bool a = false; foreach (parameter pb in this.paras) { if (pa.compare(pb)) { a = true; break; } } if (!a) return false; } } return true; } public bool compare_paras_ignore_result(List<parameter> ps) { if (this.paras.Count == ps.Count) { foreach (parameter pa in ps) { bool a = false; foreach (parameter pb in this.paras) { if (pa.compare_ignore_result(pb)) { a = true; break; } } if (!a) return false; } } return true; } public bool compare_proteins(List<protein> ps) { if (this.paras.Count == ps.Count) { foreach (protein pa in ps) { bool a = false; foreach (protein pb in this.proteins) { if (pa.compare(pb)) { a = true; break; } } if (!a) return false; } } return true; } } public class parameter { public string name; public double value; public double max; public double min; public double interval; public bool isInput; public string alias; public XmlElement getXmlElement(XmlDocument temp) { XmlElement para=temp.CreateElement("parameter"); para.SetAttribute("name",this.name); para.SetAttribute("value", this.value.ToString()); para.SetAttribute("max", this.max.ToString()); para.SetAttribute("min", this.min.ToString()); para.SetAttribute("interval", this.interval.ToString()); para.SetAttribute("isInput", this.isInput.ToString()); para.SetAttribute("alias", this.alias); return para; } public void setvalue(double v) { if (v >= this.max) { this.value = max; return; } if (v <= this.min) { this.value = min; return; } if (this.isInput) { double test = max; while (test > v) { test = test - interval; } double left = v - test; double right = test + interval - v; if (left >= right) { this.value = test + interval; } else { this.value = test; } } string delimStr = "."; char[] delimiter = delimStr.ToCharArray(); string words = this.interval.ToString(); string[] split = null; split = words.Split(delimiter); this.value=Math.Round(this.value,split[1].Length); } public bool compare(parameter p) { bool b = false; if (p.alias == this.alias && p.interval == this.interval && p.isInput == this.isInput && p.max == this.max && p.min == this.min && p.name == this.name && p.value == this.value) b = true; return b; } public bool compare_ignore_result(parameter p) { bool b = false; if (p.alias == this.alias && p.interval == this.interval && p.isInput == this.isInput && p.max == this.max && p.min == this.min && p.name == this.name && !this.isInput) b = true; else if (p.alias == this.alias && p.interval == this.interval && p.isInput == this.isInput && p.max == this.max && p.min == this.min && p.name == this.name && Math.Abs(p.value-this.value)<this.interval) return true; return b; } } public class protein { public string name; public double retentiontime; public XmlElement getXmlElement(XmlDocument temp) { XmlElement pro=temp.CreateElement("protein"); pro.SetAttribute("name",this.name); pro.SetAttribute("retention_time", this.retentiontime.ToString()); return pro; } public bool compare(protein p) { bool b = false; if (p.name == this.name && p.retentiontime == this.retentiontime) b = true; return b; } } Defining platform layout public class explocation { //public string labwarename; public int grid; public int site; public string wells; public bool used; } public class layout { public explocation[,] locs; public class carrier_info { public int name; public int grid; public List<labware_info> labwares; } public class labware_info { public int name; public int site; public string nickname; public bool ifexplocation; } public class exp_location { //public string name; public int site; public int grid; } public List<carrier_info> layoutlist; private bool first = true; public List<exp_location> explocs; public void load_layout(int id) { String conn_string = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=|DataDirectory|\\tecan_database.mdb"; System.Data.OleDb.OleDbConnection dataCon = new System.Data.OleDb.OleDbConnection(); dataCon.ConnectionString = conn_string; dataCon.Open(); String query_string; query_string = "select * from layout_tree where layout_id=" + id + " order by carrier, carrier_grid"; OleDbCommand query = new OleDbCommand(query_string, dataCon); OleDbDataAdapter adapter = new OleDbDataAdapter(query_string, dataCon); OleDbDataReader reader = query.ExecuteReader(); carrier_info temp_carrier = new carrier_info(); int carrier_name = 0; int carrier_grid = 0; carrier_info aCarrier = new carrier_info(); layoutlist = new List<carrier_info>(); bool a = true; while (reader.Read()) { //print(reader.GetValue(0) + " " + reader.GetValue(2)); if ((int)reader.GetValue(0) == carrier_name && (int)reader.GetValue(2) == carrier_grid) { labware_info aLabware = new labware_info(); aLabware.name = (int)reader.GetValue(1); aLabware.site = (int)reader.GetValue(3); aLabware.nickname = (string)reader.GetValue(5); aLabware.ifexplocation = (bool)reader.GetBoolean(6); aCarrier.labwares.Add(aLabware); } else { if (!a) { layoutlist.Add(aCarrier); } a = false; aCarrier = new carrier_info(); aCarrier.labwares = new List<labware_info>(); aCarrier.name = (int)reader.GetValue(0); carrier_name = (int)reader.GetValue(0); aCarrier.grid = (int)reader.GetValue(2); carrier_grid = (int)reader.GetValue(2); labware_info aLabware = new labware_info(); aLabware.name = (int)reader.GetValue(1); aLabware.site = (int)reader.GetValue(3); aLabware.nickname = (string)reader.GetValue(5); aLabware.ifexplocation = (bool)reader.GetBoolean(6); aCarrier.labwares.Add(aLabware); } } layoutlist.Add(aCarrier); reader.Dispose(); query.Dispose(); adapter.Dispose(); dataCon.Close(); dataCon.Dispose(); } public Script layout_script(Script scr) { explocs = new List<exp_location>(); String conn_string = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=|DataDirectory|\\tecan_database.mdb"; System.Data.OleDb.OleDbConnection dataCon = new System.Data.OleDb.OleDbConnection(); dataCon.ConnectionString = conn_string; dataCon.Open(); String query_string; foreach (carrier_info x in layoutlist) { query_string = "select * from carrier where ID=" + x.name; OleDbCommand query = new OleDbCommand(query_string, dataCon); OleDbDataAdapter adapter = new OleDbDataAdapter(query_string, dataCon); OleDbDataReader reader = query.ExecuteReader(); string name; while (reader.Read()) { name = (string)reader.GetValue(1); scr.AddCarrier(name, x.grid); } //int i=0; foreach (labware_info y in x.labwares) { query_string = "select * from labware where ID=" + y.name; OleDbCommand query2 = new OleDbCommand(query_string, dataCon); OleDbDataAdapter adapter2 = new OleDbDataAdapter(query_string, dataCon); OleDbDataReader reader2 = query2.ExecuteReader(); string carriername = ""; while (reader2.Read()) { carriername = (string)reader2.GetValue(1); } if (y.site != 0) scr.AddLabware(carriername, x.grid, y.site, y.nickname); //i++; if (y.ifexplocation) { exp_location el = new exp_location(); el.site = y.site; el.grid = x.grid; explocs.Add(el); } query2.Dispose(); adapter2.Dispose(); reader2.Dispose(); } query.Dispose(); adapter.Dispose(); reader.Dispose(); } dataCon.Close(); dataCon.Dispose(); if (first) { locs = new explocation[explocs.Count, 96]; for (int i = 0; i < explocs.Count; i++) { for (int j = 0; j < 96; j++) { locs[i, j] = new explocation(); } } layout.exp_location[] templocs = explocs.ToArray(); for (int i = 0; i < explocs.Count; i++) { for (int j = 0; j < 96; j++) { locs[i, j].grid = templocs[i].grid; locs[i, j].site = templocs[i].site; locs[i, j].used = false; locs[i, j].wells = transwellstring(j); } } first = false; } return scr; } private string transwellstring(int well) { string wellstring = ""; int x = (int)well / 8; int y = well - x * 8; x = x + 1; wellstring = Convert.ToChar(65 + y) + "" + x; return wellstring; } public int getditiwastegrid() { int grid = 0; foreach (layout.carrier_info x in layoutlist) { foreach (layout.labware_info y in x.labwares) { if (y.nickname == "diti_waste") { grid = x.grid; } } } return grid; } public int getditiwastesite() { int site = 0; foreach (layout.carrier_info x in layoutlist) { foreach (layout.labware_info y in x.labwares) { if (y.nickname == "diti_waste") { site = y.site - 1; } } } return site; } public int getwastegrid() { int wastegrid = 0; foreach (layout.carrier_info x in layoutlist) { foreach (layout.labware_info y in x.labwares) { if (y.nickname == "waste") { wastegrid = x.grid; } } } return wastegrid; } public int getwastesite() { int wastesite = 0; foreach (layout.carrier_info x in layoutlist) { foreach (layout.labware_info y in x.labwares) { if (y.nickname == "waste") { wastesite = y.site - 1; } } } return wastesite; } public int getcleanergrid() { int cleanergrid = 0; foreach (layout.carrier_info x in layoutlist) { foreach (layout.labware_info y in x.labwares) { if (y.nickname == "shallow") { cleanergrid = x.grid; } } } return cleanergrid; } public int getcleanersite() { int cleanersite = 0; foreach (layout.carrier_info x in layoutlist) { foreach (layout.labware_info y in x.labwares) { if (y.nickname == "shallow") { cleanersite = y.site - 1; } } } return cleanersite; } } Define buffer and related calculation public class buffer { public class buffertype { public int id; public int[] charge = new int[2]; public double[] K = new double[3]; public String[] type = new String[2]; } List<buffertype> bufferResults = new List<buffertype>(); private double ratio; public void conn(String perference, double phmax, double phmin) { String conn_string = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=|DataDirectory|\\tecan_database.mdb"; //print(conn_string); System.Data.OleDb.OleDbConnection dataCon = new System.Data.OleDb.OleDbConnection(); dataCon.ConnectionString = conn_string; dataCon.Open(); String query_string; if (perference != "N/A") query_string = "select * from buffer_system where buffer_name='" + perference + "' and maxpH>" + phmax + " and minpH<" + phmin; else query_string = "select * from buffer_system where maxpH>" + phmax + " and minpH<" + phmin; OleDbCommand query = new OleDbCommand(query_string, dataCon); OleDbDataAdapter adapter = new OleDbDataAdapter(query_string, dataCon); OleDbDataReader reader = query.ExecuteReader(); // decision module to deal wth the situation when more than one result show up while (reader.Read()) { buffertype aBuffer = new buffertype(); //read chemicals int caid = (int)reader.GetValue(1); int cbid = (int)reader.GetValue(2); String chemicalquery = "select chemical.charge, chemical.base, type.type from chemical inner join type on chemical.type=type.ID where chemical.ID=" + caid + " or chemical.ID=" + cbid; query = new OleDbCommand(chemicalquery, dataCon); adapter = new OleDbDataAdapter(chemicalquery, dataCon); OleDbDataReader aReader = query.ExecuteReader(); int baseid = 0; int i = 0; while (aReader.Read()) { aBuffer.charge[i] = (int)aReader.GetValue(0); aBuffer.type[i] = (String)aReader.GetValue(2); aBuffer.id = (int)reader.GetValue(0); if (aBuffer.type[i].Equals("salt")) baseid = (int)reader.GetValue(1); i++; } // read K values of the base String Kquery = "select * from base where ID=" + baseid; query = new OleDbCommand(Kquery, dataCon); adapter = new OleDbDataAdapter(Kquery, dataCon); OleDbDataReader bReader = query.ExecuteReader(); while (bReader.Read()) { aBuffer.K[0] = (double)bReader.GetValue(2); aBuffer.K[1] = (double)bReader.GetValue(3); aBuffer.K[2] = (double)bReader.GetValue(4); } bufferResults.Add(aBuffer); aReader.Dispose(); bReader.Dispose(); } dataCon.Close(); this.selectbuffer(bufferResults); } //assume concentrations of two solutions are same private void calvolume(double c, double ph) { buffertype aBuffer = new buffertype(); int charge = 0; aBuffer = bufferResults[0]; int typenum = 0; if (aBuffer.type[0].Equals(aBuffer.type[1])) typenum = 0; else if (aBuffer.type[0].Equals("acid") || aBuffer.type[1].Equals("acid")) typenum = 1; else typenum = 2; for (int i = 0; i < 2; i++) { if (aBuffer.type[i].Equals("salt")) { charge = aBuffer.charge[i]; } } switch (typenum) { case 0: this.calSalt(c, ph, aBuffer.K[0], aBuffer.K[1], aBuffer.K[2]); break; case 1: this.calAcid(c, ph, aBuffer.K[0], aBuffer.K[1], aBuffer.K[2], charge); break; case 2: this.calAlkali(c, ph, aBuffer.K[0], aBuffer.K[1], aBuffer.K[2], charge); break; } } private void selectbuffer(List<buffertype> bufferResults) { //if (bufferResults.Count == 1) print("selected!"); } private double calSalt(double c, double ph, double k1, double k2, double k3) { double hyd = Math.Pow(10, -ph); k1 = Math.Pow(10, -k1); k2 = Math.Pow(10, -k2); k3 = Math.Pow(10, -k3); double double double double r0 r1 r2 r3 = = = = 1; hyd / k1; hyd / k2; hyd / k3; r1 = r0 / r1; r2 = r1 / r2; r3 = r2 / r3; double sum = r0 + r1 + r2 + r3; r0 r1 r2 r3 = = = = r0 r1 r2 r3 / / / / sum sum sum sum * * * * c c c c / / / / 1000; 1000; 1000; 1000; ratio = (r0 + r1) / (r2 + r3); return ratio; } private double calAcid(double c, double ph, double k1, double k2, double k3, int charge) { double hyd = Math.Pow(10, -ph); k1 = Math.Pow(10, -k1); k2 = Math.Pow(10, -k2); k3 = Math.Pow(10, -k3); double double double double r0 r1 r2 r3 = = = = 1; hyd / k1; hyd / k2; hyd / k3; r1 = r0 / r1; r2 = r1 / r2; r3 = r2 / r3; double sum = r0 + r1 + r2 + r3; r0 r1 r2 r3 = = = = r0 r1 r2 r3 / / / / sum sum sum sum * * * * c c c c / / / / 1000; 1000; 1000; 1000; sum = r0 + r1 + r2 + r3; double Cl = hyd + c * charge / 1000 - Math.Pow(10, ph - 14) - sum; ratio = Cl / sum; return ratio; } private double calAlkali(double c, double ph, double k1, double k2, double k3, int charge) { double hyd = Math.Pow(10, -ph); k1 = Math.Pow(10, -k1); k2 = Math.Pow(10, -k2); k3 = Math.Pow(10, -k3); double double double double r0 r1 r2 r3 = = = = 1; hyd / k1; hyd / k2; hyd / k3; r1 = r0 / r1; r2 = r1 / r2; r3 = r2 / r3; double sum = r0 + r1 + r2 + r3; r0 r1 r2 r3 = = = = r0 r1 r2 r3 / / / / sum sum sum sum * * * * c c c c / / / / 1000; 1000; 1000; 1000; sum = r0 + r1 + r2 + r3; double OH = sum + Math.Pow(10, ph - 14) - hyd - charge * c / 1000; ratio = OH / sum; return ratio; } public double getRatio(double c, double ph) { this.calvolume(c, ph); return ratio; } }
© Copyright 2025