blob: d5764eee5fa1825570ac123e38e1393a69506019 (
plain)
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
|
// Licensed to the .NET Foundation under one or more agreements.
// The .NET Foundation licenses this file to you under the MIT license.
// See the LICENSE file in the project root for more information.
//
using System;
using System.Runtime.CompilerServices;
public class BringUpTest
{
const int Pass = 100;
const int Fail = -1;
[MethodImplAttribute(MethodImplOptions.NoInlining)]
public static float FPArray(float []x)
{
float sum = 0;
for (int i=0; i < x.Length; ++i)
sum += x[i];
return sum / x.Length;
}
[MethodImplAttribute(MethodImplOptions.NoInlining)]
public static int FPFillArray(float []x, int start, int end, float y)
{
for (int i=start; i< end; ++i)
x[i] = y++;
return end-start;
}
public static int Main()
{
float []arr = new float[5];
if (FPFillArray(arr, 0, arr.Length, 1f) != arr.Length) return Fail;
float y = FPArray(arr);
Console.WriteLine(y);
if (System.Math.Abs(y-3f) <= Single.Epsilon) return Pass;
else return Fail;
}
}
|