Doel:€250.00
Donaties:€88.00

Per saldo:€-162.00

Steun ons nu!

Laatst bijgewerkt
op 03-06-2025

Vacature: secretaris bestuur
Algemeen

De stichting

Recente berichten

Vervangen wissels flm profi door Luc2000
Vandaag om 21:57:06
Ervaringen met EVA (Ethylene-vinyl acetate) foam/rubber als rail-underlayment. door Joz
Vandaag om 21:54:05
Het bouwen van een Philotrain 2400 kit door Casmir
Vandaag om 21:46:55
Een nieuw baantje op Micromodules door Peter Soonius
Vandaag om 21:41:48
Piko NS 5/600 Hippel 2025 door prutser
Vandaag om 21:37:59
Toon hier je nieuwe (model-) spooraanwinst(en)... door MichielB
Vandaag om 21:34:44
De bouw van mijn modelbaan in Thailand door wob
Vandaag om 21:27:30
Modelbaan Beltheim. door basjuh1981
Vandaag om 20:52:39
Spoorwegmuseum krimpt collectie in door Quinzeedied
Vandaag om 20:37:40
Bouw spoor nul modulebaan, Bahnhof Königshofen, tijdperk III door BartvD
Vandaag om 20:16:47
Ombouw/Pimpen Bolle neuzen door BartvD
Vandaag om 20:11:57
Tickets Modelspoordagen 2026 door Ronald Halma
Vandaag om 20:11:18
Blokken, isoleren en bezetmelders. Help! door janvanbemmel
Vandaag om 20:10:25
Station Roodeschool door Torikoos
Vandaag om 19:43:53
De dingen die je kan maken uit een plaat. door hmmglaser
Vandaag om 19:29:58
Project X...... door Ivo tB
Vandaag om 19:27:32
Raadplaatje door GerardvV
Vandaag om 16:40:29
De Projecten van RetroJack door Hans GJ
Vandaag om 16:40:02
Decals, witte NS logo's en cijfers voor plan E door Frans Peeters
Vandaag om 16:22:02
Hoe een schaduwstation automatiseren door Eric v C
Vandaag om 15:21:34
Materieel verzameling van Michiel(NDS) door neudalhausenstadbahn
Vandaag om 12:26:50
Modulebaan.nl - kleine keerlussen µMh0UB's door NS264
Vandaag om 12:23:34
MODELSPOOR by MTD - 2025 - 18 & 19 oktober 2025 in Edegem (B) door Frans Peeters
Vandaag om 12:18:23
UP Mikado. Messing model schaal-0. De zaag er in. door FritsT
Vandaag om 11:59:38
Show je werkplek door neudalhausenstadbahn
Vandaag om 11:58:26
Mijn eerste H0-modeltreinbaan in aanbouw door Wim Vink
Vandaag om 11:16:31
Nahmertaler Kleinbahn door spoorijzer
Vandaag om 11:06:43
BNLS modulebaan: Werkspoor-Kathedraal 3.5 door MOVisser
Vandaag om 10:47:57
LS Models/Lemke CityNightLine samenstelling?? door verst107
Vandaag om 09:52:50
NS 8800 in spoor 0 door bollen neus
Vandaag om 09:20:09
  

Auteur Topic: P50x commando's  (gelezen 4341 keer)

**Jelle**

  • Offline Offline
  • Berichten: 331
P50x commando's
« Gepost op: 15 February 2007, 23:43:13 »
Vandaag bezig geweest met een (mislukt) :'( experiment. Ik gebruik eigen in Visual Basic geschreven software in combinatie met MrDirect.

De dekoders stonden in MrDirect op 14 snelheidsstappen (type NB), vandaag heb ik dat overgezet naar type N1, dus met 28 snelheidsstappen. Alle dekoders zijn ook omgeprogrammeerd naar 28 snelheidsstappen, dus CV29 op 2 gezet.
Vanuit MrDirect werkte alles weer direkt zonder problemen, maar vanuit mijn besturingsprogramma krijg ik er niet een meer in beweging. Het gekke is dat het omkeren van rijrichting wel werkt, (binnen)verlichting aan en uit werkt ook, maar de snelheidsinformatie komt niet aan in MrDirect. Terwijl dat voorheen wel werkte.
De commando's worden binair doorgegeven aan MrDirect volgens het volgende format:


*** XLok (080h) - length = 1+4 bytes
1st   low byte of Lok address
2nd   high byte of Lok address
3rd   speed (0..127: 0 = Stop, 1 = Stop/Em.Stop)
   N.B. bit #7 is reserved for future use!
4th   this byte has the following format:

   bit#   7     6     5     4     3     2     1     0
       +-----+-----+-----+-----+-----+-----+-----+-----+
       |ChgF |Force| Dir | FL  | F4  | F3  | F2  | F1  |
       +-----+-----+-----+-----+-----+-----+-----+-----+


