Skip to content

Instantly share code, notes, and snippets.

@ehmo
Created August 11, 2016 01:19
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save ehmo/9db79b6a4ec72bc18bd238393bf20e5d to your computer and use it in GitHub Desktop.
Save ehmo/9db79b6a4ec72bc18bd238393bf20e5d to your computer and use it in GitHub Desktop.
Fast fibonacci function in pure SQL
# Fast fibonacci function in pure SQL
# Tested on Postgresql 9.5
CREATE OR REPLACE FUNCTION _fib (
n integer, a bigint, b bigint
) RETURNS bigint AS $$
BEGIN
IF n < 1 THEN
RETURN b;
END IF;
RETURN _fib(n -1, b, a+b);
END;
$$ LANGUAGE plpgsql;
CREATE OR REPLACE FUNCTION fibonacci (
n integer
) RETURNS bigint AS $$
BEGIN
IF n > 91 THEN
RAISE EXCEPTION 'Bigint overflow past fibonacci(91) [%]', n;
END IF;
RETURN _fib(n, 0, 1);
END;
$$ LANGUAGE plpgsql;
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment