Free cookie consent management tool by TermsFeed Policy Generator

source: branches/PushGP/HeuristicLab.PushGP/FeatureTests/DirtyList/PushStack.cs @ 14834

Last change on this file since 14834 was 14777, checked in by pkimmesw, 8 years ago

#2665 simplifier, push solution results view, performance improvements, small bug fixes, ui fixes

File size: 6.3 KB
Line 
1namespace TestPooling.DirtyList {
2  using System;
3  using System.Collections.Generic;
4  using System.Linq;
5
6  /// <summary>
7  ///     While Push's stacks are generally treated as genuine stacks---that is, inclassions take their arguments from the
8  ///     tops of
9  ///     the stacks and push their results onto the tops of the stacks---a few inclassions (like YANK and SHOVE) do allow
10  ///     direct access
11  ///     to "deep" stack elements by means of integer indices. To this extent the stacks can be used as general, random
12  ///     access memory
13  ///     classures. This is one of the features that ensures the Turing-completeness of Push (another being the arbitrary
14  ///     name/value
15  ///     bindings supported by the NAME data type and DEFINE methods; see below).
16  /// </summary>
17  /// <typeparam name="T">The item type of the collection.</typeparam>
18  public class PushStack<T> {
19    private const string Delimiter = " ";
20
21    private readonly List<T> data;
22
23    public PushStack(int capacity = 0) {
24      this.data = new List<T>(capacity);
25      this.IsEnabled = true;
26    }
27
28    public bool IsEnabled { get; set; }
29
30    public int Capacity
31    {
32      get
33      {
34        return this.data.Capacity;
35      }
36    }
37
38    public T Top
39    {
40      get
41      {
42        return this.data[this.Count - 1];
43      }
44    }
45
46    public T TopOrDefault
47    {
48      get
49      {
50        return this.Count > 0 ? this.data[this.Count - 1] : default(T);
51      }
52    }
53
54    public T Bottom
55    {
56      get
57      {
58        return this.data[0];
59      }
60    }
61
62    public T BottomOrDefault
63    {
64      get
65      {
66        return this.Count > 0 ? this.data[0] : default(T);
67      }
68    }
69
70    public int Count
71    {
72      get
73      {
74        return this.data.Count;
75      }
76    }
77
78    public bool IsEmpty
79    {
80      get
81      {
82        return this.Count == 0;
83      }
84    }
85
86    public bool IsReadOnly
87    {
88      get
89      {
90        return false;
91      }
92    }
93
94    public void Add(T item) {
95      this.Push(item);
96    }
97
98    public void Clear() {
99      this.data.Clear();
100    }
101
102    public bool Contains(T item) {
103      return this.data.Contains(item);
104    }
105
106    public void CopyTo(T[] array, int arrayIndex) {
107      this.data.CopyTo(array, arrayIndex);
108    }
109
110    public IEnumerator<T> GetEnumerator() {
111      return this.data.GetEnumerator();
112    }
113
114    public T ElementAt(int index) {
115      return this.data[index];
116    }
117
118    public T ReverseElementAt(int offset) {
119      return this.data[this.data.Count - 1 - offset];
120    }
121
122    public void SetTop(T value) {
123      this.data[this.Count - 1] = value;
124    }
125
126    public T this[int key]
127    {
128      get
129      {
130        return this.data[key];
131      }
132      set
133      {
134        this.data[key] = value;
135      }
136    }
137
138    public void Swap(int count) {
139      var top = this.Top;
140      var bottomIndex = this.Count - count;
141
142      for (var i = this.Count - 1; i > bottomIndex; i--) this.data[i] = this.data[i - 1];
143
144      this.data[bottomIndex] = top;
145    }
146
147    public void Yank(int index) {
148      if (index == this.Count - 1) return;
149
150      var item = this.ElementAt(index);
151      this.data.RemoveAt(index);
152      this.data.Add(item);
153    }
154
155    public T Pop() {
156      var value = this.data[this.Count - 1];
157      this.data.RemoveAt(this.Count - 1);
158
159      return value;
160    }
161
162    public T[] Pop(int count) {
163      var items = this.Peek(count);
164      this.Remove(count);
165
166      return items;
167    }
168
169    public T Peek() {
170      return this.Top;
171    }
172
173    public T[] Peek(int count) {
174      var startIndex = this.Count - count;
175
176      var items = new T[count];
177      this.data.CopyTo(startIndex, items, 0, count);
178
179      return items;
180    }
181
182    public void Push(T item) {
183      if (!this.IsEnabled) return;
184
185      this.data.Add(item);
186    }
187
188    public void Push(T item1, T item2) {
189      if (!this.IsEnabled) return;
190
191      this.data.Add(item1);
192      this.data.Add(item2);
193    }
194
195    public void Push(T item1, T item2, T item3) {
196      if (!this.IsEnabled) return;
197
198      this.data.Add(item1);
199      this.data.Add(item2);
200      this.data.Add(item3);
201    }
202
203    public void Push(T item1, T item2, T item3, T item4) {
204      if (!this.IsEnabled) return;
205
206      this.data.Add(item1);
207      this.data.Add(item2);
208      this.data.Add(item3);
209      this.data.Add(item4);
210    }
211
212    public void PushResult(int count, Func<T[], T> templateFunc) {
213      if (!this.IsEnabled) return;
214
215      var startIndex = this.Count - count;
216      var items = new T[count];
217
218      this.data.CopyTo(startIndex, items, 0, count);
219      this.Remove(count - 1);
220
221      this.data[this.Count - 1] = templateFunc(items);
222    }
223
224    public void Push(IReadOnlyList<T> items) {
225      if (!this.IsEnabled) return;
226
227      for (var i = 0; i < items.Count; i++) this.data.Add(items[i]);
228    }
229
230    public void Insert(int index, T item) {
231      if (!this.IsEnabled) return;
232
233      this.data.Insert(index, item);
234    }
235
236    public void Insert(int index, params T[] items) {
237      if (!this.IsEnabled) return;
238
239      this.data.InsertRange(index, items);
240    }
241
242    public void Insert(int index, IEnumerable<T> items) {
243      if (!this.IsEnabled) return;
244
245      this.data.InsertRange(index, items);
246    }
247
248    public bool Remove(T item) {
249      var index = this.Count - 1;
250      if ((this.Count > 0) && this.data[index].Equals(item)) {
251        this.data.RemoveAt(index);
252        return true;
253      }
254      return false;
255    }
256
257    public void RemoveTop() {
258      this.data.RemoveAt(this.Count - 1);
259    }
260
261    public void Remove(int count) {
262      for (var i = 0; i < count; i++) this.data.RemoveAt(this.Count - 1);
263    }
264
265    public void RemoveAt(int index) {
266      this.data.RemoveAt(index);
267    }
268
269    public void RemoveAt(int index, int count) {
270      this.data.RemoveRange(index, count);
271    }
272
273    public bool TryPop(out T item) {
274      if (this.Count > 0) {
275        item = this.Pop();
276        return true;
277      }
278      item = default(T);
279      return false;
280    }
281
282    public override string ToString() {
283      var data = this.data as IEnumerable<T>;
284      return string.Join(Delimiter, data.Reverse());
285    }
286  }
287}
Note: See TracBrowser for help on using the repository browser.