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

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

Please note that the recommended version of Scilab is 2024.0.0. This page might be outdated.
See the recommended documentation of this function

Aide de Scilab >> Code Matlab => Scilab > mfile2sci

mfile2sci

Fonction de conversion de fichiers.m Matlab en langage Scilab

Séquence d'appel

mfile2sci()     // interface interactive
mfile2sci(M_file_path)
mfile2sci(M_file_path, result_path)
mfile2sci(M_file_path, result_path, Recmode)
mfile2sci(M_file_path, result_path, Recmode, only_double)
mfile2sci(M_file_path, result_path, Recmode, only_double, verbose_mode)
mfile2sci(M_file_path, result_path, Recmode, only_double, verbose_mode, prettyprintoutput)

Arguments

M_file_path

une chaîne de caractères qui donne le chemin du M-file à traduire

result_path

une chaîne de caractères qui donne le répertoire où le résultat sera écrit. La valeur par défault est le répertoire courant.

Recmode

Flag booléen, utilisé par translatepaths() pour une conversion récursive. Doit être %F pour convertir un seul M-file. Valeur par défaut : %F

only_double

Booléen : S'il vaut %T, mfile2sci() considère que les fonctions et les opérateurs usuellement numériques sont utilisées uniquement avec des données numériques. Cela exclut par exemple les instructions telles que "ab" + "cd" (qui sera alors conservée en l'état, au lieu d'être traduite en asciimat("ab") + asciimat("cd")).

Valeur par défaut = %F : toutes les conversions possibles sont réalisées.

verbose_mode

règle mode d'affichage des informations de conversion :

0 : aucune information affichée
1 : les informations sont écrites comme commentaires du fichier Scilab.
2 : les informations sont écrites comme commentaires du fichier Scilab et dans le fichier log.
[3] : Les informations sont écrites comme commentaires du fichier Scilab, dans le fichier log et affichées dans la fenêtre Scilab. (Valeur par défaut).
prettyprintoutput

Flag booléen, si il vaut %T le code généré est réarrangé. Valeur par défaut : %F

Description

Le module M2SCI -- et en particulier mfile2sci() -- est un ensemble d'outils de conversion de fichiers.m écrits en Matlab, vers Scilab. Il essaie à chaque fois que c'est possible de remplacer l'appel à une fonction Matlab par la primitive ou la fonction Scilab équivalente.

Pour convertir un fichier.m, entrer l'instruction Scilab : mfile2sci(fichier)

fichier est une chaîne de caractère désignant le chemin et le nom du fichier.m.

mfile2sci(..) va générer trois fichiers dans le même répertoire :

<function-name>.sci l'équivalent du fichier.m en langage Scilab
<function-name>.cat le fichier d'aide Scilab associé à la fonction
sci_<function-name>.sci la fonction Scilab requise pour convertir les appels à ce M-file dans d'autres M-files. Cette fonction peut être améliorée "à la main". Cette fonction est utile uniquement pour la conversion, pas pour utiliser la fonction convertie.

Des fonctions comme eye, ones, size, sum,... se comportent différemment selon la dimension de leurs arguments. Quand mfile2sci ne peut pas inférer les dimensions, il remplace ces fonctions par un appel à une fonction d'émulation nommée mtlb_<function_name>. Pour une meilleure éfficacité, ces fonctions peuvent être remplacées par les instructions Scilab équivalentes. Pour avoir des informations sur le remplacement, entrer : help mtlb_<function_name> dans la fenêtre de commande Scilab.

D'autres fonctions comme plot, n'ont pas d'équivalent direct en Scilab. Elles sont aussi remplacées par des fonctions d'émulation nommées : mtlb_<function_name>.

Quand la conversion peut être incorrecte ou améliorée, mfile2sci() ajoute des commentaires qui commencent par "//!" (suivant verbose_mode).

mfile2sci() appelée sans argument d'entrée ouvre une interface interactive permettant de sélectionner un fichier/dossier à convertir, et de configurer et lancer la conversion :
mfile2sci()

Exemples

// Création d'un fichier .m simple
rot90m = ["function B = rot90(A,k)"
    "if ~isa(A, ''double'')"
    "    error(''rot90: Wrong type for input argument #1: Real or complex matrix expected.'');"
    "    return"
    "end"
    "[m,n] = size(A);"
    "if nargin == 1"
    "    k = 1;"
    "else"
    "    if ~isa(k, ''double'')"
    "        error(''rot90: Wrong type for input argument #2: A real expected.'');"
    "        return"
    "    end"
    "    k = rem(k,4);"
    "    if k < 0"
    "        k = k + 4;"
    "    end"
    "end"
    "if k == 1"
    "    A = A.'';"
    "    B = A(n:-1:1,:);"
    "elseif k == 2"
    "    B = A(m:-1:1,n:-1:1);"
    "elseif k == 3"
    "    B = A(m:-1:1,:);"
    "    B = B.'';"
    "else"
    "    B = A;"
    "end"];
mputl(rot90m, TMPDIR + "/rot90.m")

// Conversion en Scilab
mfile2sci(TMPDIR + "/rot90.m",TMPDIR)

// Affichage du code
mgetl(TMPDIR + "/rot90.sci")

// Compilation dans Scilab
exec(TMPDIR+'/rot90.sci')

// Appel et usage
m=rand(4,2);
rot90(m,1)

Voir aussi

  • translatepaths — convertit un ensemble de répertoires contenant des M-files vers Scilab

Historique

VersionDescription
6.0.2 L'option only_double est désormais %F par défaut.
Report an issue
<< m2scideclare Code Matlab => Scilab translatepaths >>

Copyright (c) 2022-2023 (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:
Tue Feb 25 08:50:45 CET 2020