Is iemand wel eens vaker tegen dit probleem aangelopen?

Jelle.
NS, DDW, Edits booster, LocoNet met LbServer, besturing met eigen geschreven software in VB

Wim Ros

  • BHV
  • Offline Offline
  • Berichten: 7819
  • Alleen de waarheid ligt in het midden.
    • Perrongeluk
Re: P50x commando's
« Reactie #1 Gepost op: 15 February 2007, 23:57:14 »
Jelle,

Zend je dan ook de snelheids stappen volgens die 28 stappen.

0.127. Als je stap 127 zend zal hij op volle snelheid moeten gaan rijden.

De waardes voor de tussen stappen verschillen met de waardes voor 14 stappen.

Mvg
Wim.


DEFINT A-Z
FUNCTION P50_Speed% (P50X_Speed AS INTEGER)
SELECT CASE P50X_Speed
CASE 0, 1
   P50_Speed = 0
CASE ELSE
   P50_Speed = INT((P50X_Speed * 2) / 19) + 1
END SELECT
END FUNCTION

(Obvioulsy, it cannot ever happen that P50_Speed() = 15.)

The opposite conversion is performed using a table, indexed by the
P50 speed:
   0,  2, 10, 19, 29, 38, 48, 57, 67, 76, 86, 95, 105, 114, 127, 1

The speed conversion routines for the other protocols/speed steps are:

Speed_15:
(FMZ protocol: 0 = Stop, 1..15 = non-stop speed steps)
   IF (P50X_Speed = 0) OR (P50X_Speed = 1) THEN
      Speed_15 = 0
   ELSE
      Speed_15 = INT((P50X_Speed + 1) / 9) + 1
   ENDIF


Speed_27:
(DCC 27 protocol: 0 = Stop, 1 = Em. Stop, 2..28 = non-stop speed steps)
   IF (P50X_Speed = 0) OR (P50X_Speed = 1) THEN
      Speed_27 = P50X_Speed
   ELSE
      IF (P50X_Speed < 8) THEN
         Speed_27 = 2
      ELSE
         nTemp = P50X_Speed * 2
         nTemp1= INT(nTemp / 9)
         nTemp2= nTemp - (nTemp1 * 9)
         IF (nTemp2 >= 7) THEN
            nTemp1 = nTemp1 + 2
         ELSE
            nTemp1 = nTemp1 + 1
         ENDIF
         IF nTemp1 > 28 THEN
            Speed_27 = 28
         ELSE
            Speed_27 = nTemp1
         ENDIF
      ENDIF
   ENDIF


Speed_28:
(DCC 28 protocol: 0 = Stop, 1 = Em. Stop, 2..29 = non-stop speed steps)
   IF (P50X_Speed = 0) OR (P50X_Speed = 1) THEN
      Speed_28 = P50X_Speed
   ELSE
      Speed_28 = INT(((P50X_Speed - 2) * 2) / 9) + 2
   ENDIF


Speed_31:
(Selectrix protocol: 0 = Stop, 1..31 = non-stop speed steps)
   IF (P50X_Speed = 0) OR (P50X_Speed = 1) THEN
      Speed_31 = 0
   ELSE
      IF (P50X_Speed < 4) THEN
         Speed_31 = 1
      ELSE
         Speed_31 = INT(P50X_Speed / 4)
      ENDIF
   ENDIF

« Laatst bewerkt op: 16 February 2007, 00:02:10 door Wim Ros »
Intellibox via LocoNet-Interface met s88 via een s88 naar LocoNet adapter.Of L.NET-S88SD16-N Marklin 6021 via een 63820, LocoNet-Interface en een s88 naar LocoNet adapter. Lenz Digital Plus via  LI101F of s88XPressNetLi s88SD16-n. http://rosoft.boards.net

**Jelle**

  • Offline Offline
  • Berichten: 331
Re: P50x commando's
« Reactie #2 Gepost op: 16 February 2007, 00:20:39 »
Hallo Wim,

bedankt voor je reaktie. Ik heb net even rechtstreeks in de regel die de lokcommando's verzendt de snelheid op 127 gezet, geen reaktie. In MrDirect bleef de snelheid gewoon 0.

Groetjes, Jelle.
NS, DDW, Edits booster, LocoNet met LbServer, besturing met eigen geschreven software in VB

Wim Ros

  • BHV
  • Offline Offline
  • Berichten: 7819
  • Alleen de waarheid ligt in het midden.
    • Perrongeluk
Re: P50x commando's
« Reactie #3 Gepost op: 16 February 2007, 00:47:14 »
En hoe ziet die regel er dan verder uit?

