Please note that the recommended version of Scilab is 2024.1.0. This page might be outdated.
See the recommended documentation of this function
brackets [,;]
Concaténation. Récipients d'une affectation. Résultats d'une function
Syntaxe
Mh = [m11 m12 m13.. m1N] or [m11, m12, m13,.., m1N] Mv = [m11 ; m21 ; m31..; mN1] M = [m11, m12,...; m21, m22,...;...] [r1, r2,...] = func(...) [r1, r2,.., rN] = (e1, e2, .., eN) [r1, r2,.., rk] = (e1, e2, .., ek,.., eN) [r1, r2,.., rN] = mylist(:) [r1, r2,.., rN] = S.field([i1 i2.. iN])
Arguments
- m11, m12,...
Ensemble d'objets à concaténer (rassembler) et à fusionner : les conteneurs individuels initiaux des objets sont supprimés. Les types d'objets des familles suivantes peuvent être mélangés entre eux dans une même famille, mais pas entre familles :
- Matrices de booléens, nombres décimaux, nombres complexes, polynômes, fractions rationnelles : le type de l'objet résultant est le type de l'élément le plus complexe, des booléens (le moins complexe) aux fractions rationelles à coefficients complexes (voir les règles de transtypages).
- Matrices d'entiers encodés de type entier
inttype quelconque.
Des entiers de types différents ne peuvent pas être concaténés entre eux.
- Tableaux de cellules.
- Tableaux de structures ayant les mêmes champs. Les champs peuvent être dans des ordres différents d'un tableau à l'autre.
- Listes de type syslin
- M, Mh, Mv
Matrices ayant le type des éléments
m##
(s'ils ont tous le même type). Tableaux de cellules (si lesmi
en sont). Tableaux de structures (si lesmi
en sont).- e1, e2,..
Objets d'entrée (litéraux tels que
-1.23
ou"abcd"
, variables, ou expressions telles quea+%pi
)- mylist
Liste simple du type list(..)
- S.field
Tableau de structures ayant un champ nommé
field
.- i1, i2, ..
Indices des éléments de
S
sélectionnés.- r1, r2,...
Récipients = variables de sortie
Description
- [] (figurant à droite) : crochets concaténateurs
[..] assemble les objets de types simples et compatibles pour former un vecteur, une matrice ou une hypermatrice homogène.
La concaténation horizontale ou verticale de N éléments est un opérateur binaire itératif : la concaténation est réalisée de proche en proche entre 2 élements consécutifs, de la gauche vers la droite, et de haut en bas. Ainsi,[1 3 5 7]
est effectuée par[[[1 3] 5] 7]
.Dans les crochets,
- les espaces (blancs ou tabulations) ou
les virgules servent de séparateurs.
Il est préférable d'utiliser des virgules, en particulier lorsque des nombres complexes ou des polynômes sont fournis en expressions litérales. Par exemple,
[2 1 +%i]
sera interprété comme[2, 1, %i]
, alors que[2 1 + %i]
sera compris comme[2, 1+%i]
. - les points-virgules ou les changements de
lignes sont utilisés comme séparateurs de lignes.
Pour peu que la ligne courante soit complète, le
passage à la ligne ne pré-requiert pas les points de
poursuite-à-la-ligne
..
.
Transtypages
Avec quelques restrictions, les crochets peuvent être utilisés sur une série de valeurs ayant des types distincts mais compatibles. Des valeurs sont alors converties de proche en proche dans le type de données dominant. Les principales règles de conversion implicite sont les suivantes :
- booléen < nombre décimal < nombre complexe
- décimal < polynôme < fraction rationelle
Les booléens et les polynômes ne sont pas compatibles entre eux :
[%t 2. %z]
est accepté, car :[%t 2.]
est d'abord converti en[1. 2.]
, puis[[1. 2.] %z]
est accepté.[%z %t 2.]
est refusé et produit une erreur. En effet,[%z %t]
n'est pas permis et bloque la suite.
- Le résultat est encodé en valeurs complexes (avec
parties imaginaires éventuellement nulles) dés qu'un
élément -- valeur, polynôme, ou fraction rationnelle --
à valeur complexe est rencontré.
De même, le résultat est encodé sous forme creuse dés qu'un élément encodé creux est rencontré.
- Des polynômes ou des fractions rationnelles
de différentes variables peuvent
être concaténés entre eux. Le premier polynôme
ou fraction rationnelle listé donne alors le
nom de sa variable au résultat de la concaténation :
[%z, 1+%s, 1-%i*%s] // => [z, 1+z, 1-iz]
. - Tout entier encodé peut être concaténé uniquement
avec d'autres entiers du même type entier
(inttype). Ainsi,
les expressions
[%t int8(2)]
,[int8(2) uint8(7)]
,[int8(2) int16(7)]
,[int8(2) 1.]
produiront toutes une erreur. - Les éléments de texte (type "string") peuvent
être concaténés (au sens ensembliste, avec les crochets)
uniquement entre eux ou avec la matrice vide
[]
.
Surcharge
- [,]: concaténation horizontale :
cet opérateur n-aire (pouvant être appliqué à un
nombre arbitraire n de données) est en fait un
opérateur binaire automatiquement itéré de la
gauche vers la droite. Son code de surcharge est
"c"
. - [;]: la concaténation verticale est
également un opérateur binaire, itéré du haut
vers le bas. Son code de surcharge est
"f"
.
- les espaces (blancs ou tabulations) ou
les virgules servent de séparateurs.
- [] figurant à gauche d'une affectation
"="
Dans ce cas, les crochets ne désignent en rien une concaténation. Ils délimitent une série de variables servant de récipients.
- Les termes entre crochets doivent alors impérativement être des variables. Les expressions litérales ou symboliques sont rejetées.
- Les variables sont séparées par des virgules ou des espaces. Lorsqu'il s'agit de la liste des arguments de sortie d'une function, les virgules sont obligatoires.
- Dans une affectation distributive, il doit
y avoir au plus
autant de récipients que de sources de données
provenant du terme de droite, pas plus. S'il y
moins de récipients à gauche que de sources à droite,
les sources non collectées sont ignorées. Exemples :
[a,b] = (%pi,"Hi", %z)
est correct, mais%z
sera ignoré.[a,b,c] = (%pi,"Hi")
produit une erreur, carc
attend du contenu.
- La même variable peut être utilisée plusieurs
fois dans la liste de gauche entre crochets.
Le cas échéant, les affectations successives sont réalisées
de droite à gauche (!) dans la liste,
et écrasent les contenus pré-existants. Exemple :
[a,b,a] = (%pi, %z, "Allo")
est équivalent àa = %pi, b = %z
.
Exemples
// Concaténation horizontale a = [ %pi 4 -1 ] b1 = grand(3,4,"uin",0,10) b2 = grand(3,2,"uin",0,10) b = [b1 b2] // b1, b2.. doivent avoir le même nombre de lignes // Concaténation verticale a = [-2 ; 10 ; 7] b1 = grand(2,4,"uin",0,10) b2 = grand(3,4,"uin",0,10) b = [b1 ; b2] // // b1, b2.. doivent avoir le même nombre de colonnes // Double concaténation horizontale et verticale a = [ 3 7 ; 6, 5 ] b = [ 1:3 ; 7:3:13] c = [ a b ; a b] d = [ 3 5 1 4 ] e = [ d d d d d d ] // Concaténation de types d'objets variés : ['this is' ; 'a column' ; 'of texts'] s = poly(0,'s');[1/s,2/s] [tf2ss(1/s),tf2ss(2/s)] [%t %f %f %T %F] // Concaténation d'objets de types compatibles différents, avec transtypages automatiques [%T %pi %f 2] [%pi, 2+%i, %F] v = [%pi+0*%i, %F, %z, (1-%z)^2 ]; typeof(v), isreal(v) v = [10 1/%z], typeof(v) // Concaténations hétérogènes d'objets de types incompatibles => ERREURS [%F %z] [%F int8(5)] [int8(%pi) uint8(%e)] [int8(%pi) int16(%e)] // Concaténation de tableaux de cellules : c1 = {%pi %t}; c2 = {%z "abc"}; c = [[{%i} c1] ; [c2, {1/%z^2}]] // virgule obligatoire sinon c2{1/%z^2} => erreur
Affectations distributives :
// Variables des réponses d'une function. // Elles sont le plus souvent optionnelles, l'une après l'autre M = rand(3,3); [u, s] = schur(M) // Nous attendons et utilisons à la fois u et s u = schur(M) // Nous attendons et stockons uniquement u // Liste directe (implicite) d'objets à affecter [a, b, c] = (%pi, %t, "test") [a, b] = (%e, %f, "Hello") [a, b, a] = (%pi, %t, "test"); // Liste explicite d'objets à affecter L = list(%z, %i, %t, %pi, "Text"); [a, b, c] = L(:) // Tableau de structures : // Sélection de certaines cellules et affectation de leurs contenus s(2,3).r = %pi; s(2,1).r = %i; s(2,2) = %e; s(2,:).r s.r([2 4 6]) [a, b, c] = s.r([2 4 6]) // Expressions gauches interdites et rejetées (=> erreur) [m, n, m+n] = myfun(a,b) // "m+n" est une expression, non un nom de variable. [p, 4.5, q] = myfun(a,b) // "4.5 est une valeur littérale, non un nom de variable. [r, s+3 ] = myfun(a,b) // "s+3" est une expression mixte, non un nom de variable
--> [a, b, c] = (%pi, %t, "test") c = test b = T a = 3.1415927 --> [a, b] = (%e, %f, "Hello") b = F a = 2.7182818 --> [a, b, a] = (%pi, %t, "test"); a a = 3.1415927
Voir aussi
- empty — matrice vide
- parentheses — parenthèses droite et gauche
- cat — stacks vectors matrices or arrays into an hypermatrix or hyperarray
- lstcat — concaténation de listes
- comma — (,) virgule, séparateur d'instructions ou d'arguments
- semicolon — (;) séparateur de lignes ou d'instructions Scilab
- overloading — display, functions and operators overloading capabilities
Historique
Version | Description |
6.0 | Crochets [..] et accolades
{..} ont désormais des fonctions distinctes. |
Report an issue | ||
<< backslash | Mots clés Scilab | colon (:) >> |