view general/numerical/safe_exp2.m @ 16:db7f4afd27c5

Rearranging numerical toolbox.
author samer
date Thu, 17 Jan 2013 13:20:44 +0000
parents e44f49929e56
children
line wrap: on
line source
function [y,k]=safe_exp2(x,l)
% safe_exp2 - high dynamic range exponential
%
% safe_exp2 :: X:[[N,M]], L:real -> [[N,M]], [[1,M]].
%
% returns y and k such that exp(X) = y * exp(k) and
% maximum value in y is exp(L).
% Maximum sensible value of L is log(realmax)=709.78.

k=max(x,[],1)-l; 
y=exp(x-repmat(k,size(x,1),1));