From 1429fcf76f059f302ad0f7ea916603cc81f4447f Mon Sep 17 00:00:00 2001 From: Sebastian Plamauer Date: Mon, 5 May 2014 11:14:11 -0700 Subject: [PATCH] fixed code blocks --- Examples.md | 38 ++++++++++++++++++++------------------ 1 file changed, 20 insertions(+), 18 deletions(-) diff --git a/Examples.md b/Examples.md index 649e87a..099dc50 100644 --- a/Examples.md +++ b/Examples.md @@ -12,16 +12,18 @@ In this example we wan't to log the data from the accelerometer to a file on the Now ,the first problem with that is, that when the pyboard is connected to the computer, the computer mounts the filesystem. At the same time, the microcontroller is using the filesystem which results in broken files. So what we have to do is to tell the pyboard to NOT act as mass storage device, so the filesystem isn't mounted. To do that, we change boot.py. boot.py is the first script that is run after boot. -`# boot.py -- runs on boot-up +``` +# boot.py -- runs on boot-up import pyb -pyb.usb_mode('CDC+HID')` +pyb.usb_mode('CDC+HID') +``` `import pyb` imports the pyb module, that let's you access the functions and methods for controlling the pyboard. `pyb.usb_mode()` let's you set as what kind of device the pyboard should act if connected to USB. `'CDC+HID'` means 'Human Interface Device' - in this mode the board is recognized as if it where a mouse or keyboard. In this example, this only means that it is NOT recognized as mass storage device, so the file system doesn't get mounted. The problem is, now we can't access the filesystem anymore, so you'd have to remove the SD-card and put it into a SD-card reader to get back your data or to change the scripts again. Now, if we set `pyb.usb_mode()` back to `'CDC+MSC'`, the pyboard would act as SD-card reader. So, we use the switch to change between these modes. After reset, you have a short time window. If the switch is pressed and hold, the board acts as mass storage, if not it acts as Human Interface Device. -` +``` # boot.py -- runs on boot-up import pyb @@ -39,45 +41,45 @@ else: pyb.usb_mode('CDC+HID') pyb.LED(4).off() # indicate that we finished selecting the mode -` +``` So, now when the switch was pressed, we can access the data, if not, the filesystem is left untouched by the computer and only used by the microcontroller. But until now, the board only switches its states, but doesn't do anything else. Using `pyb.main()`, we can tell the microcontroller which script to execute after 'boot.py'. If we chose HID-mode, we wan't to log data, so we call a script called 'datalogger.py'. If the cardreader-mode was selected, we call 'cardreader.py'. So we add these calls to the if-clauses: -` +``` if switch_value: pyb.usb_mode('CDC+MSC') **pyb.main('cardreader.py')** # if switch was pressed - cardreader-mode else: pyb.usb_mode('CDC+HID') **pyb.main('datalogger.py')** # if switch wasn't pressed - datalogger-mode -` +``` 'cardreader.py' can be empty, it doesn't have to do anything. We just want't to use the filesystem. 'datalogger.py' contains the actual script for logging the data. We `import pyb` again and create objects of the stuff we want to use. -` +``` import pyb # creating objects accel = pyb.Accel() # accelerometer object blue = pyb.LED(4) # LED object switch = pyb.Switch() # switch object -` +``` Now we need to get the data and write it to a file. -` +``` log = open('1:/log.csv', 'w') # open file on SD (SD: '1:/', flash: '0/) t = pyb.millis() # get time x, y, z = accel.filtered_xyz() # get acceleration data log.write('{},{},{},{}\n'.format(t,x,y,z)) # write data to file log.close() # close file -` +``` This would measure only one time, but we want to have a continuous measurement, so we put it in loop that runs forever. -` +``` **while True:** # runs forever log = open('1:/log.csv', 'w') # open file on SD (SD: '1:/', flash: '0/) @@ -85,11 +87,11 @@ This would measure only one time, but we want to have a continuous measurement, x, y, z = accel.filtered_xyz() # get acceleration data log.write('{},{},{},{}\n'.format(t,x,y,z)) # write data to file log.close() # close file -` +``` Still not there. This way, the file would be opened and closed every time the loop runs. Also, the file would be overwritten every time. And if we disconnect the power with the file still being open, it will get corrupted. So let's use the user switch to start and end a loop. If the switch is pressed, the file is opened and data is written to it. When it get's pressed again, the file is closed. -` +``` while True: # start if switch is pressed @@ -104,11 +106,11 @@ while True: # end after switch is pressed again log.close() # close file -` +``` If you try that, you will run into another problem. If you press the switch, the write loop will start immediately. This loop also checks if the switch is pressed, so unlike you get your fingers off the switch _really_ quickly, it will detect the switch as pressed. To avoid that, we add a `pyb.delay(200)`. That will pause the board for 200 milliseconds (0.2 seconds), which gives you enough time to get your hands of the switch. We need to call that every time between `switch()` is called. We also add the blue LED now. It is on as long as the file is open. -` +``` # start if switch is pressed if switch(): **pyb.delay(200)** # delay avoids detection of multiple presses @@ -125,11 +127,11 @@ If you try that, you will run into another problem. If you press the switch, the log.close() # close file **blue.off()** # blue LED indicates file closed **pyb.delay(200)** # delay avoids detection of multiple presses -` +``` Now, as long as the switch wasn't pressed, the board doesn't have to do anything. To save power, there is the `pyb.wfi()` function. It makes the board wait for an interrupt (i.e. a button press). As long it is waiting, it is in power saving mode. We add that as first item in the outer while loop so our script finally looks like this: -` +``` # datalogger.py # Logs the data from the acceleromter to a file on the SD-card @@ -163,6 +165,6 @@ while True: log.close() # close file blue.off() # blue LED indicates file closed pyb.delay(200) # delay avoids detection of multiple presses -` +``` So, now you have a datalogger, that can also act as cardreader. Connect a battery and throw the board up in the air. If you see (almost) zero acceleration during the time the board flew through the air, there was no error, you just discovered micro gravity during free fall. \ No newline at end of file