################################################
# Module: motor.py
# Created: 21 April 2009
# Author: Daniel Thompson
# http://danthompsonsblog.blogspot.com/
# Version: 0.2
# License: GPLv3
# http://www.fsf.org/licensing/
'''Provides a serial connection abstraction layer
for use with Arduino "MultipleSteppers" sketch.
'''
#######################fhgjfhjfghjfghjgfhjfghjgfhjghjghjghj#########################
import motor
import serial
#setup the serial port
usbport = 'COM4'
ser = serial.Serial(usbport, 115200, timeout=1)
# convert a decimal (denary, base 10) integer to a binary string (base 2)
def d2b(n):
'''convert denary integer n to binary string bStr'''
bStr = ''
if n < 0: raise ValueError, "must be a positive integer"
if n == 0:
return '0'
while n > 0:
bStr = str(n % 2) + bStr
n = n >> 1
return bStr
'''Returns the number of bit bytes (eighths) in binary string.
Always rounds up, never rounds down.'''
def binaryCount(number):
sNumber = str(number)
length = len(sNumber)
numBytes = length / 8.0
numBytesInt = length / 8
if numBytes > numBytesInt:
return numBytesInt + 1
else:
return numBytesInt
'''This function gets the first byte, removes it from the string and
returns a new value'''
def shiftLeft(binary):
sBinary = str(binary)
firstByte = int(sBinary,2) & int('11111111',2)
newBinary = int(sBinary,2) >> 8
nBinary = motor.d2b(newBinary)
print "I took away", firstByte
print "And now I'm left with", nBinary
return nBinary
# Wraps several functions to split
# the "steps" integer into bytes ready for sending
# Then it write packet header (255) and then
# all the other bytes
'''The final move command. I combines all the other functions in this
module to move the motor to the specified position'''
def position(num,degsPerStepFloat,stepsFloat):
steps = int(stepsFloat / degsPerStepFloat)
if(steps < 65535 and steps > -1):
binary = motor.d2b(steps)
numBytes = motor.binaryCount(binary)
# from the shiftLef def
ser.write(chr(255))
# note: the 2 in (0,2,1) is critical for alowing two bytes through every time.
for i in range(0,2,1):
sBinary = str(binary)
firstByte = int(sBinary,2) & int('11111111',2)
newBinary = int(sBinary,2) >> 8
binary = motor.d2b(newBinary)
ser.write(chr(firstByte))
if(steps > -65535 and steps < 0):
stepsNeg = steps * -1
binary = motor.d2b(stepsNeg)
numBytes = motor.binaryCount(binary)
# from the shiftLef def
ser.write(chr(220))
# note: the 2 in (0,2,1) is critical for alowing two bytes through every time.
for i in range(0,2,1):
sBinary = str(binary)
firstByte = int(sBinary,2) & int('11111111',2)
newBinary = int(sBinary,2) >> 8
binary = motor.d2b(newBinary)
ser.write(chr(firstByte))
return stepsFloat
################################################
# Module: motor.py
# Created: 21 April 2009
# Author: Daniel Thompson
# http://danthompsonsblog.blogspot.com/
# Version: 0.2
# License: GPLv3
# http://www.fsf.org/licensing/
'''Provides a serial connection abstraction layer
for use with Arduino "MultipleSteppers" sketch.
'''
################################################
import motor
import serial
#setup the serial port
usbport = 'COM4'
ser = serial.Serial(usbport, 115200, timeout=1)
# convert a decimal (denary, base 10) integer to a binary string (base 2)
def d2b(n):
'''convert denary integer n to binary string bStr'''
bStr = ''
if n < 0: raise ValueError, "must be a positive integer"
if n == 0:
return '0'
while n > 0:
bStr = str(n % 2) + bStr
n = n >> 1
return bStr
'''Returns the number of bit bytes (eighths) in binary string.
Always rounds up, never rounds down.'''
def binaryCount(number):
sNumber = str(number)
length = len(sNumber)
numBytes = length / 8.0
numBytesInt = length / 8
if numBytes > numBytesInt:
return numBytesInt + 1
else:
return numBytesInt
'''This function gets the first byte, removes it from the string and
returns a new value'''
def shiftLeft(binary):
sBinary = str(binary)
firstByte = int(sBinary,2) & int('11111111',2)
newBinary = int(sBinary,2) >> 8
nBinary = motor.d2b(newBinary)
print "I took away", firstByte
print "And now I'm left with", nBinary
return nBinary
# Wraps several functions to split
# the "steps" integer into bytes ready for sending
# Then it write packet header (255) and then
# all the other bytes
'''The final move command. I combines all the other functions in this
module to move the motor to the specified position'''
def position(num,degsPerStepFloat,stepsFloat):
steps = int(stepsFloat / degsPerStepFloat)
if(steps < 65535 and steps > -1):
binary = motor.d2b(steps)
numBytes = motor.binaryCount(binary)
# from the shiftLef def
ser.write(chr(255))
# note: the 2 in (0,2,1) is critical for alowing two bytes through every time.
for i in range(0,2,1):
sBinary = str(binary)
firstByte = int(sBinary,2) & int('11111111',2)
newBinary = int(sBinary,2) >> 8
binary = motor.d2b(newBinary)
ser.write(chr(firstByte))
if(steps > -65535 and steps < 0):
stepsNeg = steps * -1
binary = motor.d2b(stepsNeg)
numBytes = motor.binaryCount(binary)
# from the shiftLef def
ser.write(chr(220))
# note: the 2 in (0,2,1) is critical for alowing two bytes through every time.
for i in range(0,2,1):
sBinary = str(binary)
firstByte = int(sBinary,2) & int('11111111',2)
newBinary = int(sBinary,2) >> 8
binary = motor.d2b(newBinary)
ser.write(chr(firstByte))
return stepsFloat
hooray!
################################################
# Module: motor.py
# Created: 21 April 2009
# Author: Daniel Thompson
# http://danthompsonsblog.blogspot.com/
# Version: 0.2
# License: GPLv3
# http://www.fsf.org/licensing/
'''Provides a serial connection abstraction layer
for use with Arduino "MultipleSteppers" sketch.
'''
################################################
import motor
import serial
#setup the serial port
usbport = 'COM4'
ser = serial.Serial(usbport, 115200, timeout=1)
# convert a decimal (denary, base 10) integer to a binary string (base 2)
def d2b(n):
'''convert denary integer n to binary string bStr'''
bStr = ''
if n < 0: raise ValueError, "must be a positive integer"
if n == 0:
return '0'
while n > 0:
bStr = str(n % 2) + bStr
n = n >> 1
return bStr
'''Returns the number of bit bytes (eighths) in binary string.
Always rounds up, never rounds down.'''
def binaryCount(number):
sNumber = str(number)
length = len(sNumber)
numBytes = length / 8.0
numBytesInt = length / 8
if numBytes > numBytesInt:
return numBytesInt + 1
else:
return numBytesInt
'''This function gets the first byte, removes it from the string and
returns a new value'''
def shiftLeft(binary):
sBinary = str(binary)
firstByte = int(sBinary,2) & int('11111111',2)
newBinary = int(sBinary,2) >> 8
nBinary = motor.d2b(newBinary)
print "I took away", firstByte
print "And now I'm left with", nBinary
return nBinary
# Wraps several functions to split
# the "steps" integer into bytes ready for sending
# Then it write packet header (255) and then
# all the other bytes
'''The final move command. I combines all the other functions in this
module to move the motor to the specified position'''
def position(num,degsPerStepFloat,stepsFloat):
steps = int(stepsFloat / degsPerStepFloat)
if(steps < 65535 and steps > -1):
binary = motor.d2b(steps)
numBytes = motor.binaryCount(binary)
# from the shiftLef def
ser.write(chr(255))
# note: the 2 in (0,2,1) is critical for alowing two bytes through every time.
for i in range(0,2,1):
sBinary = str(binary)
firstByte = int(sBinary,2) & int('11111111',2)
newBinary = int(sBinary,2) >> 8
binary = motor.d2b(newBinary)
ser.write(chr(firstByte))
if(steps > -65535 and steps < 0):
stepsNeg = steps * -1
binary = motor.d2b(stepsNeg)
numBytes = motor.binaryCount(binary)
# from the shiftLef def
ser.write(chr(220))
# note: the 2 in (0,2,1) is critical for alowing two bytes through every time.
for i in range(0,2,1):
sBinary = str(binary)
firstByte = int(sBinary,2) & int('11111111',2)
newBinary = int(sBinary,2) >> 8
binary = motor.d2b(newBinary)
ser.write(chr(firstByte))
return stepsFloat
Arduino
################################################
# Module: motor.py
# Created: 21 April 2009
# Author: Daniel Thompson
# http://danthompsonsblog.blogspot.com/
# Version: 0.2
# License: GPLv3
# http://www.fsf.org/licensing/
'''Provides a serial connection abstraction layer
for use with Arduino "MultipleSteppers" sketch.
'''
################################################
import motor
import serial
#setup the serial port
usbport = 'COM4'
ser = serial.Serial(usbport, 115200, timeout=1)
# convert a decimal (denary, base 10) integer to a binary string (base 2)
def d2b(n):
'''convert denary integer n to binary string bStr'''
bStr = ''
if n < 0: raise ValueError, "must be a positive integer"
if n == 0:
return '0'
while n > 0:
bStr = str(n % 2) + bStr
n = n >> 1
return bStr
'''Returns the number of bit bytes (eighths) in binary string.
Always rounds up, never rounds down.'''
def binaryCount(number):
sNumber = str(number)
length = len(sNumber)
numBytes = length / 8.0
numBytesInt = length / 8
if numBytes > numBytesInt:
return numBytesInt + 1
else:
return numBytesInt
'''This function gets the first byte, removes it from the string and
returns a new value'''
def shiftLeft(binary):
sBinary = str(binary)
firstByte = int(sBinary,2) & int('11111111',2)
newBinary = int(sBinary,2) >> 8
nBinary = motor.d2b(newBinary)
print "I took away", firstByte
print "And now I'm left with", nBinary
return nBinary
# Wraps several functions to split
# the "steps" integer into bytes ready for sending
# Then it write packet header (255) and then
# all the other bytes
'''The final move command. I combines all the other functions in this
module to move the motor to the specified position'''
def position(num,degsPerStepFloat,stepsFloat):
steps = int(stepsFloat / degsPerStepFloat)
if(steps < 65535 and steps > -1):
binary = motor.d2b(steps)
numBytes = motor.binaryCount(binary)
# from the shiftLef def
ser.write(chr(255))
# note: the 2 in (0,2,1) is critical for alowing two bytes through every time.
for i in range(0,2,1):
sBinary = str(binary)
firstByte = int(sBinary,2) & int('11111111',2)
newBinary = int(sBinary,2) >> 8
binary = motor.d2b(newBinary)
ser.write(chr(firstByte))
if(steps > -65535 and steps < 0):
stepsNeg = steps * -1
binary = motor.d2b(stepsNeg)
numBytes = motor.binaryCount(binary)
# from the shiftLef def
ser.write(chr(220))
# note: the 2 in (0,2,1) is critical for alowing two bytes through every time.
for i in range(0,2,1):
sBinary = str(binary)
firstByte = int(sBinary,2) & int('11111111',2)
newBinary = int(sBinary,2) >> 8
binary = motor.d2b(newBinary)
ser.write(chr(firstByte))
return stepsFloat
Arduino Code
################################################
# Module: motor.py
# Created: 21 April 2009
# Author: Daniel Thompson
# http://danthompsonsblog.blogspot.com/
# Version: 0.2
# License: GPLv3
# http://www.fsf.org/licensing/
'''Provides a serial connection abstraction layer
for use with Arduino "MultipleSteppers" sketch.
'''
################################################
import motor
import serial
#setup the serial port
usbport = 'COM4'
ser = serial.Serial(usbport, 115200, timeout=1)
# convert a decimal (denary, base 10) integer to a binary string (base 2)
def d2b(n):
'''convert denary integer n to binary string bStr'''
bStr = ''
if n < 0: raise ValueError, "must be a positive integer"
if n == 0:
return '0'
while n > 0:
bStr = str(n % 2) + bStr
n = n >> 1
return bStr
'''Returns the number of bit bytes (eighths) in binary string.
Always rounds up, never rounds down.'''
def binaryCount(number):
sNumber = str(number)
length = len(sNumber)
numBytes = length / 8.0
numBytesInt = length / 8
if numBytes > numBytesInt:
return numBytesInt + 1
else:
return numBytesInt
'''This function gets the first byte, removes it from the string and
returns a new value'''
def shiftLeft(binary):
sBinary = str(binary)
firstByte = int(sBinary,2) & int('11111111',2)
newBinary = int(sBinary,2) >> 8
nBinary = motor.d2b(newBinary)
print "I took away", firstByte
print "And now I'm left with", nBinary
return nBinary
# Wraps several functions to split
# the "steps" integer into bytes ready for sending
# Then it write packet header (255) and then
# all the other bytes
'''The final move command. I combines all the other functions in this
module to move the motor to the specified position'''
def position(num,degsPerStepFloat,stepsFloat):
steps = int(stepsFloat / degsPerStepFloat)
if(steps < 65535 and steps > -1):
binary = motor.d2b(steps)
numBytes = motor.binaryCount(binary)
# from the shiftLef def
ser.write(chr(255))
# note: the 2 in (0,2,1) is critical for alowing two bytes through every time.
for i in range(0,2,1):
sBinary = str(binary)
firstByte = int(sBinary,2) & int('11111111',2)
newBinary = int(sBinary,2) >> 8
binary = motor.d2b(newBinary)
ser.write(chr(firstByte))
if(steps > -65535 and steps < 0):
stepsNeg = steps * -1
binary = motor.d2b(stepsNeg)
numBytes = motor.binaryCount(binary)
# from the shiftLef def
ser.write(chr(220))
# note: the 2 in (0,2,1) is critical for alowing two bytes through every time.
for i in range(0,2,1):
sBinary = str(binary)
firstByte = int(sBinary,2) & int('11111111',2)
newBinary = int(sBinary,2) >> 8
binary = motor.d2b(newBinary)
ser.write(chr(firstByte))
return stepsFloat
fixed??
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
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
################################################
# Module: motor.py
# Created: 21 April 2009
# Author: Daniel Thompson
# http://danthompsonsblog.blogspot.com/
# Version: 0.2
# License: GPLv3
# http://www.fsf.org/licensing/
'''Provides a serial connection abstraction layer
for use with Arduino "MultipleSteppers" sketch.
'''
################################################
import motor
import serial
#setup the serial port
usbport = 'COM4'
ser = serial.Serial(usbport, 115200, timeout=1)
# convert a decimal (denary, base 10) integer to a binary string (base 2)
def d2b(n):
'''convert denary integer n to binary string bStr'''
bStr = ''
if n < 0: raise ValueError, "must be a positive integer"
if n == 0:
return '0'
while n > 0:
bStr = str(n % 2) + bStr
n = n >> 1
return bStr
'''Returns the number of bit bytes (eighths) in binary string.
Always rounds up, never rounds down.'''
def binaryCount(number):
sNumber = str(number)
length = len(sNumber)
numBytes = length / 8.0
numBytesInt = length / 8
if numBytes > numBytesInt:
return numBytesInt + 1
else:
return numBytesInt
'''This function gets the first byte, removes it from the string and
returns a new value'''
def shiftLeft(binary):
sBinary = str(binary)
firstByte = int(sBinary,2) & int('11111111',2)
newBinary = int(sBinary,2) >> 8
nBinary = motor.d2b(newBinary)
print "I took away", firstByte
print "And now I'm left with", nBinary
return nBinary
# Wraps several functions to split
# the "steps" integer into bytes ready for sending
# Then it write packet header (255) and then
# all the other bytes
'''The final move command. I combines all the other functions in this
module to move the motor to the specified position'''
def position(num,degsPerStepFloat,stepsFloat):
steps = int(stepsFloat / degsPerStepFloat)
if(steps < 65535 and steps > -1):
binary = motor.d2b(steps)
numBytes = motor.binaryCount(binary)
# from the shiftLef def
ser.write(chr(255))
# note: the 2 in (0,2,1) is critical for alowing two bytes through every time.
for i in range(0,2,1):
sBinary = str(binary)
firstByte = int(sBinary,2) & int('11111111',2)
newBinary = int(sBinary,2) >> 8
binary = motor.d2b(newBinary)
ser.write(chr(firstByte))
if(steps > -65535 and steps < 0):
stepsNeg = steps * -1
binary = motor.d2b(stepsNeg)
numBytes = motor.binaryCount(binary)
# from the shiftLef def
ser.write(chr(220))
# note: the 2 in (0,2,1) is critical for alowing two bytes through every time.
for i in range(0,2,1):
sBinary = str(binary)
firstByte = int(sBinary,2) & int('11111111',2)
newBinary = int(sBinary,2) >> 8
binary = motor.d2b(newBinary)
ser.write(chr(firstByte))
return stepsFloat
tester
#!/usr/bin/env python
import sys
import traceback
import utils
from bin.server import LearndServer
if __name__ == '__main__':
learnd = LearndServer( )
try:
learnd.run()
except KeyboardInterrupt:
utils.log("KeyboardInterrupt - Exiting.")
learnd.close()
except:
traceback.print_exc()
utils.log("Exiting.")
learnd.close()
Subscribe to:
Posts (Atom)