По умолчанию моя 64-разрядная версия Windows 10 включала только версию Powershell версии 1.0.
Убедитесь, что включен движок Windows Powershell 2.0.
Перезапустите VS2015 в режиме без администратора и отключите его. при этом все пакеты установлены правильно.
Разделите, чтобы получить соотношение между размерами двух диапазонов, затем вычтите начальное значение вашего внутреннего диапазона, умножьте на коэффициент и добавьте начальное значение вашего второго диапазона. Другими словами,
R = (20 - 10) / (6 - 2)
y = (x - 2) * R + 10
Это равномерно распределяет числа из первого диапазона во втором диапазоне.
Каждый единичный интервал в первом диапазоне занимает (dc) / (ba) «пробел» во втором диапазоне.
Псевдо:
var interval = (d-c)/(b-a)
for n = 0 to (b - a)
print c + n*interval
Как вы обрабатываете округление зависит от вас.
В дополнение к ответу @PeterAllenWebb, если вы хотите отменить результат, используйте следующее:
reverseX = (B-A)*(Y-C)/(D-C) + A
В стороне, это та же проблема, что и классический конвертировать celcius в farenheit, где вы хотите сопоставить диапазон чисел, который равен 0 - 100 (C) - 32 - 212 (F).
Если ваше число X падает между A и B, и вы хотите, чтобы Y упал между C и D, вы можете применить следующее линейное преобразование:
Y = (XA) / (BA) * (DC) + C
Это должно дать вам то, что вы хотите, хотя ваш вопрос немного неоднозначен, поскольку вы также можете отобразить интервал в обратном направлении. Просто следите за делением на ноль, и вы должны быть в порядке.
int srcMin = 2, srcMax = 6;
int tgtMin = 10, tgtMax = 20;
int nb = srcMax - srcMin;
int range = tgtMax - tgtMin;
float rate = (float) range / (float) nb;
println(srcMin + " > " + tgtMin);
float stepF = tgtMin;
for (int i = 1; i < nb; i++)
{
stepF += rate;
println((srcMin + i) + " > " + (int) (stepF + 0.5) + " (" + stepF + ")");
}
println(srcMax + " > " + tgtMax);
Конечно, с проверкой деления на ноль.
Было бы неплохо иметь эту функциональность в классе java.lang.Math
, так как это такая широко требуемая функция и доступна на других языках. Вот простая реализация:
final static double EPSILON = 1e-12;
public static double map(double valueCoord1,
double startCoord1, double endCoord1,
double startCoord2, double endCoord2) {
if (Math.abs(endCoord1 - startCoord1) < EPSILON) {
throw new ArithmeticException("/ 0");
}
double offset = startCoord2;
double ratio = (endCoord2 - startCoord2) / (endCoord1 - startCoord1);
return ratio * (valueCoord1 - startCoord1) + offset;
}
Я помещаю этот код здесь как ссылку на будущее и, возможно, это кому-то поможет.