当前位置: 首页>>代码示例>>C#>>正文


C# Measurement.GetMessageList方法代码示例

本文整理汇总了C#中Measurement.GetMessageList方法的典型用法代码示例。如果您正苦于以下问题:C# Measurement.GetMessageList方法的具体用法?C# Measurement.GetMessageList怎么用?C# Measurement.GetMessageList使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在Measurement的用法示例。


在下文中一共展示了Measurement.GetMessageList方法的2个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。

示例1: BuildMeasurement


//.........这里部分代码省略.........
            mcr.triples_multi = results.triples_multi;

            INCCResult result;
            MeasOptionSelector mos = new MeasOptionSelector(meas.MeasOption, det.MultiplicityParams);
            result = meas.INCCAnalysisState.Lookup(mos);
            result.DeadtimeCorrectedRates.Singles.err = results.singles_err;
            result.DeadtimeCorrectedRates.Doubles.err = results.doubles_err;
            result.DeadtimeCorrectedRates.Triples.err = results.triples_err;
            result.DeadtimeCorrectedRates.Singles.v = results.singles;
            result.DeadtimeCorrectedRates.Doubles.v = results.doubles;
            result.DeadtimeCorrectedRates.Triples.v = results.triples;
            result.rates.RawRates.Scaler1s.v = results.scaler1;
            result.rates.RawRates.Scaler2s.v = results.scaler2;
            result.rates.RawRates.Scaler1s.err = results.scaler1_err;
            result.rates.RawRates.Scaler2s.err = results.scaler2_err;
            result.S1Sum = results.scaler1_sum;
            result.S2Sum = results.scaler2_sum;
            result.ASum = results.acc_sum;
            result.RASum = results.reals_plus_acc_sum;
            result.RAMult = TransferUtils.multarrayxfer(results.mult_reals_plus_acc_sum, INCC.MULTI_ARRAY_SIZE);
            result.NormedAMult = TransferUtils.multarrayxfer(results.mult_acc_sum, INCC.MULTI_ARRAY_SIZE);
            result.MaxBins = (ulong)Math.Max(result.RAMult.Length, result.NormedAMult.Length);
            result.MinBins = (ulong)Math.Min(result.RAMult.Length, result.NormedAMult.Length);
            mcr.RawDoublesRate.v = results.uncorrected_doubles;
            mcr.RawDoublesRate.err = results.uncorrected_doubles_err;
            result.singles_multi = results.singles_multi;
            result.doubles_multi = results.doubles_multi;
            result.triples_multi = results.triples_multi;

            // hack expansion of Normed mult array to same length as Acc mult array on each cycle to accomodate TheoreticalOutlier calc array length bug
            ExpandMaxBins(MaxBins, meas.Cycles, det.MultiplicityParams);
            Bloat(MaxBins, mcr);

            List<MeasurementMsg> msgs = meas.GetMessageList(det.MultiplicityParams);

            // move the error messages
            for (int i = 0; i < INCC.NUM_ERROR_MSG_CODES; i++)
            {
                int index = i * INCC.ERR_MSG_LENGTH;
                string e = TransferUtils.str(results.error_msg_codes + index, INCC.ERR_MSG_LENGTH);
                if (e.Length > 0)
                    meas.AddMessage(msgs, LogLevels.Error, 911, e, meas.MeasurementId.MeasDateTime);
            }
            // move the warning messages
            for (int i = 0; i < INCC.NUM_WARNING_MSG_CODES; i++)
            {
                int index = i * INCC.ERR_MSG_LENGTH;
                string w = TransferUtils.str(results.warning_msg_codes + index, INCC.ERR_MSG_LENGTH);
                if (w.Length > 0)
                    meas.AddMessage(msgs, LogLevels.Warning, 411, w, meas.MeasurementId.MeasDateTime);
            }

            #region results transfer
            INCCMethodResults imr;
            bool got = meas.INCCAnalysisResults.TryGetINCCResults(det.MultiplicityParams, out imr); // only ever this single mkey for INCC5-style transfer import, (thankfully)
            if (got)
                imr.primaryMethod = OldToNewMethodId(results.primary_analysis_method);
            // check these results against the meas.MeasOption expectation => seems to always be 1 - 1 with (opt, sr) -> results, and subresults only for verif and calib choice
            //         rates -> none,
            //         bkg -> bkg, norm -> bias, init src -> init src, prec ->  prec,
            //         calib -> calib, 1 or more INCC methods on the methods submap
            //         verif -> 1 or more INCC methods on the methods submap
            foreach (iresultsbase r in itf.method_results_list)
            {
                if (r is results_init_src_rec)
                {
开发者ID:hnordquist,项目名称:INCC6,代码行数:67,代码来源:INCCKnew.cs

示例2: MoveResultsRec


//.........这里部分代码省略.........
                            mcr = m.CountingAnalysisResults.GetFirstMultiplicity;
                    }
                if (mcr == null)
                    mcr = new MultiplicityCountingRes();  // inadequate attempt tries to account for LM-only condition, where no mcr, or no matching mcr, exists

                rec.r_acc_sngl_test_rate_limit = m.Tests.accSnglTestRateLimit;
                rec.r_acc_sngl_test_precision_limit = m.Tests.accSnglTestPrecisionLimit;
                rec.r_acc_sngl_test_outlier_limit = m.Tests.accSnglTestOutlierLimit;
                rec.r_outlier_test_limit = m.Tests.outlierTestLimit;
                rec.r_bkg_doubles_rate_limit = m.Tests.bkgDoublesRateLimit;
                rec.r_bkg_triples_rate_limit = m.Tests.bkgTriplesRateLimit;
                rec.r_chisq_limit = m.Tests.chiSquaredLimit;
                rec.r_max_num_failures = m.Tests.maxNumFailures;
                rec.r_high_voltage_test_limit = m.Tests.highVoltageTestLimit;

                rec.r_normal_backup_assay_test_lim = m.Tests.normalBackupAssayTestLimit;
                rec.r_max_runs_for_outlier_test = m.Tests.maxCyclesForOutlierTest;
                rec.r_checksum_test = (byte)(m.Tests.checksum ? 1 : 0);
                rec.results_accidentals_method = (m.Tests.accidentalsMethod == AccidentalsMethod.Measure ? INCC.IDC_MEASURE_ACCIDENTALS : INCC.IDC_CALCULATE_ACCIDENTALS);

                rec.passive_bkg_singles_rate = m.Background.DeadtimeCorrectedRates.Singles.v;
                rec.passive_bkg_singles_rate_err = m.Background.DeadtimeCorrectedRates.Singles.err;
                rec.passive_bkg_doubles_rate = m.Background.DeadtimeCorrectedRates.Doubles.v;
                rec.passive_bkg_doubles_rate_err = m.Background.DeadtimeCorrectedRates.Doubles.err;
                rec.passive_bkg_triples_rate = m.Background.DeadtimeCorrectedRates.Triples.v;
                rec.passive_bkg_triples_rate_err = m.Background.DeadtimeCorrectedRates.Triples.err;
                rec.active_bkg_singles_rate = m.Background.INCCActive.Singles.v;
                rec.active_bkg_singles_rate_err = m.Background.INCCActive.Singles.err;
                rec.passive_bkg_scaler1_rate = m.Background.Scaler1.v;
                rec.passive_bkg_scaler2_rate = m.Background.Scaler2.v;
                rec.active_bkg_scaler1_rate = m.Background.INCCActive.Scaler1Rate;
                rec.active_bkg_scaler2_rate = m.Background.INCCActive.Scaler2Rate;

                List<MeasurementMsg> msgs = m.GetMessageList(m.Detector.MultiplicityParams);
                byte[] bb = new byte[INCC.NUM_ERROR_MSG_CODES * INCC.ERR_MSG_LENGTH];
                int indx = 0, recidx = 0;
                for (int i = 0; i < msgs.Count && recidx < INCC.NUM_ERROR_MSG_CODES; i++)
                {
                    if (msgs.Count > i && string.IsNullOrEmpty(msgs[i].text) && msgs[i].IsError)
                    {
                        char[] aa = msgs[i].text.ToCharArray(0, Math.Min(msgs[i].text.Length, INCC.ERR_MSG_LENGTH));
                        Encoding.ASCII.GetBytes(aa, 0, aa.Length, bb, indx);
                        recidx++;
                    }
                    indx += INCC.ERR_MSG_LENGTH;
                }
                TransferUtils.Copy(bb, 0, rec.error_msg_codes, 0, INCC.NUM_ERROR_MSG_CODES * INCC.ERR_MSG_LENGTH);
                bb = new byte[INCC.NUM_ERROR_MSG_CODES * INCC.ERR_MSG_LENGTH];
                indx = 0; recidx = 0;
                for (int i = 0; i < msgs.Count && recidx < INCC.NUM_ERROR_MSG_CODES; i++)
                {
                    if (msgs.Count > i && string.IsNullOrEmpty(msgs[i].text) && msgs[i].IsWarning)
                    {
                        char[] aa = msgs[i].text.ToCharArray(0, Math.Min(msgs[i].text.Length, INCC.ERR_MSG_LENGTH));
                        Encoding.ASCII.GetBytes(aa, 0, aa.Length, bb, indx);
                        recidx++;
                    }
                    indx += INCC.ERR_MSG_LENGTH;
                }
                TransferUtils.Copy(bb, 0, rec.warning_msg_codes, 0, INCC.NUM_ERROR_MSG_CODES * INCC.ERR_MSG_LENGTH);

                // these ride on, or can be computed from, m.Cycles, but they sum across multiple analyzers and so are not considered complete yet for LM measurements
                rec.total_number_runs = (ushort)m.Cycles.GetValidCycleCount(); // any and all cycles
                rec.number_good_runs = (ushort)m.Cycles.GetUseableCycleCount();  // those that are marked OK
                rec.total_good_count_time = (ushort)m.Cycles.GetUseableCycleCount() * m.AcquireState.run_count_time;  // check against time on first cycle, to assert
开发者ID:hnordquist,项目名称:INCC6,代码行数:66,代码来源:INCCKnew.cs


注:本文中的Measurement.GetMessageList方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。