time-to-botec

Benchmark sampling in different programming languages
Log | Files | Refs | README

rational_p12q12.js (2848B)


      1 /**
      2 * @license Apache-2.0
      3 *
      4 * Copyright (c) 2018 The Stdlib Authors.
      5 *
      6 * Licensed under the Apache License, Version 2.0 (the "License");
      7 * you may not use this file except in compliance with the License.
      8 * You may obtain a copy of the License at
      9 *
     10 *    http://www.apache.org/licenses/LICENSE-2.0
     11 *
     12 * Unless required by applicable law or agreed to in writing, software
     13 * distributed under the License is distributed on an "AS IS" BASIS,
     14 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
     15 * See the License for the specific language governing permissions and
     16 * limitations under the License.
     17 */
     18 
     19 /* This is a generated file. Do not edit directly. */
     20 'use strict';
     21 
     22 // MAIN //
     23 
     24 /**
     25 * Evaluates a rational function, i.e., the ratio of two polynomials described by the coefficients stored in \\(P\\) and \\(Q\\).
     26 *
     27 * ## Notes
     28 *
     29 * -   Coefficients should be sorted in ascending degree.
     30 * -   The implementation uses [Horner's rule][horners-method] for efficient computation.
     31 *
     32 * [horners-method]: https://en.wikipedia.org/wiki/Horner%27s_method
     33 *
     34 *
     35 * @private
     36 * @param {number} x - value at which to evaluate the rational function
     37 * @returns {number} evaluated rational function
     38 */
     39 function evalrational( x ) {
     40 	var ax;
     41 	var s1;
     42 	var s2;
     43 	if ( x === 0.0 ) {
     44 		return -0.9999999999999991;
     45 	}
     46 	if ( x < 0.0 ) {
     47 		ax = -x;
     48 	} else {
     49 		ax = x;
     50 	}
     51 	if ( ax <= 1.0 ) {
     52 		s1 = -0.9999999999999991 + (x * (-4.712373111208652 + (x * (-7.94125711970499 + (x * (-5.746577466976647 + (x * (-0.4042133494563989 + (x * (2.4787778117864288 + (x * (2.0771415170245513 + (x * (0.8588778991623601 + (x * (0.20499222604410033 + (x * (0.027210314034819473 + (x * 0.001576484902087695))))))))))))))))))); // eslint-disable-line max-len
     53 		s2 = 1.0 + (x * (4.712373111208634 + (x * (9.586191186553398 + (x * (11.094006726982938 + (x * (8.090754247493278 + (x * (3.877058901598914 + (x * (1.2275867870191448 + (x * (0.249092040606385 + (x * (0.02957504139006556 + (x * (0.0015764849020049815 + (x * 1.6126405034405948e-15))))))))))))))))))); // eslint-disable-line max-len
     54 	} else {
     55 		x = 1.0 / x;
     56 		s1 = 0.001576484902087695 + (x * (0.027210314034819473 + (x * (0.20499222604410033 + (x * (0.8588778991623601 + (x * (2.0771415170245513 + (x * (2.4787778117864288 + (x * (-0.4042133494563989 + (x * (-5.746577466976647 + (x * (-7.94125711970499 + (x * (-4.712373111208652 + (x * -0.9999999999999991))))))))))))))))))); // eslint-disable-line max-len
     57 		s2 = 1.6126405034405948e-15 + (x * (0.0015764849020049815 + (x * (0.02957504139006556 + (x * (0.249092040606385 + (x * (1.2275867870191448 + (x * (3.877058901598914 + (x * (8.090754247493278 + (x * (11.094006726982938 + (x * (9.586191186553398 + (x * (4.712373111208634 + (x * 1.0))))))))))))))))))); // eslint-disable-line max-len
     58 	}
     59 	return s1 / s2;
     60 }
     61 
     62 
     63 // EXPORTS //
     64 
     65 module.exports = evalrational;