Scilab Website | Contribute with GitLab | Mailing list archives | ATOMS toolboxes
Scilab Online Help
6.0.1 - Français

Change language to:
English - 日本語 - Português - Русский

Please note that the recommended version of Scilab is 2025.0.0. This page might be outdated.
However, this page did not exist in the previous stable version.

Aide de Scilab >> Fonctions Elémentaires > Traitement du signal > sysdiag

sysdiag

Create a block diagonal matrix from provided inputs or block diagonal system connection

Syntax

r=sysdiag(a1,a2,...,an)

Description

Returns the block-diagonal system made with subsystems put in the main diagonal

ai

subsystems (i.e. gains, or linear systems in state-space or transfer form)

constant, boolean, polynomial or rational matrices of any size

r

a matrix with a1, a2, a3, ... on the diagonal

Description

Given the inputs A, B and C, the output will have these matrices arranged on the diagonal: .

If all the input matrices are square, the output is known as a block diagonal matrix.

Used in particular for system interconnections.

Beside this function, you can also use sparse() primitive to build a block diagonal sparse matrix.

For boolean matrices sysdiag() always returns a zero one matrix in the corresponding block ("true" values are replaced by 1 and "false" value by 0).

sysdiag() cannot be used to arrange matrices made of character strings, but you can overload it (see: overloading).

Remark

At most 17 arguments.

Examples

s=poly(0,'s')
sysdiag(rand(2,2),1/(s+1),[1/(s-1);1/((s-2)*(s-3))])
sysdiag(tf2ss(1/s),1/(s+1),[1/(s-1);1/((s-2)*(s-3))])
// a matrix of doubles:
A=[1 0; 0 1], B=[3 4 5; 6 7 8], C=7
D=sysdiag(A,B,C)
//
sysdiag([%t %f; %f %t], eye(2,2), ones(3,3))
// a polynomial matrix:
s=%s;
sysdiag([s 4*s; 4 s^4], [1 s^2 s+2; 3*s 2 s^2-1])
// a rational matrix:
sysdiag([1/s 2*s/(4*s+3)], [s; 4; 1/(s^2+2*s+1)])
// a block diagonal sparse matrix:
S=sysdiag([1 2; 3 4], [5 6; 7 8], [9 10; 11 12], [13 14; 15 16])
S=sparse(S)

See also

  • brackets — Concaténation. Récipients d'une affectation. Résultats d'une function
  • insertion — insertion/modification dans une variable
  • feedback — feedback operation
  • diag — extraction de diagonale ou construction d'une matrice avec un vecteur en diagonal
  • bdiag — bloc-diagonalisation, vecteurs propres généralisés
  • sparse — sparse matrix definition
  • repmat — Définit un grand tableau par pavage avec un tableau 2D.
Report an issue
<< sysconv Traitement du signal trfmod >>

Copyright (c) 2022-2024 (Dassault Systèmes)
Copyright (c) 2017-2022 (ESI Group)
Copyright (c) 2011-2017 (Scilab Enterprises)
Copyright (c) 1989-2012 (INRIA)
Copyright (c) 1989-2007 (ENPC)
with contributors
Last updated:
Mon Feb 12 19:15:27 CET 2018