IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

VHDL Discussion :

Problème diviseur de fréquence pour MLI.


Sujet :

VHDL

  1. #1
    Candidat au Club
    Profil pro
    Inscrit en
    Avril 2013
    Messages
    3
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2013
    Messages : 3
    Points : 2
    Points
    2
    Par défaut Problème diviseur de fréquence pour MLI.
    Bonjour,

    Voila, j'ai besoin de généré une sinsoide d'amplitude et fréquence variable pour de la MLI.
    J'ai jamais codé en VHDL mais jusque la je m 'en suis sortit mais en fixant dans mon code VHDL du diviseur de fréquence, la fréquence que je voulais pour ma sinusoide.

    Maintenant je voudrais que ce paramètre (variable : Fmodulante) soit une entrée de mon bloc..et la ca coince car je ne sais pas comment la déclarer dans mon programme.
    Voici le code du diviseur :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
     
    entity DiviseurFrequence is
    port (clk :in  std_logic;
           Fmodulante :in integer;
          NewClk : out std_logic
          );
    end DiviseurFrequence;
     
    architecture ModulanteSinus of DiviseurFrequence is
    signal i : integer range 0 to 50000:=0;
     
    begin
    process(clk)
    begin
      --to check the rising edge of the clock signal
    if(rising_edge(clk)) then  
    i <= i+1;
     
    if(i = (2e9/800/Fmodulante/2)) then
    NewClk <= '1';
    end if;
     
    if(i = (2e9/800/Fmodulante)) then
    NewClk <= '0';
    i <= 0;
     
    end if;
    end if;
    end process;
    end ModulanteSinus;
    Une idée svp ?

    Merci d'avance !

  2. #2
    Membre expérimenté

    Homme Profil pro
    Collégien
    Inscrit en
    Juillet 2010
    Messages
    545
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Afghanistan

    Informations professionnelles :
    Activité : Collégien

    Informations forums :
    Inscription : Juillet 2010
    Messages : 545
    Points : 1 429
    Points
    1 429
    Par défaut
    Bonjour.

    Tu y étais presque!

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    entity DiviseurFrequence is
        port (
            RST         : in std_logic;
            clk         : in std_logic;
            Fmodulante  : in integer;
            NewClk      : out std_logic
        );
    end DiviseurFrequence;
     
    architecture ModulanteSinus of DiviseurFrequence is
        signal i        : integer range 0 to 50000:=0;
        signal NewClk_i : std_logic;    
    begin
        process(RST,clk)
        begin
          --to check the rising edge of the clock signal
            if(RST = '1')then
                NewClk_i  <= '0';
            elsif(rising_edge(clk)) then
     
                if( i < Fmodulante)then
                    i <= i+1;
                else
                    i <= 0;
                    NewClk_i  <= not NewClk_i;
                end if;
            end if;
        end process;
        NewClk  <= NewClk_i;
    end ModulanteSinus;
    Maintenant réfléchit un peu avec un papier et un crayon, et cherche l'équation entre la fréquence du signal NewClk la valeur de l’entier Fmodulante et la fréquence du signal clk.

  3. #3
    Candidat au Club
    Profil pro
    Inscrit en
    Avril 2013
    Messages
    3
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2013
    Messages : 3
    Points : 2
    Points
    2
    Par défaut
    Merci pour ta réponse, ca fonctionne parfaitement !

    D'ailleurs, je sais pas si tu sais mais je me suis renseigné et il existe une MegaWizard (MegaWizard/DSP/SignalGeneration) qui fait la génération de sinus modulable en fréquence et amplitude mais je n'ai pas encore testé ^^

    Merci encore pour ton aide !

    bye

Discussions similaires

  1. Problème de boutons radio pour récuperer les infos
    Par marsupilami34 dans le forum Général JavaScript
    Réponses: 1
    Dernier message: 06/09/2005, 11h47
  2. problèmes avec "include file" pour une page asp
    Par chipsense dans le forum ASP
    Réponses: 1
    Dernier message: 02/09/2005, 15h22
  3. Réponses: 5
    Dernier message: 31/08/2005, 10h05
  4. problème de requète SQL pour formulaire
    Par en_stage dans le forum Requêtes et SQL.
    Réponses: 15
    Dernier message: 21/06/2005, 12h21
  5. [tomcat] [jsp] Problème avec driver OCI pour oracle
    Par nanardcompanie dans le forum Tomcat et TomEE
    Réponses: 3
    Dernier message: 01/07/2004, 09h54

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo