Приемы, используемые для минимизации вычислений


Одним из критериев, характеризующим качество составленной программы, является объем выполняемых ею вычислений для достижения требуемого результата. Чем он меньше, тем, как правило, быстрее будет работать программа. Существуют разные приемы, применение которых позволяет сократить объем вычислений за счет уменьшения в первую очередь количества вызовов функций, затем – количества операций типа умножения, и, наконец, – количества операций типа сложения. Вот некоторые из них, рассмотренные отдельно, хотя, как правило, они используются в сочетании.

Вынесение общих множителей за скобки. Например, вместо оператора

Z:=Sin(X)*Y-Sin(X)*Sqr(Y)*Y+Sqr(X)*X+X;

лучше использовать оператор

Z:=Sin(X)*Y*(1-Sqr(Y))+X*(Sqr(X)+1);

Использование схемы Горнера для полиномов. Например, полином

преобразованный по схеме Горнера, примет вид

((((2X-5)X+2)X+7)X-4)X+6

где явно меньше число операций умножения, если считать, что возведение в степень выполняется через умножение. В программе по второму варианту записи полинома будем иметь выражение

((((2*X-5)*X+2)*X+7)*X-4)*X+6,

а по первому –

2*IntPower(X,5)-5*IntPower(X,4)+2*IntPower(X,3)+7*IntPower(X,2)-4* X+6

где помимо такого же числа операций умножения требуется выполнить четыре обращения к функции возведения в степень.

Другой пример, где также применима схема Горнера:

1+2!+3!+4!+5! = 1+2(1+3(1+4(1+5)))

Использование дополнительных переменных. Например, при вычислении значения функции целесообразно предварительно вычислить и , а исходную формулу преобразовать к виду . В этом случае в программе будут использованы три оператора присваивания:

A:=X-Y;

B:=Sqr(A);

Z:=A*(1+A*B)/(1+B);



Дата добавления: 2020-07-18; просмотров: 187;


Поиск по сайту:

Воспользовавшись поиском можно найти нужную информацию на сайте.

Поделитесь с друзьями:

Считаете данную информацию полезной, тогда расскажите друзьям в соц. сетях.
Poznayka.org - Познайка.Орг - 2016-2024 год. Материал предоставляется для ознакомительных и учебных целей.
Генерация страницы за: 0.007 сек.