From ef8c48d4ab395c19c2f92aa6a7d88f82a743ded7 Mon Sep 17 00:00:00 2001 From: Brett Webster Date: Sat, 6 Apr 2024 06:40:50 -0500 Subject: [PATCH 01/13] renamed a few test files. tested the dropna function --- src/Pandas.NET/DataFrames/DataFrame.Index.cs | 8 ++--- ...ame.copyTest.cs => DataFrame.test.copy.cs} | 0 ...ribeTest.cs => DataFrame.test.describe.cs} | 0 ...me.drop.test.cs => DataFrame.test.drop.cs} | 3 -- .../DataFrames/DataFrame.test.dropna.cs | 30 +++++++++++++++++++ 5 files changed, 32 insertions(+), 9 deletions(-) rename test/Pandas.NET.Test/DataFrames/{DataFrame.copyTest.cs => DataFrame.test.copy.cs} (100%) rename test/Pandas.NET.Test/DataFrames/{DataFrame.describeTest.cs => DataFrame.test.describe.cs} (100%) rename test/Pandas.NET.Test/DataFrames/{DataFrame.drop.test.cs => DataFrame.test.drop.cs} (95%) create mode 100644 test/Pandas.NET.Test/DataFrames/DataFrame.test.dropna.cs diff --git a/src/Pandas.NET/DataFrames/DataFrame.Index.cs b/src/Pandas.NET/DataFrames/DataFrame.Index.cs index 3ecaf5d..4e4e129 100644 --- a/src/Pandas.NET/DataFrames/DataFrame.Index.cs +++ b/src/Pandas.NET/DataFrames/DataFrame.Index.cs @@ -1,5 +1,6 @@ using System; using System.Collections.Generic; +using System.Data.Common; using System.Linq; using System.Text; using Tensorflow; @@ -19,11 +20,6 @@ public DataFrame this[Slice slice] { return _data.FirstOrDefault(x => x.name == columName); } - - set - { - throw new NotImplementedException(""); - } } public Series this[string columName] @@ -86,7 +82,7 @@ DataFrame Slice(Slice slice) index.SetValue(_index.GetValue(row), data1RowIndex); data1RowIndex++; } - + foreach (var d in data1) d.SetIndex(index); diff --git a/test/Pandas.NET.Test/DataFrames/DataFrame.copyTest.cs b/test/Pandas.NET.Test/DataFrames/DataFrame.test.copy.cs similarity index 100% rename from test/Pandas.NET.Test/DataFrames/DataFrame.copyTest.cs rename to test/Pandas.NET.Test/DataFrames/DataFrame.test.copy.cs diff --git a/test/Pandas.NET.Test/DataFrames/DataFrame.describeTest.cs b/test/Pandas.NET.Test/DataFrames/DataFrame.test.describe.cs similarity index 100% rename from test/Pandas.NET.Test/DataFrames/DataFrame.describeTest.cs rename to test/Pandas.NET.Test/DataFrames/DataFrame.test.describe.cs diff --git a/test/Pandas.NET.Test/DataFrames/DataFrame.drop.test.cs b/test/Pandas.NET.Test/DataFrames/DataFrame.test.drop.cs similarity index 95% rename from test/Pandas.NET.Test/DataFrames/DataFrame.drop.test.cs rename to test/Pandas.NET.Test/DataFrames/DataFrame.test.drop.cs index dd0e7be..44d1032 100644 --- a/test/Pandas.NET.Test/DataFrames/DataFrame.drop.test.cs +++ b/test/Pandas.NET.Test/DataFrames/DataFrame.test.drop.cs @@ -1,6 +1,3 @@ -using System; -using System.Linq; -using Tensorflow; using Xunit; using static PandasNet.PandasApi; diff --git a/test/Pandas.NET.Test/DataFrames/DataFrame.test.dropna.cs b/test/Pandas.NET.Test/DataFrames/DataFrame.test.dropna.cs new file mode 100644 index 0000000..22e6239 --- /dev/null +++ b/test/Pandas.NET.Test/DataFrames/DataFrame.test.dropna.cs @@ -0,0 +1,30 @@ +using System; +using PandasNet; +using Xunit; +using static PandasNet.PandasApi; + +namespace Pandas.Test +{ + public class DataFrameDropnaTest + { + [Fact] + public void TestDropna() + { + // Arrange + var df = pd.DataFrame.from_dict("{'col_1': [3, 2, 1, 0], 'col_2': ['a', 'b', 'c', 'd']}"); + Assert.Equal(4, df.shape[0]); + Assert.Equal(2, df.shape[1]); + df["col_1"].SetNull(1); + df["col_2"].SetNull(2); + + // Act + var result = df.dropna(); + + // Assert + Assert.Equal(2, result.shape[0]); //rows + Assert.Equal(2, result.shape[1]); //columns + Assert.Equal(new int[] { 3, 0 }, result["col_1"].array()); + Assert.Equal(new string[] { "a", "d" }, result["col_2"].array()); + } + } +} \ No newline at end of file From 8f7fd1918359902c188007437e08ff882b3a40d0 Mon Sep 17 00:00:00 2001 From: Brett Webster Date: Sun, 14 Apr 2024 15:32:23 -0500 Subject: [PATCH 02/13] indexer tests --- src/Pandas.NET/DataFrames/DataFrame.Index.cs | 4 +- .../DataFrames/DataFrame.test.index.cs | 83 +++++++++++++++++++ .../DataFrames/PandasConsole.indexers.cs | 28 +++++++ test/PandasConsole/Program.cs | 19 +++++ 4 files changed, 132 insertions(+), 2 deletions(-) create mode 100644 test/Pandas.NET.Test/DataFrames/DataFrame.test.index.cs create mode 100644 test/PandasConsole/DataFrames/PandasConsole.indexers.cs diff --git a/src/Pandas.NET/DataFrames/DataFrame.Index.cs b/src/Pandas.NET/DataFrames/DataFrame.Index.cs index 4e4e129..4c685ce 100644 --- a/src/Pandas.NET/DataFrames/DataFrame.Index.cs +++ b/src/Pandas.NET/DataFrames/DataFrame.Index.cs @@ -14,11 +14,11 @@ public DataFrame this[Slice slice] get => Slice(slice); } - public Series this[int row, string columName] + public object this[int row, string columName] { get { - return _data.FirstOrDefault(x => x.name == columName); + return _data.FirstOrDefault(x => x.name == columName).GetValue(row); } } diff --git a/test/Pandas.NET.Test/DataFrames/DataFrame.test.index.cs b/test/Pandas.NET.Test/DataFrames/DataFrame.test.index.cs new file mode 100644 index 0000000..6fa2a9d --- /dev/null +++ b/test/Pandas.NET.Test/DataFrames/DataFrame.test.index.cs @@ -0,0 +1,83 @@ +using System.Linq; +using Tensorflow.NumPy; +using static PandasNet.PandasApi; +using Tensorflow; +using PandasNet; +using System.Collections.Generic; +using System.Text.Json; + +namespace Pandas.Test +{ + public class DataFrameIndexTest + { + [Fact] + public void IndexTest1_Slice() + { + //Arrange + var df = pd.DataFrame.from_dict("{'col_1': [1, 2, 3, 4, 5], 'col_2': ['a', 'b', 'c', 'd', 'e']}"); + + //Act + var slicedDf = df[new Slice(1, 4, 1)]; + + //Assert + Assert.Equal(3, slicedDf.shape[0]); + Assert.Equal(2, slicedDf.shape[1]); + + Assert.Equal(2, slicedDf["col_1"].GetValue(0)); + Assert.Equal("c", slicedDf["col_2"].GetValue(1)); + } + + [Fact] + public void TestIndexer() + { + // Arrange + var df = pd.DataFrame.from_dict("{'col_1': [3, 2, 1, 0], 'col_2': ['a', 'b', 'c', 'd']}"); + + + // Act + var indexedInt = df[0, "col_1"]; + var indexedString = df[1, "col_2"]; + + // Assert + Assert.Equal(df["col_1"].GetValue(0), (int)indexedInt); + Assert.Equal(df["col_2"].GetValue(1), (string)indexedString); + } + + [Fact] + public void TestReturnsCorrectSeries() + { + // Arrange + var df = pd.DataFrame.from_dict("{'col_1': [3, 2, 1, 0]}"); + + // Act + Series col2 = new Series(new int[] { 1, 2, 3, 4 }, new Column { Name = "col_2", DType = typeof(int) }); + df.data.Add(col2); + + // Assert + Assert.Equal(col2, df["col_2"]); + Assert.True(col2.array().SequenceEqual(df["col_2"].array())); + } + + [Fact] + public void TestMultiColumnIndexer() + { + // Arrange + var df = pd.DataFrame.from_dict("{'col_1': [3, 2, 1, 0], 'col_2': ['a', 'b', 'c', 'd'], 'col_3': [1, 2, 3, 4]}"); + + Assert.Equal(3, df.shape[1]); + + // Act + var indexedDf = df["col_1", "col_2"]; + + // Assert + + + Assert.Equal(2, indexedDf.shape[1]); + Assert.Equal(4, indexedDf.shape[0]); + + Assert.Equal(3, indexedDf["col_1"].GetValue(0)); + Assert.Equal("b", indexedDf["col_2"].GetValue(1)); + } + + } +} \ No newline at end of file diff --git a/test/PandasConsole/DataFrames/PandasConsole.indexers.cs b/test/PandasConsole/DataFrames/PandasConsole.indexers.cs new file mode 100644 index 0000000..59a558f --- /dev/null +++ b/test/PandasConsole/DataFrames/PandasConsole.indexers.cs @@ -0,0 +1,28 @@ +using System.Collections.Generic; +using System.Text.Json; +using PandasNet; +using static PandasNet.PandasApi; + +namespace PandasConsole.Methods +{ + public class PandasConsoleIndexers + { + public DataFrame GetSampleDataFrame() + { + var df = pd.DataFrame.from_dict(JsonSerializer.Serialize(new Dictionary + { + { "col_1",new int[] { 1, 2, 3, 4, 5 }}, + { "col_2", new int[] { 4, 5, 6, 7, 8 }}, + { "col_3 ", new int[] { 7, 8, 9, 10, 11 }} + })); + return df; + } + + + public (DataFrame, DataFrame) MultiColumnIndexer() + { + var df = GetSampleDataFrame(); + return (df, df["col_1","col_2"]); + } + } +} \ No newline at end of file diff --git a/test/PandasConsole/Program.cs b/test/PandasConsole/Program.cs index 91dd465..2367d18 100644 --- a/test/PandasConsole/Program.cs +++ b/test/PandasConsole/Program.cs @@ -19,6 +19,9 @@ public class Options [Option("describe", Required = false, HelpText = "Print the describe a DataFrame")] public bool DescribeSample { get; set; } + + [Option("multi-column-indexer", Required = false, HelpText = "Print the describe a DataFrame")] + public bool MultiColumnIndexer { get; set; } } @@ -35,6 +38,10 @@ static void Main(string[] args) { CommandRunners.RunDescribeSample(); } + if (o.MultiColumnIndexer) + { + CommandRunners.RunMultiColumnIndexer(); + } }) .WithNotParsed(CommandRunners.HandleParseError); } @@ -59,6 +66,18 @@ public static void RunDescribeSample() Console.Write(Utils.RenderDataTable(Utils.DataFrameToTable(df))); } + + internal static void RunMultiColumnIndexer() + { + var indexers = new PandasConsoleIndexers(); + var dfTuple = indexers.MultiColumnIndexer(); + + Console.WriteLine("Original DataFrame"); + Console.Write(Utils.RenderDataTable(Utils.DataFrameToTable(dfTuple.Item1))); + + Console.WriteLine("Indexed DataFrame"); + Console.Write(Utils.RenderDataTable(Utils.DataFrameToTable(dfTuple.Item2))); + } } } } From 4180a8ce3b8742eb72c611f03fd34dd5aab05a0a Mon Sep 17 00:00:00 2001 From: Brett Webster Date: Sat, 27 Apr 2024 18:04:47 -0500 Subject: [PATCH 03/13] subtraction --- .vscode/launch.json | 26 +++++++ .vscode/tasks.json | 41 ++++++++++ src/Pandas.NET/Columns/Column.cs | 11 +++ .../DataFrames/DataFrame.operator.cs | 2 + src/Pandas.NET/Series/Series.operator.cs | 8 +- .../DataFrames/DataFrame.test.operator.cs | 75 +++++++++++++++++++ 6 files changed, 159 insertions(+), 4 deletions(-) create mode 100644 .vscode/launch.json create mode 100644 .vscode/tasks.json create mode 100644 test/Pandas.NET.Test/DataFrames/DataFrame.test.operator.cs diff --git a/.vscode/launch.json b/.vscode/launch.json new file mode 100644 index 0000000..6b6006e --- /dev/null +++ b/.vscode/launch.json @@ -0,0 +1,26 @@ +{ + "version": "0.2.0", + "configurations": [ + { + // Use IntelliSense to find out which attributes exist for C# debugging + // Use hover for the description of the existing attributes + // For further information visit https://github.com/dotnet/vscode-csharp/blob/main/debugger-launchjson.md + "name": ".NET Core Launch (console)", + "type": "coreclr", + "request": "launch", + "preLaunchTask": "build", + // If you have changed target frameworks, make sure to update the program path. + "program": "${workspaceFolder}/test/Pandas.NET.Test/bin/Debug/net8.0/Pandas.NET.Test.dll", + "args": [], + "cwd": "${workspaceFolder}/test/Pandas.NET.Test", + // For more information about the 'console' field, see https://aka.ms/VSCode-CS-LaunchJson-Console + "console": "internalConsole", + "stopAtEntry": false + }, + { + "name": ".NET Core Attach", + "type": "coreclr", + "request": "attach" + } + ] +} \ No newline at end of file diff --git a/.vscode/tasks.json b/.vscode/tasks.json new file mode 100644 index 0000000..5fd1dbd --- /dev/null +++ b/.vscode/tasks.json @@ -0,0 +1,41 @@ +{ + "version": "2.0.0", + "tasks": [ + { + "label": "build", + "command": "dotnet", + "type": "process", + "args": [ + "build", + "${workspaceFolder}/Pandas.NET.sln", + "/property:GenerateFullPaths=true", + "/consoleloggerparameters:NoSummary;ForceNoAlign" + ], + "problemMatcher": "$msCompile" + }, + { + "label": "publish", + "command": "dotnet", + "type": "process", + "args": [ + "publish", + "${workspaceFolder}/Pandas.NET.sln", + "/property:GenerateFullPaths=true", + "/consoleloggerparameters:NoSummary;ForceNoAlign" + ], + "problemMatcher": "$msCompile" + }, + { + "label": "watch", + "command": "dotnet", + "type": "process", + "args": [ + "watch", + "run", + "--project", + "${workspaceFolder}/Pandas.NET.sln" + ], + "problemMatcher": "$msCompile" + } + ] +} \ No newline at end of file diff --git a/src/Pandas.NET/Columns/Column.cs b/src/Pandas.NET/Columns/Column.cs index 22481d7..32940a9 100644 --- a/src/Pandas.NET/Columns/Column.cs +++ b/src/Pandas.NET/Columns/Column.cs @@ -10,6 +10,17 @@ public class Column public string Name { get; set; } public Type DType { get; set; } + + public Column() + { + } + + public Column(string name, Type dtype) + { + Name = name; + DType = dtype; + } + public override string ToString() => $"{Name} {DType}"; } diff --git a/src/Pandas.NET/DataFrames/DataFrame.operator.cs b/src/Pandas.NET/DataFrames/DataFrame.operator.cs index 3bebe6c..01d07d0 100644 --- a/src/Pandas.NET/DataFrames/DataFrame.operator.cs +++ b/src/Pandas.NET/DataFrames/DataFrame.operator.cs @@ -16,7 +16,9 @@ public partial class DataFrame { data.Add(a.data[i] - b.data switch { + double[] double64 => double64[i], float[] float32 => float32[i], + int[] int32 => int32[i], _ => throw new NotImplementedException("") }); } diff --git a/src/Pandas.NET/Series/Series.operator.cs b/src/Pandas.NET/Series/Series.operator.cs index f5183d1..e3270de 100644 --- a/src/Pandas.NET/Series/Series.operator.cs +++ b/src/Pandas.NET/Series/Series.operator.cs @@ -51,14 +51,14 @@ public partial class Series throw new NotImplementedException(""); } - public static Series operator -(Series a, float b) + public static Series operator -(Series a, double b) { if (a.data is float[] float32) - return new Series(float32.Select(x => x - b).ToArray()); + return new Series(float32.Select(x => x - Convert.ToSingle(b)).ToArray(), a.column); else if (a.data is double[] float64) - return new Series(float64.Select(x => x - b).ToArray()); + return new Series(float64.Select(x => x - b).ToArray(), a.column); else if (a.data is int[] int32) - return new Series(int32.Select(x => x - b).ToArray()); + return new Series(int32.Select(x => x - Convert.ToInt32(b)).ToArray(), a.column); throw new NotImplementedException(""); } diff --git a/test/Pandas.NET.Test/DataFrames/DataFrame.test.operator.cs b/test/Pandas.NET.Test/DataFrames/DataFrame.test.operator.cs new file mode 100644 index 0000000..8c495c9 --- /dev/null +++ b/test/Pandas.NET.Test/DataFrames/DataFrame.test.operator.cs @@ -0,0 +1,75 @@ +using System; +using System.Collections.Generic; +using HDF5CSharp; +using PandasNet; + + +namespace Pandas.Test; + +public class DataFrameOperatorTests +{ + [Fact] + public void TestSubtractionOperator() + { + // Arrange + List data = new List + { + new Series(new int[] { 1, 2, 3, 4, 5 }, new Column { Name = "column1", DType = typeof(int) }), + new Series(new int[] { 2, 4, 6, 8, 10 }, new Column { Name = "column2", DType = typeof(int) }) + }; + var df = new DataFrame(data); + + var series = new Series(new int[] { 1, 2 }, new Series(new string[]{"column1","column2"}), new Column("sub", typeof(int))); + + // Act + var result = df - series; + + // Assert + Assert.Equal(new int[] { 0, 1, 2, 3, 4 }, result["column1"].data as int[]); + Assert.Equal(new int[] { 0, 2, 4, 6, 8}, result["column2"].data as int[]); + } + + + [Fact] + public void TestSubtractionOperator_Float() + { + // Arrange + List data = new List + { + new Series(new float[] { 1, 2, 3, 4, 5 }, new Column { Name = "column1", DType = typeof(float) }), + new Series(new float[] { 2, 4, 6, 8, 10 }, new Column { Name = "column2", DType = typeof(float) }) + }; + var df = new DataFrame(data); + + var series = new Series(new float[] { 0.5F, 1.5F }, new Series(new string[]{"column1","column2"}), new Column("sub", typeof(float))); + + // Act + var result = df - series; + + // Assert + Assert.Equal(new float[] { 0.5F, 1.5F, 2.5F, 3.5F, 4.5F }, result["column1"].data as float[]); + Assert.Equal(new float[] { 0.5F, 2.5F, 4.5F, 6.5F, 8.5F}, result["column2"].data as float[]); + } + + + [Fact] + public void TestSubtractionOperator_Double() + { + // Arrange + List data = new List + { + new Series(new double[] { 1, 2, 3, 4, 5 }, new Column { Name = "column1", DType = typeof(double) }), + new Series(new double[] { 2, 4, 6, 8, 10 }, new Column { Name = "column2", DType = typeof(double) }) + }; + var df = new DataFrame(data); + + var series = new Series(new double[] { 0.5, 1.5 }, new Series(new string[]{"column1","column2"}), new Column("sub", typeof(double))); + + // Act + var result = df - series; + + // Assert + Assert.Equal(new double[] { 0.5, 1.5, 2.5, 3.5, 4.5 }, result["column1"].data as double[]); + Assert.Equal(new double[] { 0.5, 2.5, 4.5, 6.5, 8.5}, result["column2"].data as double[]); + } +} From 671dc479e10649a803db61600cce6697da1ac89c Mon Sep 17 00:00:00 2001 From: Brett Webster Date: Sun, 14 Jul 2024 09:21:32 -0500 Subject: [PATCH 04/13] Subtract, divide, and equals --- .../DataFrames/DataFrame.operator.cs | 12 +++ src/Pandas.NET/Series/Series.operator.cs | 78 +++++++++++-------- .../DataFrames/DataFrame.test.operator.cs | 75 +++++++++++++----- 3 files changed, 113 insertions(+), 52 deletions(-) diff --git a/src/Pandas.NET/DataFrames/DataFrame.operator.cs b/src/Pandas.NET/DataFrames/DataFrame.operator.cs index 01d07d0..58db786 100644 --- a/src/Pandas.NET/DataFrames/DataFrame.operator.cs +++ b/src/Pandas.NET/DataFrames/DataFrame.operator.cs @@ -34,7 +34,9 @@ public partial class DataFrame { data.Add(a.data[i] / b.data switch { + double[] double64 => double64[i], float[] float32 => float32[i], + int[] int32 => int32[i], _ => throw new NotImplementedException("") }); } @@ -42,6 +44,16 @@ public partial class DataFrame return new DataFrame(data, index: a.index, columns: a.columns); } + public static DataFrame operator *(DataFrame a, Series b) + { + var data = new List(); + for(int i=0;i x != b).ToArray()); - else if (a.data is double[] float64) - return new Series(float64.Select(x => x != b).ToArray()); + if (a.data is int[] || a.data is float[] || a.data is double[]) + { + return new Series(a.data.Cast().Select(x => x != b).ToArray() + , column: a._column + , index: a._index?.copy()); + } + throw new NotImplementedException(""); } - public static Series operator ==(Series a, float b) + public static Series operator ==(Series a, double b) { - if (a.data is float[] float32) - return new Series(float32.Select(x => x == b).ToArray()); - else if (a.data is double[] float64) - return new Series(float64.Select(x => x == b).ToArray()); + if (a.data is int[] || a.data is float[] || a.data is double[]) + { + return new Series(a.data.Cast().Select(x => x == b).ToArray() + , column: a._column + , index: a._index?.copy()); + } + throw new NotImplementedException(""); } @@ -42,41 +48,51 @@ public partial class Series throw new NotImplementedException(""); } - public static Series operator +(Series a, float b) + public static Series operator +(Series a, double b) { - if (a.data is float[] float32) - return new Series(float32.Select(x => x + b).ToArray()); - else if (a.data is double[] float64) - return new Series(float64.Select(x => x + b).ToArray()); + if (a.data is int[] || a.data is float[] || a.data is double[]) + { + return new Series(a.data.Cast().Select(x => x + b).ToArray() + , column: a._column + , index: a._index?.copy()); + } + throw new NotImplementedException(""); } public static Series operator -(Series a, double b) { - if (a.data is float[] float32) - return new Series(float32.Select(x => x - Convert.ToSingle(b)).ToArray(), a.column); - else if (a.data is double[] float64) - return new Series(float64.Select(x => x - b).ToArray(), a.column); - else if (a.data is int[] int32) - return new Series(int32.Select(x => x - Convert.ToInt32(b)).ToArray(), a.column); + if (a.data is int[] || a.data is float[] || a.data is double[]) + { + return new Series(a.data.Cast().Select(x => x - b).ToArray() + , column: a._column + , index: a._index?.copy()); + } + throw new NotImplementedException(""); } - public static Series operator *(Series a, float b) + public static Series operator *(Series a, double b) { - if (a.data is float[] float32) - return new Series(float32.Select(x => x * b).ToArray()); - else if (a.data is double[] float64) - return new Series(float64.Select(x => x * b).ToArray()); + if (a.data is int[] || a.data is float[] || a.data is double[]) + { + return new Series(a.data.Cast().Select(x => x * b).ToArray() + , column: a._column + , index: a._index?.copy()); + } + throw new NotImplementedException(""); } - public static Series operator /(Series a, float b) + public static Series operator /(Series a, double b) { - if (a.data is float[] float32) - return new Series(float32.Select(x => x / b).ToArray()); - else if (a.data is double[] float64) - return new Series(float64.Select(x => x / b).ToArray()); + if (a.data is int[] || a.data is float[] || a.data is double[]) + { + return new Series(a.data.Cast().Select(x => x / b).ToArray() + , column: a._column + , index: a._index?.copy()); + } + throw new NotImplementedException(""); } } diff --git a/test/Pandas.NET.Test/DataFrames/DataFrame.test.operator.cs b/test/Pandas.NET.Test/DataFrames/DataFrame.test.operator.cs index 8c495c9..cc4ab86 100644 --- a/test/Pandas.NET.Test/DataFrames/DataFrame.test.operator.cs +++ b/test/Pandas.NET.Test/DataFrames/DataFrame.test.operator.cs @@ -14,62 +14,95 @@ public void TestSubtractionOperator() // Arrange List data = new List { - new Series(new int[] { 1, 2, 3, 4, 5 }, new Column { Name = "column1", DType = typeof(int) }), - new Series(new int[] { 2, 4, 6, 8, 10 }, new Column { Name = "column2", DType = typeof(int) }) + new Series(new double[] { 1, 2, 3, 4, 5 }, new Column { Name = "column1", DType = typeof(double) }), + new Series(new double[] { 2, 4, 6, 8, 10 }, new Column { Name = "column2", DType = typeof(double) }) }; var df = new DataFrame(data); - var series = new Series(new int[] { 1, 2 }, new Series(new string[]{"column1","column2"}), new Column("sub", typeof(int))); + var series = new Series(new double[] { 0.5, 1.5 }, new Series(new string[]{"column1","column2"}), new Column("sub", typeof(double))); // Act var result = df - series; // Assert - Assert.Equal(new int[] { 0, 1, 2, 3, 4 }, result["column1"].data as int[]); - Assert.Equal(new int[] { 0, 2, 4, 6, 8}, result["column2"].data as int[]); + Assert.Equal(new double[] { 0.5, 1.5, 2.5, 3.5, 4.5 }, result["column1"].data as double[]); + Assert.Equal(new double[] { 0.5, 2.5, 4.5, 6.5, 8.5}, result["column2"].data as double[]); } - [Fact] - public void TestSubtractionOperator_Float() + public void TestDivisionOperator() { - // Arrange List data = new List { - new Series(new float[] { 1, 2, 3, 4, 5 }, new Column { Name = "column1", DType = typeof(float) }), - new Series(new float[] { 2, 4, 6, 8, 10 }, new Column { Name = "column2", DType = typeof(float) }) + new Series(new double[] { 5, 10, 15, 20, 25 }, new Column { Name = "column1", DType = typeof(double) }), + new Series(new double[] { 2, 4, 6, 8, 10 }, new Column { Name = "column2", DType = typeof(double) }) }; var df = new DataFrame(data); - var series = new Series(new float[] { 0.5F, 1.5F }, new Series(new string[]{"column1","column2"}), new Column("sub", typeof(float))); + var series = new Series(new double[] { 5, 2 }); // Act - var result = df - series; + var result = df / series; // Assert - Assert.Equal(new float[] { 0.5F, 1.5F, 2.5F, 3.5F, 4.5F }, result["column1"].data as float[]); - Assert.Equal(new float[] { 0.5F, 2.5F, 4.5F, 6.5F, 8.5F}, result["column2"].data as float[]); + Assert.Equal(new double[] { 1, 2, 3, 4, 5 }, result["column1"].data as double[]); + Assert.Equal(new double[] { 1, 2, 3, 4, 5 }, result["column2"].data as double[]); } + [Fact] + public void TestMultiplicationOperator() + { + List data = new List + { + new Series(new double[] { 5, 10, 15, 20, 25 }, new Column { Name = "column1", DType = typeof(double) }), + new Series(new double[] { 2, 4, 6, 8, 10 }, new Column { Name = "column2", DType = typeof(double) }) + }; + var df = new DataFrame(data); + + var series = new Series(new double[] { 1, 10 }); + + // Act + var result = df * series; + + // Assert + Assert.Equal(new double[] { 5, 10, 15, 20, 25 }, result["column1"].data as double[]); + Assert.Equal(new double[] { 20, 40, 60, 80, 100 }, result["column2"].data as double[]); + } [Fact] - public void TestSubtractionOperator_Double() + public void TestEqualityOperator() { // Arrange List data = new List { - new Series(new double[] { 1, 2, 3, 4, 5 }, new Column { Name = "column1", DType = typeof(double) }), - new Series(new double[] { 2, 4, 6, 8, 10 }, new Column { Name = "column2", DType = typeof(double) }) + new Series(new float[] { 1, 2, 3, 4, 5 }, new Column { Name = "column1", DType = typeof(float) }), + new Series(new float[] { 6, 7, 8, 9, 10 }, new Column { Name = "column2", DType = typeof(float) }) }; var df = new DataFrame(data); + var df2 = new DataFrame(data); - var series = new Series(new double[] { 0.5, 1.5 }, new Series(new string[]{"column1","column2"}), new Column("sub", typeof(double))); + // Arrange: DataFrame with different column name + List badColumnData = new List + { + new Series(new float[] { 1, 2, 3, 4, 5 }, new Column { Name = "Column1", DType = typeof(float) }), + new Series(new float[] { 6, 7, 8, 9, 10 }, new Column { Name = "column2", DType = typeof(float) }) + }; + var badColumnDf = new DataFrame(badColumnData); + // Arrange: DataFrame with different data + List badData = new List + { + new Series(new float[] { 1, 2, 3, 4, 5 }, new Column { Name = "column1", DType = typeof(float) }), + new Series(new float[] { 6, 7, 8, 9, 11 }, new Column { Name = "column2", DType = typeof(float) }) + }; // Act - var result = df - series; + bool areEqual = df == df2; + bool badColumnInequal = df == badColumnDf; + bool badDataInequal = df == new DataFrame(badData); // Assert - Assert.Equal(new double[] { 0.5, 1.5, 2.5, 3.5, 4.5 }, result["column1"].data as double[]); - Assert.Equal(new double[] { 0.5, 2.5, 4.5, 6.5, 8.5}, result["column2"].data as double[]); + Assert.True(areEqual); + Assert.False(badColumnInequal); + Assert.False(badDataInequal); } } From 47539a647859de054016cababb295e671bb36cb8 Mon Sep 17 00:00:00 2001 From: Brett Webster Date: Sun, 21 Jul 2024 08:30:51 -0500 Subject: [PATCH 05/13] DataFrame operators - equality --- .../DataFrames/DataFrame.operator.cs | 13 +++++++ src/Pandas.NET/Series/Series.operator.cs | 26 +++++++++++++ .../DataFrames/DataFrame.test.operator.cs | 37 +++++++++++++++++++ 3 files changed, 76 insertions(+) diff --git a/src/Pandas.NET/DataFrames/DataFrame.operator.cs b/src/Pandas.NET/DataFrames/DataFrame.operator.cs index 58db786..d6bf53b 100644 --- a/src/Pandas.NET/DataFrames/DataFrame.operator.cs +++ b/src/Pandas.NET/DataFrames/DataFrame.operator.cs @@ -90,5 +90,18 @@ public partial class DataFrame { return !(a == b); } + + public override bool Equals(object obj) + { + return obj is DataFrame frame && + data == frame.data && + columns == frame.columns && + index == frame.index; + } + + public override int GetHashCode() + { + return HashCode.Combine(data, columns, index); + } } } diff --git a/src/Pandas.NET/Series/Series.operator.cs b/src/Pandas.NET/Series/Series.operator.cs index cfe12c2..9e56c4b 100644 --- a/src/Pandas.NET/Series/Series.operator.cs +++ b/src/Pandas.NET/Series/Series.operator.cs @@ -95,5 +95,31 @@ public partial class Series throw new NotImplementedException(""); } + + public override bool Equals(object obj) + { + if (obj is Series series) + { + if (series.data is double[] double64) + { + return data.Cast().SequenceEqual(double64); + } + else if (series.data is float[] float32) + { + return data.Cast().SequenceEqual(float32); + } + else if (series.data is int[] int32) + { + return data.Cast().SequenceEqual(int32); + } + } + + return false; + } + + public override int GetHashCode() + { + return base.GetHashCode(); + } } } diff --git a/test/Pandas.NET.Test/DataFrames/DataFrame.test.operator.cs b/test/Pandas.NET.Test/DataFrames/DataFrame.test.operator.cs index cc4ab86..04e309d 100644 --- a/test/Pandas.NET.Test/DataFrames/DataFrame.test.operator.cs +++ b/test/Pandas.NET.Test/DataFrames/DataFrame.test.operator.cs @@ -105,4 +105,41 @@ public void TestEqualityOperator() Assert.False(badColumnInequal); Assert.False(badDataInequal); } + + [Fact] + public void TestInEqualityOperator() + { + // Arrange + List data = new List + { + new Series(new float[] { 1, 2, 3, 4, 5 }, new Column { Name = "column1", DType = typeof(float) }), + new Series(new float[] { 6, 7, 8, 9, 10 }, new Column { Name = "column2", DType = typeof(float) }) + }; + var df = new DataFrame(data); + var df2 = new DataFrame(data); + + // Arrange: DataFrame with different column name + List badColumnData = new List + { + new Series(new float[] { 1, 2, 3, 4, 5 }, new Column { Name = "Column1", DType = typeof(float) }), + new Series(new float[] { 6, 7, 8, 9, 10 }, new Column { Name = "column2", DType = typeof(float) }) + }; + var badColumnDf = new DataFrame(badColumnData); + // Arrange: DataFrame with different data + List badData = new List + { + new Series(new float[] { 1, 2, 3, 4, 5 }, new Column { Name = "column1", DType = typeof(float) }), + new Series(new float[] { 6, 7, 8, 9, 11 }, new Column { Name = "column2", DType = typeof(float) }) + }; + + // Act + bool areEqual = df != df2; + bool badColumnInequal = df != badColumnDf; + bool badDataInequal = df != new DataFrame(badData); + + // Assert + Assert.False(areEqual); + Assert.True(badColumnInequal); + Assert.True(badDataInequal); + } } From a81e5059bd61af3776541bdccde75d738de03da8 Mon Sep 17 00:00:00 2001 From: Brett Webster Date: Sat, 27 Jul 2024 06:24:03 -0500 Subject: [PATCH 06/13] added pop test --- .../DataFrames/DataFrame.test.pop.cs | 26 +++++++++++++++++++ 1 file changed, 26 insertions(+) create mode 100644 test/Pandas.NET.Test/DataFrames/DataFrame.test.pop.cs diff --git a/test/Pandas.NET.Test/DataFrames/DataFrame.test.pop.cs b/test/Pandas.NET.Test/DataFrames/DataFrame.test.pop.cs new file mode 100644 index 0000000..3911159 --- /dev/null +++ b/test/Pandas.NET.Test/DataFrames/DataFrame.test.pop.cs @@ -0,0 +1,26 @@ +using System; +using System.Collections.Generic; +using System.Linq; +using PandasNet; +using Tensorflow; + +public class DataFrameTests +{ + [Fact] + public void TestPopMethod() + { + // Arrange + var dataFrameData = new List(); + dataFrameData.Add(new Series(new float[] { 1, 2, 3, 4, 5 }, new Column("column1", typeof(float)))); + dataFrameData.Add(new Series(new float[] { 6, 7, 8, 9, 10 }, new Column("column2", typeof(float)))); + var dataFrame = new DataFrame(dataFrameData); + + // Act + var poppedSeries = dataFrame.pop("column1"); + + // Assert + Assert.True(poppedSeries.array().SequenceEqual([1, 2, 3, 4, 5])); + Assert.False(dataFrame.columns.Where(c => c.Name == "column1").Any()); + Assert.True(dataFrame.columns.Where(c => c.Name == "column2").Any()); + } +} \ No newline at end of file From 3550ff8344a198e3bb77e1c3f3e82d5cca944353 Mon Sep 17 00:00:00 2001 From: Brett Webster Date: Sat, 27 Jul 2024 15:21:03 -0500 Subject: [PATCH 07/13] Sample test added. Added support for sample with replace. --- src/Pandas.NET/DataFrames/DataFrame.cs | 6 ++ src/Pandas.NET/DataFrames/DataFrame.sample.cs | 70 +++++++++++++++--- .../DataFrames/DataFrame.test.pop.cs | 4 +- .../DataFrames/DataFrame.test.sample.cs | 73 +++++++++++++++++++ 4 files changed, 141 insertions(+), 12 deletions(-) create mode 100644 test/Pandas.NET.Test/DataFrames/DataFrame.test.sample.cs diff --git a/src/Pandas.NET/DataFrames/DataFrame.cs b/src/Pandas.NET/DataFrames/DataFrame.cs index fbb2c07..b9a05ea 100644 --- a/src/Pandas.NET/DataFrames/DataFrame.cs +++ b/src/Pandas.NET/DataFrames/DataFrame.cs @@ -45,6 +45,12 @@ public DataFrame(List data, Series index = null, List columns = index.size, columns.Count }; + + foreach (var s in _data) + { + s.SetIndex(_index); + } + } } } diff --git a/src/Pandas.NET/DataFrames/DataFrame.sample.cs b/src/Pandas.NET/DataFrames/DataFrame.sample.cs index 11de784..377e13e 100644 --- a/src/Pandas.NET/DataFrames/DataFrame.sample.cs +++ b/src/Pandas.NET/DataFrames/DataFrame.sample.cs @@ -1,28 +1,76 @@ using System; +using System.Collections; using System.Collections.Generic; using System.Linq; +using System.Reflection.PortableExecutable; +using Tensorflow.Util; namespace PandasNet; public partial class DataFrame { - public DataFrame sample(float frac= 0.8f, int random_state = 0) + public DataFrame sample(int n = 0, float frac = 0, int random_state = 0, bool replace = false) { - var rnd = new Random(random_state); - var n = (int)Math.Ceiling((1 - frac) * _index.size); - var excludeRowIndexArray = new int[n]; - for (int i = 0; i < n; i++) + if (n == 0 && frac == 0) + { + throw new ArgumentException("Either n or frac should be greater than 0"); + } + if (n != 0 && frac != 0) + { + throw new ArgumentException("Only one of n or frac should be greater than 0"); + } + if (frac > 0) { - excludeRowIndexArray[i] = rnd.Next(0, _index.size - 1); + n = (int)Math.Ceiling(frac * _index.size); } + if (n > _index.size) + { + throw new ArgumentException("n should be less than the size of the DataFrame"); + } + + // treat axis as 0 for now. support for axis=1 should be added in the future + var rnd = new Random(random_state); - var data = new List(); + // make a list that we can sample from + List sampleIndex = null; + + if(!replace){ + // randomize the index and take the first n elements, no duplicates + sampleIndex = Enumerable + .Range(0, _index.size) + .OrderBy(arg => rnd.Next()) + .Take(n).ToList(); + } + else{ + // for each sample, randomly select an index allowing duplicates + var sampleIndexes = Enumerable.Range(0, _index.size); + for (int i = 0; i < n; i++) + { + sampleIndex.Add(sampleIndexes.ElementAt(rnd.Next(0, sampleIndexes.Count()-1))); + } + } + + // initialize a dictionary to hold the data + Dictionary data = new Dictionary(); foreach (var s in _data) { - var series = s.drop(excludeRowIndexArray); - data.Add(series); + // init the array based on the dtype + ArrayList array =new ArrayList(); + data.Add(s.column, array); + } + + // fill the arrays with the sampled data + for (int i = 0; i < sampleIndex.Count; i++) + { + foreach (var s in _data) + { + data[s.column].Add(s.data.GetValue(sampleIndex[i])); + } } - var index = _index.array().Where(x => !excludeRowIndexArray.Contains(x)).ToArray(); - return new DataFrame(data, columns: _columns, index: new Series(index)); + + // create a new DataFrame with the sampled data + DataFrame df = new DataFrame(data.Select(x => new Series(x.Value.ToArray(x.Key.DType), x.Key)).ToList(), index: new Series(sampleIndex.ToArray())); + return df; + } } diff --git a/test/Pandas.NET.Test/DataFrames/DataFrame.test.pop.cs b/test/Pandas.NET.Test/DataFrames/DataFrame.test.pop.cs index 3911159..34095fc 100644 --- a/test/Pandas.NET.Test/DataFrames/DataFrame.test.pop.cs +++ b/test/Pandas.NET.Test/DataFrames/DataFrame.test.pop.cs @@ -4,7 +4,9 @@ using PandasNet; using Tensorflow; -public class DataFrameTests +namespace Pandas.Test; + +public class DataFramePopTest { [Fact] public void TestPopMethod() diff --git a/test/Pandas.NET.Test/DataFrames/DataFrame.test.sample.cs b/test/Pandas.NET.Test/DataFrames/DataFrame.test.sample.cs new file mode 100644 index 0000000..c4de814 --- /dev/null +++ b/test/Pandas.NET.Test/DataFrames/DataFrame.test.sample.cs @@ -0,0 +1,73 @@ +using PandasNet; +using System; +using System.Collections.Generic; +using System.Linq; + +namespace Pandas.Test; +public class DataFrameSampleTests +{ + [Fact] + public void TestSampleMethod() + { + // Arrange + List data = new List + { + new Series(new double[] { 1, 2, 3, 4, 5 }, new Column { Name = "column1", DType = typeof(double) }), + new Series(new double[] {6, 7, 8, 9, 10 }, new Column { Name = "column2", DType = typeof(double) }) + }; + var dataFrame = new DataFrame(data); + + // Act + var sampledDataFrame = dataFrame.sample(n: 3, random_state: 1); + + // Assert + Assert.Equal(3, sampledDataFrame.index.size); + Assert.True(sampledDataFrame.columns.Where(x => x.Name == "column1").Any()); + Assert.True(sampledDataFrame.columns.Where(x => x.Name == "column2").Any()); + } + + [Fact] + public void TestSampleMethodWithFrac() + { + // Arrange + List data = new List + { + new Series(new double[] { 1, 2, 3, 4, 5 }, new Column { Name = "column1", DType = typeof(double) }), + new Series(new double[] {6, 7, 8, 9, 10 }, new Column { Name = "column2", DType = typeof(double) }) + }; + var dataFrame = new DataFrame(data); + + // Act + var sampledDataFrame = dataFrame.sample(frac: 0.4f, random_state: 1); + var sampledDataFrame2 = dataFrame.sample(frac: 0.4f, random_state: 2); + + // Assert + Assert.Equal(2, sampledDataFrame.index.size); // 40% of 5 is 2 + Assert.True(sampledDataFrame.columns.Where(x => x.Name == "column1").Any()); + Assert.True(sampledDataFrame.columns.Where(x => x.Name == "column2").Any()); + Assert.Equal(2.0D, sampledDataFrame["column1"].GetValue(0)); + Assert.Equal(7.0D, sampledDataFrame["column2"].GetValue(0)); + + // assert for other state + Assert.Equal(2, sampledDataFrame2.index.size); // 40% of 5 is 2 + Assert.Equal(5.0D, sampledDataFrame2["column1"].GetValue(0)); + Assert.Equal(10.0D, sampledDataFrame2["column2"].GetValue(0)); + } + + [Fact] + public void TestSampleMethodThrowsException() + { + // Arrange + List data = new List + { + new Series(new double[] { 1, 2, 3, 4, 5 }, new Column { Name = "column1", DType = typeof(double) }), + new Series(new double[] {6, 7, 8, 9, 10 }, new Column { Name = "column2", DType = typeof(double) }) + }; + var dataFrame = new DataFrame(data); + + // Act & Assert + Assert.Throws(() => dataFrame.sample()); + Assert.Throws(() => dataFrame.sample(n: 3, frac: 0.4f)); + Assert.Throws(() => dataFrame.sample(n: 6)); + } +} \ No newline at end of file From 2aca3ab207aa31095b0760fce2b48d4bbbcd1958 Mon Sep 17 00:00:00 2001 From: Brett Webster Date: Sat, 27 Jul 2024 15:57:05 -0500 Subject: [PATCH 08/13] Create ubuntu-dotnet.yml --- .github/workflows/ubuntu-dotnet.yml | 28 ++++++++++++++++++++++++++++ 1 file changed, 28 insertions(+) create mode 100644 .github/workflows/ubuntu-dotnet.yml diff --git a/.github/workflows/ubuntu-dotnet.yml b/.github/workflows/ubuntu-dotnet.yml new file mode 100644 index 0000000..c62b908 --- /dev/null +++ b/.github/workflows/ubuntu-dotnet.yml @@ -0,0 +1,28 @@ +# This workflow will build a .NET project +# For more information see: https://docs.github.com/en/actions/automating-builds-and-tests/building-and-testing-net + +name: .NET + +on: + push: + branches: [ "master" ] + pull_request: + branches: [ "master" ] + +jobs: + build: + + runs-on: ubuntu-latest + + steps: + - uses: actions/checkout@v4 + - name: Setup .NET + uses: actions/setup-dotnet@v4 + with: + dotnet-version: 8.0.x + - name: Restore dependencies + run: dotnet restore + - name: Build + run: dotnet build --no-restore + - name: Test + run: dotnet test --no-build --verbosity normal From 0b014a52531c1e5c25dcd3b6b337834f1d7c9015 Mon Sep 17 00:00:00 2001 From: Brett Webster Date: Sat, 27 Jul 2024 16:00:35 -0500 Subject: [PATCH 09/13] Update ubuntu-dotnet.yml --- .github/workflows/ubuntu-dotnet.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/ubuntu-dotnet.yml b/.github/workflows/ubuntu-dotnet.yml index c62b908..95eec33 100644 --- a/.github/workflows/ubuntu-dotnet.yml +++ b/.github/workflows/ubuntu-dotnet.yml @@ -1,7 +1,7 @@ # This workflow will build a .NET project # For more information see: https://docs.github.com/en/actions/automating-builds-and-tests/building-and-testing-net -name: .NET +name: Ubuntu Latest on: push: From 5bc0a7429bd9640b725b67395e829f87766bc197 Mon Sep 17 00:00:00 2001 From: Brett Webster Date: Sat, 27 Jul 2024 16:11:45 -0500 Subject: [PATCH 10/13] Remove reference to TensorFlow.NET --- src/Pandas.NET/Pandas.NET.csproj | 1 - test/Pandas.NET.Test/Pandas.NET.Test.csproj | 1 - 2 files changed, 2 deletions(-) diff --git a/src/Pandas.NET/Pandas.NET.csproj b/src/Pandas.NET/Pandas.NET.csproj index 3e9fa8e..eecef47 100644 --- a/src/Pandas.NET/Pandas.NET.csproj +++ b/src/Pandas.NET/Pandas.NET.csproj @@ -22,6 +22,5 @@ - \ No newline at end of file diff --git a/test/Pandas.NET.Test/Pandas.NET.Test.csproj b/test/Pandas.NET.Test/Pandas.NET.Test.csproj index e6a0115..e4a70ac 100644 --- a/test/Pandas.NET.Test/Pandas.NET.Test.csproj +++ b/test/Pandas.NET.Test/Pandas.NET.Test.csproj @@ -13,7 +13,6 @@ all - runtime; build; native; contentfiles; analyzers; buildtransitive From 5a4ab956f6d4f2c148fe409e3b9813198a8bd27e Mon Sep 17 00:00:00 2001 From: Brett Webster Date: Sat, 27 Jul 2024 16:26:09 -0500 Subject: [PATCH 11/13] Update PandasConsole.indexers.cs --- test/PandasConsole/DataFrames/PandasConsole.indexers.cs | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/test/PandasConsole/DataFrames/PandasConsole.indexers.cs b/test/PandasConsole/DataFrames/PandasConsole.indexers.cs index 59a558f..95114db 100644 --- a/test/PandasConsole/DataFrames/PandasConsole.indexers.cs +++ b/test/PandasConsole/DataFrames/PandasConsole.indexers.cs @@ -18,11 +18,11 @@ public DataFrame GetSampleDataFrame() return df; } - + // index on multiple columns public (DataFrame, DataFrame) MultiColumnIndexer() { var df = GetSampleDataFrame(); return (df, df["col_1","col_2"]); } } -} \ No newline at end of file +} From 1068652e426891a783081df7fba4b536be42087d Mon Sep 17 00:00:00 2001 From: Brett Webster Date: Sat, 27 Jul 2024 17:17:32 -0500 Subject: [PATCH 12/13] ubuntu, windows, and macos ci --- .github/workflows/macos-ci.yml | 34 +++++++++++++++++++ ...buntu-dotnet.yml => ubuntu-windows-ci.yml} | 14 +++++--- 2 files changed, 43 insertions(+), 5 deletions(-) create mode 100644 .github/workflows/macos-ci.yml rename .github/workflows/{ubuntu-dotnet.yml => ubuntu-windows-ci.yml} (71%) diff --git a/.github/workflows/macos-ci.yml b/.github/workflows/macos-ci.yml new file mode 100644 index 0000000..cc189f0 --- /dev/null +++ b/.github/workflows/macos-ci.yml @@ -0,0 +1,34 @@ +# This workflow will build a .NET project +# For more information see: https://docs.github.com/en/actions/automating-builds-and-tests/building-and-testing-net + +name: Build and Test +on: + push: + branches: [ "master" ] + pull_request: + branches: [ "master" ] + +jobs: + build_matrix: + strategy: + matrix: + os: + - ubuntu-latest + - windows-latest + + runs-on: ${{matrix.os}} + + steps: + - uses: actions/checkout@v4 + - name: Setup .NET + uses: actions/setup-dotnet@v4 + with: + dotnet-version: 8.0.x + - name: Restore dependencies + run: dotnet restore + - name: SciSharp Mac OS Dependencies + run: Install-Package SciSharp.TensorFlow.Redist-OSX + - name: Build + run: dotnet build --no-restore + - name: Test + run: dotnet test --no-build --verbosity normal \ No newline at end of file diff --git a/.github/workflows/ubuntu-dotnet.yml b/.github/workflows/ubuntu-windows-ci.yml similarity index 71% rename from .github/workflows/ubuntu-dotnet.yml rename to .github/workflows/ubuntu-windows-ci.yml index 95eec33..5596945 100644 --- a/.github/workflows/ubuntu-dotnet.yml +++ b/.github/workflows/ubuntu-windows-ci.yml @@ -1,8 +1,7 @@ # This workflow will build a .NET project # For more information see: https://docs.github.com/en/actions/automating-builds-and-tests/building-and-testing-net -name: Ubuntu Latest - +name: Build and Test on: push: branches: [ "master" ] @@ -10,9 +9,14 @@ on: branches: [ "master" ] jobs: - build: + build_matrix: + strategy: + matrix: + os: + - ubuntu-latest + - windows-latest - runs-on: ubuntu-latest + runs-on: ${{matrix.os}} steps: - uses: actions/checkout@v4 @@ -25,4 +29,4 @@ jobs: - name: Build run: dotnet build --no-restore - name: Test - run: dotnet test --no-build --verbosity normal + run: dotnet test --no-build --verbosity normal \ No newline at end of file From 1bb1df4e9317bd88c18aa93d5f49f62b2e34ac60 Mon Sep 17 00:00:00 2001 From: Brett Webster Date: Sat, 27 Jul 2024 17:18:52 -0500 Subject: [PATCH 13/13] fixing macos file 1 --- .github/workflows/macos-ci.yml | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/.github/workflows/macos-ci.yml b/.github/workflows/macos-ci.yml index cc189f0..4d7115b 100644 --- a/.github/workflows/macos-ci.yml +++ b/.github/workflows/macos-ci.yml @@ -13,8 +13,7 @@ jobs: strategy: matrix: os: - - ubuntu-latest - - windows-latest + - macos-latest runs-on: ${{matrix.os}}