Return an identity matrix. If invoked with a single scalar argument n, return a square NxN identity matrix. If supplied two scalar arguments (m, n),
eyetakes them to be the number of rows and columns. If given a vector with two elements,eyeuses the values of the elements as the number of rows and columns, respectively. For example:eye (3) ⇒ 1 0 0 0 1 0 0 0 1The following expressions all produce the same result:
eye (2) == eye (2, 2) == eye (size ([1, 2; 3, 4])The optional argument class, allows
eyeto return an array of the specified type, likeval = zeros (n,m, "uint8")Calling
eyewith no arguments is equivalent to calling it with an argument of 1. This odd definition is for compatibility with matlab.See also: speye.
Return a matrix or N-dimensional array whose elements are all 1. If invoked with a single scalar integer argument n, return a square NxN matrix. If invoked with two or more scalar integer arguments, or a vector of integer values, return an array with the given dimensions.
If you need to create a matrix whose values are all the same, you should use an expression like
val_matrix = val * ones (m, n)The optional argument class specifies the class of the return array and defaults to double. For example:
val = ones (m,n, "uint8")See also: zeros.
Return a matrix or N-dimensional array whose elements are all 0. If invoked with a single scalar integer argument, return a square NxN matrix. If invoked with two or more scalar integer arguments, or a vector of integer values, return an array with the given dimensions.
The optional argument class specifies the class of the return array and defaults to double. For example:
val = zeros (m,n, "uint8")See also: ones.
Form a block matrix of size m by n, with a copy of matrix A as each element. If n is not specified, form an m by m block matrix.
See also: repelems.
Construct a vector of repeated elements from x. r is a 2xN integer matrix specifying which elements to repeat and how often to repeat each element.
Entries in the first row, r(1,j), select an element to repeat. The corresponding entry in the second row, r(2,j), specifies the repeat count. If x is a matrix then the columns of x are imagined to be stacked on top of each other for purposes of the selection index. A row vector is always returned.
Conceptually the result is calculated as follows:
y = []; for i = 1:columns (r) y = [y, x(r(1,i)*ones(1, r(2,i)))]; endforSee also: repmat.
The functions linspace and logspace make it very easy to
create vectors with evenly or logarithmically spaced elements. 
See Ranges.
   
Return a row vector with n linearly spaced elements between base and limit. If the number of elements is greater than one, then the endpoints base and limit are always included in the range. If base is greater than limit, the elements are stored in decreasing order. If the number of points is not specified, a value of 100 is used.
The
linspacefunction always returns a row vector if both base and limit are scalars. If one, or both, of them are column vectors,linspacereturns a matrix.For compatibility with matlab, return the second argument (limit) if fewer than two values are requested.
Return a row vector with n elements logarithmically spaced from 10^a to 10^b. If n is unspecified it defaults to 50.
If b is equal to pi, the points are between 10^a and pi, not 10^a and 10^pi, in order to be compatible with the corresponding matlab function.
Also for compatibility with matlab, return the second argument b if fewer than two values are requested.
See also: linspace.
Return a matrix with random elements uniformly distributed on the interval (0, 1). The arguments are handled the same as the arguments for
eye.You can query the state of the random number generator using the form
v = rand ("state")This returns a column vector v of length 625. Later, you can restore the random number generator to the state v using the form
rand ("state", v)You may also initialize the state vector from an arbitrary vector of length ≤ 625 for v. This new state will be a hash based on the value of v, not v itself.
By default, the generator is initialized from
/dev/urandomif it is available, otherwise from CPU time, wall clock time, and the current fraction of a second.To compute the pseudo-random sequence,
randuses the Mersenne Twister with a period of 2^19937-1 (See M. Matsumoto and T. Nishimura, Mersenne Twister: A 623-dimensionally equidistributed uniform pseudorandom number generator, ACM Trans. on Modeling and Computer Simulation Vol. 8, No. 1, pp. 3-30, January 1998, http://www.math.sci.hiroshima-u.ac.jp/~m-mat/MT/emt.html). Do not use for cryptography without securely hashing several returned values together, otherwise the generator state can be learned after reading 624 consecutive values.Older versions of Octave used a different random number generator. The new generator is used by default as it is significantly faster than the old generator, and produces random numbers with a significantly longer cycle time. However, in some circumstances it might be desirable to obtain the same random sequences as used by the old generators. To do this the keyword "seed" is used to specify that the old generators should be use, as in
rand ("seed", val)which sets the seed of the generator to val. The seed of the generator can be queried with
s = rand ("seed")However, it should be noted that querying the seed will not cause
randto use the old generators, only setting the seed will. To causerandto once again use the new generators, the keyword "state" should be used to reset the state of therand.The state or seed of the generator can be reset to a new random value using the "reset" keyword.
Return random integers in the range 1:imax.
Additional arguments determine the shape of the return matrix. When no arguments are specified a single random integer is returned. If one argument n is specified then a square matrix (n x n) is returned. Two or more arguments will return a multi-dimensional matrix (m x n x ...).
The integer range may optionally be described by a two element matrix with a lower and upper bound in which case the returned integers will be on the interval [imin, imax].
The optional argument "class" will return a matrix of the requested type. The default is "double".
The following example returns 150 integers in the range 1-10.
ri = randi (10, 150, 1);Implementation Note:
randirelies internally onrandwhich uses class "double" to represent numbers. This limits the maximum integer (imax) and range (imax - imin) to the value returned by thebitmaxfunction. For IEEE floating point numbers this value is 2^53 - 1.See also: rand.
Return a matrix with normally distributed random elements having zero mean and variance one. The arguments are handled the same as the arguments for
rand.By default,
randnuses the Marsaglia and Tsang “Ziggurat technique” to transform from a uniform to a normal distribution.Reference: G. Marsaglia and W.W. Tsang, Ziggurat Method for Generating Random Variables, J. Statistical Software, vol 5, 2000, http://www.jstatsoft.org/v05/i08/)
Return a matrix with exponentially distributed random elements. The arguments are handled the same as the arguments for
rand.By default,
randnuses the Marsaglia and Tsang “Ziggurat technique” to transform from a uniform to an exponential distribution.Reference: G. Marsaglia and W.W. Tsang, Ziggurat Method for Generating Random Variables, J. Statistical Software, vol 5, 2000, http://www.jstatsoft.org/v05/i08/)
Return a matrix with Poisson distributed random elements with mean value parameter given by the first argument, l. The arguments are handled the same as the arguments for
rand, except for the argument l.Five different algorithms are used depending on the range of l and whether or not l is a scalar or a matrix.
- For scalar l ≤ 12, use direct method.
- W.H. Press, et al., Numerical Recipes in C, Cambridge University Press, 1992.
- For scalar l > 12, use rejection method.[1]
- W.H. Press, et al., Numerical Recipes in C, Cambridge University Press, 1992.
- For matrix l ≤ 10, use inversion method.[2]
- E. Stadlober, et al., WinRand source code, available via FTP.
- For matrix l > 10, use patchwork rejection method.
- E. Stadlober, et al., WinRand source code, available via FTP, or H. Zechner, Efficient sampling from continuous and discrete unimodal distributions, Doctoral Dissertation, 156pp., Technical University Graz, Austria, 1994.
- For l > 1e8, use normal approximation.
- L. Montanet, et al., Review of Particle Properties, Physical Review D 50 p1284, 1994.
Return a matrix with
gamma(a,1)distributed random elements. The arguments are handled the same as the arguments forrand, except for the argument a.This can be used to generate many distributions:
gamma (a, b)fora > -1,b > 0r = b * randg (a)
beta (a, b)fora > -1,b > -1
r1 = randg (a, 1) r = r1 / (r1 + randg (b, 1))
Erlang (a, n)r = a * randg (n)
chisq (df)fordf > 0r = 2 * randg (df / 2)
t (df)for0 < df < inf(use randn if df is infinite)r = randn () / sqrt (2 * randg (df / 2) / df)
F (n1, n2)for0 < n1,0 < n2
## r1 equals 1 if n1 is infinite r1 = 2 * randg (n1 / 2) / n1 ## r2 equals 1 if n2 is infinite r2 = 2 * randg (n2 / 2) / n2 r = r1 / r2- negative
binomial (n, p)forn > 0,0 < p <= 1r = randp ((1 - p) / p * randg (n))
- non-central
chisq (df, L), fordf >= 0andL > 0- (use chisq if
L = 0)r = randp (L / 2) r(r > 0) = 2 * randg (r(r > 0)) r(df > 0) += 2 * randg (df(df > 0)/2)
Dirichlet (a1, ... ak)
r = (randg (a1), ..., randg (ak)) r = r / sum (r)
The generators operate in the new or old style together, it is not
possible to mix the two.  Initializing any generator with
"state" or "seed" causes the others to switch to the
same style for future calls.
   
The state of each generator is independent and calls to different generators can be interleaved without affecting the final result. For example,
     rand ("state", [11, 22, 33]);
     randn ("state", [44, 55, 66]);
     u = rand (100, 1);
     n = randn (100, 1);
   and
     rand ("state", [11, 22, 33]);
     randn ("state", [44, 55, 66]);
     u = zeros (100, 1);
     n = zeros (100, 1);
     for i = 1:100
       u(i) = rand ();
       n(i) = randn ();
     end
   produce equivalent results.  When the generators are initialized in
the old style with "seed" only rand and randn are
independent, because the old rande, randg and
randp generators make calls to rand and randn.
   
The generators are initialized with random states at start-up, so that the sequences of random numbers are not the same each time you run Octave.1 If you really do need to reproduce a sequence of numbers exactly, you can set the state or seed to a specific value.
If invoked without arguments, rand and randn return a
single element of a random sequence.
   
The original rand and randn functions use Fortran code from
ranlib, a library of Fortran routines for random number generation,
compiled by Barry W. Brown and James Lovato of the Department of
Biomathematics at The University of Texas, M.D. Anderson Cancer Center,
Houston, TX 77030.
   
Return a row vector containing a random permutation of
1:n. If m is supplied, return m permutations, one in each row of an MxN matrix. The complexity is O(M*N) in both time and memory. The randomization is performed using rand(). All permutations are equally likely.See also: perms.