Mvg
Wim.
Intellibox via LocoNet-Interface met s88 via een s88 naar LocoNet adapter.Of L.NET-S88SD16-N Marklin 6021 via een 63820, LocoNet-Interface en een s88 naar LocoNet adapter. Lenz Digital Plus via  LI101F of s88XPressNetLi s88SD16-n. http://rosoft.boards.net

**Jelle**

  • Offline Offline
  • Berichten: 331
Re: P50x commando's
« Reactie #4 Gepost op: 16 February 2007, 17:09:09 »
Goedendag,

De aanstuurregel om loks aan te sturen vanuit Visual Basic ziet er als volgt uit:

MDIForm1.MrDirectAanst.Output = "X" + Chr$(&H80) + Chr$(DekAdres(LokNo) And &HFF) + Chr$(DekAdres(LokNo) \ 256) + Chr$(AanstSnel) + Chr$(&H80 + &H40 * Force + &H20 * Ri + F14)

Chr$(DekAdres(LokNo) And &HFF), low byte of Lok adress
Chr$(DekAdres(LokNo) \ 256), high byte of Lok adress
Chr$(AanstSnel), snelheid
Chr$(&H80 + &H40 * Force + &H20 * Ri + F14), hierin zit de richting, funkties etc.

Aan deze regel is niets veranderd sinds het omzetten naar 28 rijstappen. De waarde AanstSnel bevat de gewenste snelheid, en deze heeft allerlei waarden tussen 0 en 127 gehad, maar in MrDirect gebeurde niets. ??? Omzetten rijrichting, funkties etc werkt wel.

Jelle.


NS, DDW, Edits booster, LocoNet met LbServer, besturing met eigen geschreven software in VB

Wim Ros

  • BHV
  • Offline Offline
  • Berichten: 7819
  • Alleen de waarheid ligt in het midden.
    • Perrongeluk
Re: P50x commando's
« Reactie #5 Gepost op: 16 February 2007, 18:38:45 »
Dit is een onderdeel van een werkend voorbeeld programma te vinden op
http://groups.yahoo.com/group/IBX/files/Simple_VB6_Program/

Misschien dat je even lid moet worden van de group.


P50XCmd Chr(XLok) + Chr(Adresse% And &HFF) + Chr(Adresse% \ 256) + Chr(Vitesse%) + Chr(&HC0 + (Direction% And &H1) * 32 + (Lumiere% And &H1) * 16 + (F14% And &HF))

De juiste waardes voor Vitesse%

staan in spd

 Case "28", "28ADR", "28DAC"
        Select Case spd
        Case 0: spd = 0
        Case 1: spd = 2
        Case 2: spd = 7
        Case 3: spd = 11
        Case 4: spd = 16
        Case 5: spd = 20
        Case 6: spd = 25
        Case 7: spd = 29
        Case 8: spd = 34
        Case 9: spd = 38
        Case 10: spd = 43
        Case 11: spd = 47
        Case 12: spd = 52
        Case 13: spd = 56
        Case 14: spd = 61
        Case 15: spd = 65
        Case 16: spd = 70
        Case 17: spd = 74
        Case 18: spd = 79
        Case 19: spd = 83
        Case 20: spd = 88
        Case 21: spd = 92
        Case 22: spd = 97
        Case 23: spd = 101
        Case 24: spd = 106
        Case 25: spd = 110
        Case 26: spd = 115
        Case 27: spd = 119
        Case 28: spd = 124

'Function to send a P50Xa (P50X ASCII) or P50Xb cmd.
'It returns the ASCII reply to the cmd

Public Function P50XCmd(s As String)

If Programmer.Port.PortOpen Then
send = IIf(Asc(Left(s, 1)) < &H80, s + vbCr, s)

If P50 Then
    send = "x" + send
End If

    While Programmer.Port.OutBufferCount > 0: Wend

   
    With Programmer.Port
    j = Len(send)
        For i = 1 To j
            Tmp = Left(send, 1)
            send = Mid(send, 2)
           
            .Output = Tmp
           
        Next
        End With



    If Asc(Left(s, 1)) >= &H80 Then
                Call Events(s)
     else
        r$ = ""
        Do
            t% = WaitRx%()
            If t% = -1 Then     'I.e. if rx timeout
                Debug.Print (t%)
                P50XCmd = ""
                Exit Function
            Else
                r$ = r$ + Chr$(t%)
               
            End If
           
        Loop While t% <> Asc(IB_OK_Prompt): '"]"
       

P50XCmd = r$
End If
End Function

« Laatst bewerkt op: 16 February 2007, 18:55:29 door Wim Ros »
Intellibox via LocoNet-Interface met s88 via een s88 naar LocoNet adapter.Of L.NET-S88SD16-N Marklin 6021 via een 63820, LocoNet-Interface en een s88 naar LocoNet adapter. Lenz Digital Plus via  LI101F of s88XPressNetLi s88SD16-n. http://rosoft.boards.net