gpt4 book ai didi

c# - 从图表中的文件生成趋势线

转载 作者:行者123 更新时间:2023-11-30 23:01:05 25 4
gpt4 key购买 nike

我希望能够从文件夹中获取 .csv 文件并将它们绘制在图表中。

目前,我只是保存文件并像这样显示一条单独的曲线:

运行测试函数:

public List<Tuple<double,double>> runTest()
{
_dpg = new Root(this, "english", false);
_dpg.Init();
var filename = "Dpg10Export_" + DateTime.Now.ToString("yyyyMMdd_HHmm") + ".csv";
List<Tuple<double, double>> results = new List<Tuple<double, double>>();

var measurement = new Measurement();
var resultCode = RunMeasurement(60, 1000, 2200, ref measurement, null /* TODO: ref ProgressBar? */);

using (var fileStream = new StreamWriter(filename))
{
var count = measurement.I_inc_Values.Count;

for (var i = 0; i < count; i++)
{
var item = measurement.I_inc_Values[i + 1];
var current = (float)Convert.ToDouble(item);

item = measurement.LI_inc_Values[i + 1];
var inductance = (float)Convert.ToDouble(item);

var line = current.ToString() + ";" + inductance.ToString() + ";";

fileStream.WriteLine(line);
currentList.Add(current);
inductanceList.Add(inductance);
results.Add(new Tuple<double, double>(current,inductance));
if (i == 0 || (i + 1) % 32 == 0)
{
Console.WriteLine((i + 1) + ": " + line);
}
}
}
return results;
}

此代码会生成一个如下所示的 csv 文件:

0,22 | 0,44

0,32 | 0,54

0,44 | 0,65

这些值会产生一条如下所示的曲线:

image

当您点击“获取波形”按钮时,就会生成上面的曲线。但是,我想显示所有已生成的曲线,以及一个趋势线。我将如何实现这一点?

void BindData(List<Tuple<double,double>> results)
{
chart.Series.Clear();
var series1 = new System.Windows.Forms.DataVisualization.Charting.Series
{
Name = "curr/induc",
Color = System.Drawing.Color.Green,
IsVisibleInLegend = true,
IsXValueIndexed = true,
ChartType = SeriesChartType.Line
};

foreach (var i in results)
{
series1.Points.AddXY(i.Item2,i.Item1);
}

chart.Invalidate();
chart.Series.Add(series1);
}

private void getWaveformBtn_Click(object sender, EventArgs e)
{
Dpg10Client.Dpg10Settings settings = new Dpg10Client.Dpg10Settings();
Dpg10Instrument hej = new Dpg10Instrument(settings);
List<Tuple<double,double>> results = hej.runTest();
double current, inductance;

foreach(var i in results)
{
current = i.Item1;
inductance = i.Item2;
textBoxWaveformInput.Text += current.ToString() + inductance.ToString();
}
BindData(results);
}

长话短说

解析 CSV 文件中的信息以生成曲线,并根据这些文件创建趋势线。

标记为重复:该答案是关于直线的,这些值可以在曲线中波动。

最佳答案

有很多方法可以解决您问题中的大部分问题。

让我只处理实际上与计算多个系列的平均值有关的部分,即不会处理使用 CSV 文件中的数据创建系列。

有一个内置类可以进行各种高级数学运算,包括 financialstatistical ,但我没有找到有助于在多个系列上创建平均线/曲线的工具。

所以让我们自己做..

第一个问题是,要计算平均值,我们不仅需要数据,还需要数据,即它们的 x 值,必须分组“bins”中我们想得到平均值。

除非数据已经像那样分组,例如因为它们每天每个系列都有一个值,所以我们需要创建这样的组。

让我们首先收集我们要处理的所有系列的所有点;您可能需要调整循环以仅包含您的系列集..:

var allPoints = new List <DataPoint>();
for (int s = 0; s < 3; s++) // I know I have created these three series
{
Series ser = chartGraphic.Series["S" + (s+1)];
allPoints.AddRange(ser.Points);
}

接下来我们需要确定一个 bin 范围/大小,这是一个确定哪些 x 值应属于同一 bin/组的值。我选择了 10 个箱子。

所以我们最好得到 x 值的总范围,然后除以我们想要的 bin 数..:

double xmax = allPoints.Max(x => x.XValue);
double xmin = allPoints.Min(x => x.XValue);
int bins = 10;
double groupSize = (xmax - xmin) / (bins - 1);

接下来我们进行实际的计算;为此,我们排序我们的点,分组它们并为每个分组集选择平均值..:

var grouped = allPoints
.OrderBy(x => x.XValue)
.GroupBy(x => groupSize * (int)(x.XValue /groupSize ))
.Select(x => new { xval = x.Key, yavg = x.Average(y => y.YValues[0]) })
.ToList();

现在我们可以将它们添加到一个新系列中以显示 bin 中的平均值:

 foreach (var kv in grouped) avgSeries.Points.AddXY(kv.xval + groupSize/2f, kv.yavg);

我将平均点置于 bin 的中心。

这是一个例子:

enter image description here

关于这个例子的几点说明:

平均线没有显示真正的“趋势”,因为我的数据几乎是随机的。

我已将标记 添加到所有系列,使DataPoints 从线条中脱颖而出。这是我为平均值系列所做的:

avgSeries.MarkerStyle = MarkerStyle.Cross;
avgSeries.MarkerSize = 7;
avgSeries.BorderWidth = 2;

我添加了一个 StripLine 来显示 bin。方法如下:

StripLine sl = new StripLine();
sl.BackColor = Color.FromArgb(44,155,155,222);
sl.StripWidth = groupSize;
sl.Interval = groupSize * 2;
sl.IntervalOffset = chartGraphic.ChartAreas[0].AxisX.IntervalOffset;
chartGraphic.ChartAreas[0].AxisX.StripLines.Add(sl);

我还设置了一个点,使其具有非常低的 -300 值,以演示这将如何降低其 bin 中的平均值。为了使图表仍然很好地以正常数据范围为中心,我在 y 轴上添加了一个 ScaleBreakStyle:

chartGraphic.ChartAreas[0].AxisY.ScaleBreakStyle.BreakLineStyle = BreakLineStyle.Wave;
chartGraphic.ChartAreas[0].AxisY.ScaleBreakStyle.Enabled = true;

关于c# - 从图表中的文件生成趋势线,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51261839/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com