- getting started
- classroom assignments
- python
- collaboration tool: live share scripts in vscode
- Presentations
- Frequently asked questions
All relevant links for this course are collected at a single website: https://ctl.polyphys.mat.ethz.ch/, which you may bookmark.
Visit www.github.com and sign in, if you have already an account, or Sign up and create an account. You can choose your institutional email address to create an account. Check your settings like email notifactions etc. under 'Settings'.
The following instructions reflect our recommendations on how to install a functional python environment with git integration in VS Code for working with github classroom. If you already have an environment which meets these requirements, you can ignore the instructions, but understand that we might not be able to provide assistance if you run into problems. Click on the following images if you need to enlarge them.
- Check, if you have anaconda (or miniconda) installed already. If so, start the anaconda navigator and check if VS Code is one of the existing applications (or search for visual studio code/VS Code/vscode on your computer). If both are true, continue at 5. If you are missing VS Code in your anaconda navigator, close the navigator and continue at 3. Otherwise continue.
- You have neither anaconda nor miniconda installed. Install anaconda 2.4.3 or later (not miniconda) from https://anaconda.com/download (Requires 5GB of disk space. Additional information at https://docs.anaconda.com/free/anaconda/install). Once installed successfully, start the anaconda navigator (You do not need to create an anaconda cloud account and can skip this question). Check if VS Code is an installed application , if you cannot find the VS Code symbol in the list, then you need to close the anaconda navigator and continue at 3. Otherwise launch VS Code and continue at 5.
- You need to install VS Code, hence visit http://code.visualstudio.com/download and download and install VS Code. When asked for, choose "Add to PATH", which is the default. Once installed, do not start VS Code or exit if you opened it already (On MacOS you should move the application from your download folder to your applications folder).
- Now start the anaconda navigator again. You should have VS Code in the list of applications. Launch VS Code. Just in case you have several versions of python installed (older versions, from a previous install): you might need to manually link the python extension with the python installation from anaconda (or miniconda). The walkthrough on the VS code start screen will prompt you to select the interpreter, if you indeed have several versions installed, otherwise not. Simply choose the option containing "('base')" which is the default installation for anaconda (and miniconda).
- Within VS Code, open a terminal from the top menu bar . Click into the terminal window, write "conda install git" and press enter. Answer questions with yes, if there are any.
- Within VS Code, click on the Extensions symbol in the menu bar on the left, and search for "Github Pull Requests and Issues". Click the blue 'install' buttom (in the screenshot it is not visible as I have it already installed), and once installed, close the VS Code application.
- Start VS Code again. This time, you should see a blue (1) at the accounts symbol in the menu bar on the left. Click on it, and choose "Sign in with Github ..". If nothing works, be patient, check if there are more than one VS Code screen open now, and eventually choose one of the options (like local server) that are offered to sign in. Once you are signed in, the blue (1) does not appear anymore, and if you press the accounts symbol again, it should show your github name.
- Within VS Code, click on the Extensions symbol (shown above), and search for "Github Classroom" Click the blue 'install' buttom. Ignore the Warning "This extension is depreciated"!
- VS Code asks you again (blue 1 at the accounts symbol ) for permission to connect with github. Once connected, and if there are no remaining blue numbers in the left panel, click on the github symbol . Ideally, VS Code tells that you have not yet accepted any assignments. If you see this message, you are almost done.
- Within VS Code, click on the (well known) Extensions symbol in the menu bar on the left, and search for "Python" (from Microsoft). Click 'install'. To verify the installation you should follow along with the last three minutes of this video (https://youtu.be/HvAjnpA6mlA?t=282). Having installed anaconda you should also select the interpreter called 'base'. We will check in the first lecture if you can successfully print text to the command line.
- Done! You successfully completed the whole setup and can close VS Code and anaconda. You have now installed: anaconda, python, git, VS Code, and you have a github account, and are ready to accept a classroom assignment.
If you would like some additional guidance during the installation process, we recommend the following two videos for installing anaconda (https://www.youtube.com/watch?v=xfAcErzOKN4) and VS Code (https://www.youtube.com/watch?v=HvAjnpA6mlA). The creator, Luke Barousse, uses many similar tools and a very similar installation process. However, the installation of github is not covered in these videos (points 6 through 9 above). If you are interested in a more thorough introduction to VS Code, we can recommend the following video (https://www.youtube.com/watch?v=UuwlySU7Hjg) from the same series.
If you encounter any problems during the installation process, do not hesitate to reach out to us via email or approach us in person. We can try to assist you via email or arrange a one on one meeting.
Additional steps that can be done during the first CTL lecture, after having accepted your first classroom assignment.
-
Open a Terminal in VS code as described above. Type python --version (enter), and git --version (enter) to see if python and git are installed.
-
To finish the git configuration, execute the following commands within the Terminal, where you have to choose a XXX name (no blanks or special characters), and enter your email address:
git config --global user.name "XXX"
git config --global user.email XXX@YYY
-
Within VS Code. Choose File and New File from the menu bar. Select 'Python file' from the options. Enter a command like print("hello"), and then press the small triangle in the top right corner of the VS code window to save (with extension .py) and run your python file.
-
Within VS code, close Folder (if you have an open folder), then click the Github symbol . You should see the classroom folder.
You will receive an invitation for each assignment by email. Accept the assignment and choose from the existing groups, if you'd like to join any of the existing groups, or create a new group (with a science/lecture-related name, no special characters, no blanks). Upon acceptance, you will find a new repository in your personal GitHub account. If you cannot find any place in any of the existing groups and want to create a new group, while the maximum number of groups has been reached already, please send an email. To check if it worked, login to www.github.com, click your github symbol. Check your profile. Check if you are member of the CTL organization and member of a group. If not, contact us.
deal with classroom assignments in vscode
Start vscode. To manage your classroom assignments, click the GitHub symbol in the left taskbar, sign in to GitHub. To find your classroom assignment, click on the GitHub symbol in the vscode menu bar on the left. Select and open your assignment, find your files (click on the folder symbol after the assignment to open the folder), edit them or create a new file (File/New file/choose python). To commit your changes, save your file, then click the Source Control icon (Crtl-Shift-G). Leave a message for your commit. To see the rendered markdown README.md, click on README.md (or your own md-file), and then click 'Open Previes to the Side' (crtl+K followed by V). To see if your committed changes in VS code have been transferred to github, visit your corresponding repository at Github, and check the time stamp of the modified file (or its content). If your classroom folder is visible, but you do not see any files in it, either click the Explorer symbol (crtl-shift+E), or go to File / Close Folder (crtl+K F), and click the github symbol.
deal with classroom assignments at GitHub
Once you accepted an assignment, you will find a new repository in your personal GitHub. You do not need to use vscode to edit your codes, you can also edit them directly at GitHub, or clone the directory to a local directory, and edit from there using another software. Make sure to commit your changes directly to the main branch (or create a branch + pull request, if you want your group members or assistants review your changes, and if you know what you are doing). To find back (if needed) your assignment(s) at GitHub, click https://github.com/ETH-Computational-Thinking-Lab and then on the name of the assignment.
After editing a python script or markdown file, you commit your changes directly to the main branch and update the file or create a branch and pull request. If you go for a pull reuqest, leave a comment in the pull request if you have any particular question. Open pull requests are mentioned in the menu bar of your assignment. If you are assigned to review a pull request (most likely by email), or if you have the permission to review it, you can reject or merge a pull request to finally update the current script. At the 'branches' tab you can find the existing active branches, and also delete them, if they had been taken care of already.
All information about a project other than the script itself, such as goals, ideas, problems, results should be collected in the file report.md located at your GitHub assignment. All group members should be enabled to edit report.md. md-files are interpreted using the Markdown syntax at GitHub. A quick reference to the Markdown syntax is available at https://www.markdownguide.org/cheat-sheet/. To watch the report.md side-by-side with your code, split the window (top right), click on the report.md and press crtl+K followed by V to render the markdown file properly. To add an image to the report.md file, first upload the image file (say, myfile.png) to your repository. Then edit the report.md file and add
<img src="myfile.png" width=50%>
Cheat Sheets: https://cheatography.com/tag/-python/, https://www.pythoncheatsheet.org/
Make sure your python script have a name like script.py with proper extension py.
vscode: If you wish to open a new file and if python is not in the list, press crtl-shift-p and search for python: interpreter, and select from this list.
import sys
...
# the number of command line arguments is: len(sys.argv)-1
n = int(sys.argv[1])
If you are in vscode: Click on 'Terminal. If not, under windows: search and open Command Prompt. macos and linux: Open terminal window. Switch (cd) to the directory containing your script or provide the full path of your script. Enter
python3 [yourscript.py] [arguments]
Exit the interactive python3 via quit(). Display the exit value via
python3 [yourscript.py] [arguments]; echo $?
General structure of Python script that can be imported or reused and also executed from the command line
from sys import argv
def myfunction1 (a):
print("first (integer) argument is "+str(a))
def myfunction2 (a,b):
print("first (integer) argument is "+str(a))
print("2nd (float) argument is "+str(b))
# do the following if called from the command line
if len(argv)-1==1:
a = int(argv[1])
myfunction1(a)
elif len(argv)-1==2:
a = int(argv[1])
b = float(argv[2])
myfunction2(a,b)
import sys
...
sys.exit(13)
import sys
from sys import argv
def myfunction (a):
print("first (integer) argument is "+str(a))
b = 2*a
return b
# do the following if called from the command line
if len(argv)-1==1:
a = int(argv[1])
b = myfunction(a)
sys.exit(int(b))
import os.path
...
if os.path.isfile("myfile"):
...
import numpy as np
data = np.genfromtxt("tic-tac-toe.txt", dtype=np.int32)
data[0,0]=1
np.savetxt("tic-tac-toe.txt", data, fmt="%d")
import matplotlib.pyplot as plt
# assuming myarray (an array) carries your image
plt.imshow(myarray)
plt.savefig('mygraphics.png')
Calling python with the following options
python3 -m cProfile -o log.profiler mypthonscript.py
creates a file log.profiler that contains information about the cpu time spent in the several routines. This can be very useful to find the most time-consuming parts of your code.
import matplotlib.pyplot as plt
import numpy as np
# importing movie py libraries
from moviepy.editor import VideoClip
from moviepy.video.io.bindings import mplfig_to_npimage
# numpy array
x = np.linspace(-2, 2, 200)
# duration of the video in seconds
duration = 2
# matplot subplot
fig, ax = plt.subplots()
# method to get frames
def make_frame(t):
# clear
ax.clear()
# plotting line
ax.plot(x, np.sinc(x**2) + np.sin(x + 2 * np.pi / duration * t), lw = 3)
ax.set_ylim(-1.5, 2.5)
# returning numpy image
return mplfig_to_npimage(fig)
# creating animation
animation = VideoClip(make_frame, duration = duration)
# displaying animation with auto play and looping
animation.ipython_display(fps = 20, loop = True, autoplay = True)
https://www.youtube.com/watch?v=ZDa-Z5JzLYM
windows, macos, linux: download from https://docs.conda.io/en/latest/miniconda.html
Miniconda is a free minimal installer for conda. It is a small, bootstrap version of Anaconda that includes only conda, Python, the packages they depend on, and a small number of other useful packages, including pip, zlib and a few others. Choose install 'just for me' and 'add to path' during installation! Use the conda install command (now or later from within the vscode Terminal) to install additional packages like numpy or matplotlib.
In some cases the library you want to use does not run under the python version you installed. You can use older python version or older packages quite easily in vscode with the help of a single conda command as shown below. By default, environments are installed into the envs directory in your conda directory. Run conda create --help for information on specifying a different path. Below, replace myenv by with a unique name of your new (optional) environment. Open a command prompt and execute
conda create -n myenv python=3.7
or
conda create -n myenv python=3.7 scipy=0.17.3 astroid babel
This will create a new directory myenv in your conda/envs directory. Start vscode. Press ctrl-alt-p and search for: python: select interpreter. Choose myenv from the list, if you prefer to use myenv in your current project.
You can edit your python script simultaneously with group members or let them just read and comment on your code from within vscode + live share. If the code is located at GitHub, all group members can open it from there and commit their modified codes.
- click on the Extensions symbol in the left taskbar (Crtl-shift-X). Search for VS live share. Choose the version from Microsoft, install.
In vscode, click the Live Share icon in the left taskbar. Click Share to share the file or folder you are editing. Follow the instruction and send the invitation to one or more group members, assistants, lecturer (email, skype etc). You can allow the invited person to read only or to edit your file. If you are receiving the invitation, follow the link and accept the invitation (you can join either by the vscode web interface or by your locally installed vscode). The inviting person will then let you in. You can add comments to the open files, chat etc. and change the file if you have the permission.
Towards the end of the semester, each group presents its work during a 8 minutes talk. During these 8 minutes, group members should equally contribute to the presentation. The presentation should include the following:
- how did the group work together (communication channel)
- how did we approach the problems stated by the assignments (ideas)
- did we encounter problems, and eventually solved them, and how?
- how have individual functions been tested (example)?
- how did we test the code?
- Selected results obtained with the codes
- If you like: Criticism, suggestions for improvements
DO NOT:
- repeat the task descriptions
- show your code (only a few lines, if meaningful)
Collect all your slides on one of your laptops, and save the presentation also on a stick (or at one of your github repositories).