Forum: FPGA, VHDL & Co. Timerfrage


von Tim (Gast)


Lesenswert?

Hi,

noch einmal eine doofe Frage von mir, aber stecke ein wenig fest.

Ich möchte mir einen Timer bauen der ein 1,2 oder 4 Hz Taktsignal hat.
Leider bin ich mir grade noch so wirklich sicher wie ich das machen
soll. Folgenden Ansatze habe ich:

entity Timer is
    Port ( Aktiv : in STD_LOGIC_VECTOR (1 downto 0);
           Clk : out  STD_LOGIC);
end Timer;


architecture Behavioral of Timer is
  signal intern_sig: STD_LOGIC;

begin
  process(Aktiv)
  begin

    if(Aktiv = '1')
      if(Frequenz = "00") then                --1HZ
        intern_sig <= (not intern_sig) after 100 MS;
      elsif (Frequenz = "01") then              --2HZ
        intern_sig <= (not intern_sig) after 50 MS;
      elsif (Frequenz = "10") then              --3HZ
        intern_sig <= (not intern_sig) after 25 MS;
      end if;
      Clk <= intern_sig;
    end if

  end process;
end Behavioral;


Das Problem ist, Clk kann ich nicht auf inout setzen, da es sich sonst
mit den Eingängen aus dem Simulator überschneidet und ich einen
undefinierten Zustand bekomme.
Kennt einer von euch eine Lösung auf dieses Problem?

Alternativ hat die Platine noch einen 50 Hz Taktgeber, wo ich aber das
Problem hab, da ich nicht weiß wie ich genau 1, 2 bzw. 4 Hz einstelle.

Mit einem Frequenzteiler komme ich so grade auf 3,0125Hz.

Naja irgendwie will das alles nicht so ganz.

Bin über jede Hilfe dankbar.


TIM :)

von Klaus F. (kfalser)


Lesenswert?

Wenn Dein Timer auf einer Platine laufen soll, dann ist nix mit "after
100 ms".

Die einzige Möglichkeit ist aus dem externen Takt durch einen Teiler
auf die gewünschte Frequenz zu kommen.
Also : 1 Hz => 50 Hz durch 50 teilen
       4 Hz => geht nicht, weil 50 nicht durch 4 teilbar.

von someone-somewhere (Gast)


Lesenswert?

hat hier jemand einen fertigen Core, der aus x-Mhz Taktfrequenz X/2-Mhz
erzeugt?
Wenn möglich 2 Cores die je nur einen einzelnen Puls oder Impulse
erzeugen

Danke

von gekko (Gast)


Lesenswert?

hallo someone-somewere!

Du möchtest also nur eine Frequenz halbieren, wenn ich das richtig
verstehe?

Nimm dafür doch ein einfach ein FlipFlop und koppel den negierten
Ausgang auf den Einfang zurück.

Das mit den einzelnen impulsen hab ich nicht ganz verstanden, sorry!

Bitte melde dich an um einen Beitrag zu schreiben. Anmeldung ist kostenlos und dauert nur eine Minute.
Bestehender Account
Schon ein Account bei Google/GoogleMail? Keine Anmeldung erforderlich!
Mit Google-Account einloggen
Noch kein Account? Hier anmelden.