Coder Social home page Coder Social logo

Comments (2)

rvagg avatar rvagg commented on July 19, 2024

Unfortunately I don't have a good answer for you here ; it could be a GC problem with the large loop, perhaps if it was broken up across event loop turns you might have different results, unfortunately that's not a great answer because it would significantly complicate your code.

I'll leave this issue open in the hope that someone else can answer it--I'm more of a maintainer rather than an expert user unfortunately!

from node-bignum.

ZiCog avatar ZiCog commented on July 19, 2024

I tried your suggestion and iterated the loop via a setInterval(), also tried a 1ms setTimeout().

This reduces my CPU load down a few percent and I guess it would take a little over an hour to complete.

Sadly it still ramps up to 30% of my 3GB RAM here after a few minutes.

Here is the code:
var bigNumber = require("bignum");

function fibo_iterative(n, callback) {
    var first = bigNumber(0),
        second = bigNumber(1),
        next = bigNumber(0),
        loop,
        c;
    if (n <= 1) {
         callback (bigNumber(n));
    } else {
        c = 0;
        (function loop () {
            if (c < n - 1) {
                next = first.add(second);
                first = second;
                second = next;
                c += 1;
                //setImmediate(loop);
                setTimeout(loop, 1);
            } else {
                callback (next);
            }
        }());
    }
}
var n = 4784969;  // The first fibo number with one million digits!
fibo_iterative(n, function (r) {
    var rs = r.toString();
    console.log("The " + rs.length + " digits of fibo(" + n + ") are:");
    console.log(rs);
    console.log("Done.");
});

from node-bignum.

Related Issues (20)

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.