forked from RevenantX/LiteNetLib
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathSerializerBenchmark.cs
More file actions
174 lines (155 loc) · 6.05 KB
/
SerializerBenchmark.cs
File metadata and controls
174 lines (155 loc) · 6.05 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
using LiteNetLib.Utils;
using System;
using System.Diagnostics;
using System.IO;
using System.Runtime.Serialization.Formatters.Binary;
using System.Text;
namespace LibSample
{
class SerializerBenchmark
{
[Serializable] //Just for test binary formatter
private struct SampleNetSerializable : INetSerializable
{
public int Value;
public void Serialize(NetDataWriter writer)
{
writer.Put(Value);
}
public void Deserialize(NetDataReader reader)
{
Value = reader.GetInt();
}
}
[Serializable] //Just for test binary formatter
private class SamplePacket
{
public string SomeString { get; set; }
public float SomeFloat { get; set; }
public int[] SomeIntArray { get; set; }
public SomeVector2 SomeVector2 { get; set; }
public SomeVector2[] SomeVectors { get; set; }
public string EmptyString { get; set; }
public SampleNetSerializable TestObj { get; set; }
public override string ToString()
{
StringBuilder sb = new StringBuilder();
sb.AppendLine("SomeString: " + SomeString);
sb.AppendLine("SomeFloat: " + SomeFloat);
sb.AppendLine("SomeIntArray: ");
for (int i = 0; i < SomeIntArray.Length; i++)
{
sb.AppendLine(" " + SomeIntArray[i]);
}
sb.AppendLine("SomeVector2 X: " + SomeVector2);
sb.AppendLine("SomeVectors: ");
for (int i = 0; i < SomeVectors.Length; i++)
{
sb.AppendLine(" " + SomeVectors[i]);
}
sb.AppendLine("EmptyString: " + EmptyString);
sb.AppendLine("TestObj value: " + TestObj.Value);
return sb.ToString();
}
}
[Serializable] //Just for test binary formatter
private struct SomeVector2
{
public int X;
public int Y;
public SomeVector2(int x, int y)
{
X = x;
Y = y;
}
public override string ToString()
{
return "X: " + X + ", Y: " + Y;
}
public static void Serialize(NetDataWriter writer, SomeVector2 vector)
{
writer.Put(vector.X);
writer.Put(vector.Y);
}
public static SomeVector2 Deserialize(NetDataReader reader)
{
SomeVector2 res = new SomeVector2();
res.X = reader.GetInt();
res.Y = reader.GetInt();
return res;
}
}
public void Run()
{
Console.WriteLine("=== Serializer benchmark ===");
const int LoopLength = 100000;
//Test serializer performance
Stopwatch stopwatch = new Stopwatch();
BinaryFormatter binaryFormatter = new BinaryFormatter();
MemoryStream memoryStream = new MemoryStream();
NetDataWriter netDataWriter = new NetDataWriter();
SamplePacket samplePacket = new SamplePacket
{
SomeFloat = 0.3f,
SomeString = "TEST",
SomeIntArray = new [] { 1, 2, 3 },
SomeVector2 = new SomeVector2(1, 2),
SomeVectors = new [] { new SomeVector2(3,4), new SomeVector2(5,6) }
};
NetSerializer netSerializer = new NetSerializer();
netSerializer.RegisterNestedType<SampleNetSerializable>();
netSerializer.RegisterNestedType( SomeVector2.Serialize, SomeVector2.Deserialize );
//Prewarm cpu
for (int i = 0; i < 10000000; i++)
{
double c = Math.Sin(i);
}
//Test binary formatter
stopwatch.Start();
for (int i = 0; i < LoopLength; i++)
{
binaryFormatter.Serialize(memoryStream, samplePacket);
}
stopwatch.Stop();
Console.WriteLine("BinaryFormatter time: " + stopwatch.ElapsedMilliseconds + " ms");
//Test NetSerializer
stopwatch.Restart();
for (int i = 0; i < LoopLength; i++)
{
netSerializer.Serialize(netDataWriter, samplePacket);
}
stopwatch.Stop();
Console.WriteLine("NetSerializer first run time: " + stopwatch.ElapsedMilliseconds + " ms");
//Test NetSerializer
netDataWriter.Reset();
stopwatch.Restart();
for (int i = 0; i < LoopLength; i++)
{
netSerializer.Serialize(netDataWriter, samplePacket);
}
stopwatch.Stop();
Console.WriteLine("NetSerializer second run time: " + stopwatch.ElapsedMilliseconds + " ms");
//Test RAW
netDataWriter.Reset();
stopwatch.Restart();
for (int i = 0; i < LoopLength; i++)
{
netDataWriter.Put(samplePacket.SomeFloat);
netDataWriter.Put(samplePacket.SomeString);
netDataWriter.PutArray(samplePacket.SomeIntArray);
netDataWriter.Put(samplePacket.SomeVector2.X);
netDataWriter.Put(samplePacket.SomeVector2.Y);
netDataWriter.Put(samplePacket.SomeVectors.Length);
for (int j = 0; j < samplePacket.SomeVectors.Length; j++)
{
netDataWriter.Put(samplePacket.SomeVectors[j].X);
netDataWriter.Put(samplePacket.SomeVectors[j].Y);
}
netDataWriter.Put(samplePacket.EmptyString);
netDataWriter.Put(samplePacket.TestObj.Value);
}
stopwatch.Stop();
Console.WriteLine("DataWriter (raw put method calls) time: " + stopwatch.ElapsedMilliseconds + " ms");
}
}
}