- Scilab Help
- Compatibility Functions
- firstnonsingleton
- mstr2sci
- mtlb_0
- mtlb_a
- mtlb_all
- mtlb_any
- mtlb_axis
- mtlb_beta
- mtlb_box
- mtlb_close
- mtlb_colordef
- mtlb_cumprod
- mtlb_cumsum
- mtlb_dec2hex
- mtlb_delete
- mtlb_diag
- mtlb_diff
- mtlb_dir
- mtlb_double
- mtlb_e
- mtlb_echo
- mtlb_eval
- mtlb_exist
- mtlb_eye
- mtlb_false
- mtlb_fft
- mtlb_fftshift
- mtlb_find
- mtlb_findstr
- mtlb_fliplr
- mtlb_fopen
- mtlb_format
- mtlb_fprintf
- mtlb_fread
- mtlb_fscanf
- mtlb_full
- mtlb_fwrite
- mtlb_grid
- mtlb_hold
- mtlb_i
- mtlb_ifft
- mtlb_imp
- mtlb_int16
- mtlb_int32
- mtlb_int64
- mtlb_int8
- mtlb_is
- mtlb_isa
- mtlb_isfield
- mtlb_isletter
- mtlb_isspace
- mtlb_l
- mtlb_legendre
- mtlb_linspace
- mtlb_logic
- mtlb_logical
- mtlb_lower
- mtlb_max
- mtlb_min
- mtlb_more
- mtlb_num2str
- mtlb_ones
- mtlb_plot
- mtlb_prod
- mtlb_rand
- mtlb_randn
- mtlb_realmax
- mtlb_realmin
- mtlb_s
- mtlb_setstr
- mtlb_size
- mtlb_sort
- mtlb_strcmp
- mtlb_strcmpi
- mtlb_strfind
- mtlb_strrep
- mtlb_sum
- mtlb_t
- mtlb_toeplitz
- mtlb_tril
- mtlb_triu
- mtlb_true
- mtlb_uint16
- mtlb_uint32
- mtlb_uint64
- mtlb_uint8
- mtlb_upper
- mtlb_var
- mtlb_zeros

# mtlb_sum

Matlab sum emulation function

### Description

Matlab and Scilab `sum`

behave differently in some particular cases:

When called with one input: Matlab

`sum`

treats the values along the first non-singleton dimension of input while Scilab`sum`

threats all values of input.When called with two inputs: Matlab

`sum`

can be used with second input giving a non-existing dimension of first input while Scilab`sum`

returns an error message.

The function `mtlb_sum(A[,dim])`

is used by
`mfile2sci`

to replace `sum(A[,dim])`

when it was not
possible to know what were the inputs while porting Matlab code to Scilab. This function will
determine the correct semantic at run time. If you want to have a
more efficient code it is possible to replace `mtlb_sum`

calls:

When called with one input, if

`A`

is an empty matrix, a scalar or a vector,`mtlb_sum(A)`

may be replaced by`sum(A)`

When called with one input, if

`A`

is a not-empty matrix,`mtlb_sum(A)`

may be replaced by`sum(A,1)`

When called with one input, if

`A`

is a multidimensional array,`mtlb_sum(A)`

may be replaced by`sum(A,firstnonsingleton(A))`

When called with two inputs, if

`dim`

is lesser than the number of dimensions of`A`

`mtlb_sum(A,dim)`

may be replaced by`sum(A,dim)`

Caution: `mtlb_sum` has not to be used for hand coded functions. |

### See also

- firstnonsingleton — Finds first dimension which is not 1

## Comments

Add a comment:Please login to comment this page.