Gra*_*ton 21
使用此公式
y=mx+c
Run Code Online (Sandbox Code Playgroud)
在哪里m = (255-0)/(244-13)和c= -13*m
所以你必须只是转换数组
public double[] GetScaling(double[] arr, double min, double max)
{
double m = (max-min)/(arr.Max()-arr.Min());
double c = min-arr.Min()*m;
var newarr=new double[arr.Length];
for(int i=0; i< newarr.Length; i++)
newarr[i]=m*arr[i]+c;
return newarr;
}
Run Code Online (Sandbox Code Playgroud)
缩放范围内的值(minScale,maxScale)
private double Scale(int value , int min, int max, int minScale, int maxScale)
{
double scaled = minScale + (double)(value - min)/(max-min) * (maxScale - minScale);
return scaled;
}
Run Code Online (Sandbox Code Playgroud)
从传入的数组中查找最小值和最大值
var min = Array.Min();
var max = Array.Max();
Run Code Online (Sandbox Code Playgroud)
IEnumerable<T>如果您使用 .NET 3.5,则 LINQ 可以轻松地从任何对象(数组)获取最小值和最大值。
int[] values = new int[] { 0, 1, 2, ... 255 };
int minValue = values.Min();
int maxValue = values.Max();
Run Code Online (Sandbox Code Playgroud)
如果您正在寻找可以扩展整个阵列的东西......
public static int[] Scale(int[] values, int scaledMin, int scaledMax)
{
int minValue = values.Min();
int maxValue = values.Max();
float scale = (float)(scaledMax - scaledMin) / (float)(maxValue - minValue);
float offset = minValue * scale - scaledMin;
int[] output = new int[values.Length];
for (int i = 0; i < values.Length; i++)
{
output[i] = (int)Math.Round(values[i] * scale - offset, 0);
}
return output;
}
Run Code Online (Sandbox Code Playgroud)