diff --git a/Labs/Lab.1/Lab 1 Solutions.ipynb b/Labs/Lab.1/Lab 1 Solutions.ipynb new file mode 100644 index 0000000..66712dd --- /dev/null +++ b/Labs/Lab.1/Lab 1 Solutions.ipynb @@ -0,0 +1,2058 @@ +{ + "nbformat": 4, + "nbformat_minor": 0, + "metadata": { + "colab": { + "name": "Copy of Lab-1.ipynb", + "provenance": [], + "collapsed_sections": [] + }, + "kernelspec": { + "display_name": "Python 3", + "language": "python", + "name": "python3" + }, + "language_info": { + "codemirror_mode": { + "name": "ipython", + "version": 3 + }, + "file_extension": ".py", + "mimetype": "text/x-python", + "name": "python", + "nbconvert_exporter": "python", + "pygments_lexer": "ipython3", + "version": "3.8.0" + } + }, + "cells": [ + { + "cell_type": "markdown", + "metadata": { + "colab_type": "text", + "id": "O5vg8KKRq0sy" + }, + "source": [ + "# Lab 1\n", + "\n", + "## Python Notebooks on Google Colab\n", + "\n", + "Data 1401's Labs, Homework, and Exams will be all in form of iPython notebooks. You may already be familiar with python notebooks if you have used Jupyter before. If so, you are welcome to use whatever means you have to run Jupyter notebooks for this course, though you may get limited support. Our primary means of running python notebooks will be through [Google Colab](https://colab.research.google.com). You may also choose to store your files on google drive.\n", + "\n", + "You will need a google account. If you do not have one or you wish to use a different account for this course, please follow [these instructions](https://edu.gcfglobal.org/en/googledriveanddocs/getting-started-with-google-drive/1/) to make an account.\n", + "\n", + "Once you are ready with your account, you can continue in Colab. Click on the following badge to open this notebook in Colab:\n", + "\n", + "[![Open In Colab](https://colab.research.google.com/assets/colab-badge.svg)](https://colab.research.google.com/github/UTA-DataScience/DATA1401.2020.Fall/blob/master/Labs/Lab.1/Lab.1.ipynb)\n" + ] + }, + { + "cell_type": "code", + "metadata": { + "id": "kk0NnGoLYGJG", + "colab_type": "code", + "colab": { + "base_uri": "https://localhost:8080/", + "height": 162 + }, + "outputId": "0f48ef0a-c0df-4971-c03f-eb2d6ef58b7b" + }, + "source": [ + "echo" + ], + "execution_count": 1, + "outputs": [ + { + "output_type": "error", + "ename": "NameError", + "evalue": "ignored", + "traceback": [ + "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m", + "\u001b[0;31mNameError\u001b[0m Traceback (most recent call last)", + "\u001b[0;32m\u001b[0m in \u001b[0;36m\u001b[0;34m()\u001b[0m\n\u001b[0;32m----> 1\u001b[0;31m \u001b[0mecho\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m", + "\u001b[0;31mNameError\u001b[0m: name 'echo' is not defined" + ] + } + ] + }, + { + "cell_type": "markdown", + "metadata": { + "colab_type": "text", + "id": "FVt_1hPt1dAK" + }, + "source": [ + "## Notebooks in Colab\n", + "\n", + "You now are presumably in Colab. Word of caution, by default, Google Colab does not save your notebooks, so if you close your session, you will loose your work.\n", + "\n", + "So first thing: from the file menu above select \"Save a copy in Drive\"." + ] + }, + { + "cell_type": "markdown", + "metadata": { + "colab_type": "text", + "id": "x0JBL_RFrDDj" + }, + "source": [ + "## Storing Notebooks in Google Drive (Optional)\n", + "If you like, you may save your notebooks directly into Google Drive and upload directly to Git (where you will be downloading and uploading your homework). In order properly setup Git, we'll need to work more directly in your Google Drive.\n", + "\n", + "On the left sidebar, press the file icon to see a listing of files accessibile to this Notebook. Then press \"Mount Drive\" and follow the instructions to mount your Google Drive in this notebook. A new cell will be inserted into this notebook, which after you run by pressing the play button will instruct you to follow a link to log into your Google Account and enable access to your Drive in another tab. Finally you will copy a link from the new tab back into the cell in this notebook. Once you are done, press refresh under files in the left sidebar and you should have \"drive/My Drive\" appear." + ] + }, + { + "cell_type": "markdown", + "metadata": { + "colab_type": "text", + "id": "hwJ6wJk3tiLv" + }, + "source": [ + "## Github\n", + "All the class material will be stored on github. You will also submit your homework using github. To do so, you will need a github account.\n", + "\n", + "If you do not already have a github account or wish to create a new one for this course, create one:\n", + "* Browse to [github.com](https://github.com).\n", + "* Click the green “Sign up for GitHub”\tbutton.\n", + "* Follow instructions for creating an account.\n", + "* Make sure you remember your github username and password.\n", + "\n", + "Write an email to the course Instructor titled \"Data 1401: Github account\" with your github username (not your password) as the contents.\n", + "\n", + "## Google Groups\n", + "\n", + "Class annoucements will be made via google groups. If you did not already receive an invite to the class google group, had trouble with the invite, or wish to use a different email address, write an email to the course TA titled \"Data 1401: Google Group\" with your preferred email.\n" + ] + }, + { + "cell_type": "markdown", + "metadata": { + "colab_type": "text", + "id": "TjfIzdQZqvzk" + }, + "source": [ + "## Introduction: Unix, Git, and Jupyter\n", + "\n", + "This lab aims to introduce you to basic Unix, familiarize you with iPython notebooks and get you setup to submit your homework.\n" + ] + }, + { + "cell_type": "markdown", + "metadata": { + "colab_type": "text", + "id": "C_LmOgzFqvzp" + }, + "source": [ + "\n", + "\n", + "### Terminal, Shell, and ssh\n", + "\n", + "\n", + "The terminal is a simple program that generally runs another program, taking mostly keyboard input from you, passing it to this other program, and taking the output of the program and displaying on the screen for you.\n", + "\n", + "The terminal usually runs a program called a shell. Shells present a command prompt where you can type in commands, which are then executed when you press enter. In most shells, there are some special commands which the shell will execute. Everything else you type in, the shell will assume is a name of a program you want to run and arguments you want to pass that program. So if the shell doesn't recognize something you type in, it'll try to find a program with a name that is the same as the first word you gave it. \n", + "\n", + "### Shell in Colab\n", + "\n", + "Unfortunately, google Colab does not allow you to open a terminal window. Jupyter does, so if you are running in Jupyter (which most of you will not be), you may choose to open a terminal window by returning to the jupyter file list tab and selecting new terminal from the top right.\n", + "\n", + "For Colab, we will have to do something non-ideal, but functional. There are several ways to execute shell commands from within a python notebook. For example, you can use any shell command by putting \"!\" in front of the command:\n", + "\n", + "\n", + "\n" + ] + }, + { + "cell_type": "code", + "metadata": { + "colab_type": "code", + "id": "KJ5f-WO0wcAv", + "colab": { + "base_uri": "https://localhost:8080/", + "height": 101 + }, + "outputId": "580fffd0-1896-45fc-a8ef-4c7c8bbc2501" + }, + "source": [ + "!ls\n", + "!echo \"----------\"\n", + "!ls sample_data" + ], + "execution_count": 3, + "outputs": [ + { + "output_type": "stream", + "text": [ + "sample_data\n", + "----------\n", + "anscombe.json\t\t mnist_test.csv\n", + "california_housing_test.csv mnist_train_small.csv\n", + "california_housing_train.csv README.md\n" + ], + "name": "stdout" + } + ] + }, + { + "cell_type": "markdown", + "metadata": { + "colab_type": "text", + "id": "8f-n4AXFw-dD" + }, + "source": [ + "Unfortunately, every time you use \"!\" a new environment is created and the state reverted to the original state. Try to understand the difference between the following two sets of commands:\n" + ] + }, + { + "cell_type": "code", + "metadata": { + "colab_type": "code", + "id": "99nrBYTWxZJr", + "colab": { + "base_uri": "https://localhost:8080/", + "height": 67 + }, + "outputId": "6c281b71-b927-43a6-e049-3b8932304536" + }, + "source": [ + "!echo \"Technique 1:\"\n", + "!ls\n", + "!cd sample_data\n", + "!ls" + ], + "execution_count": 4, + "outputs": [ + { + "output_type": "stream", + "text": [ + "Technique 1:\n", + "sample_data\n", + "sample_data\n" + ], + "name": "stdout" + } + ] + }, + { + "cell_type": "code", + "metadata": { + "colab_type": "code", + "id": "2-Znf97Lxl-Z", + "colab": { + "base_uri": "https://localhost:8080/", + "height": 101 + }, + "outputId": "419258a0-3040-4e98-cd91-11baa7b09729" + }, + "source": [ + "!echo \"Technique 2:\"\n", + "!ls ; cd sample_data ;ls" + ], + "execution_count": 5, + "outputs": [ + { + "output_type": "stream", + "text": [ + "Technique 2:\n", + "sample_data\n", + "anscombe.json\t\t mnist_test.csv\n", + "california_housing_test.csv mnist_train_small.csv\n", + "california_housing_train.csv README.md\n" + ], + "name": "stdout" + } + ] + }, + { + "cell_type": "markdown", + "metadata": { + "colab_type": "text", + "id": "4x9n1rAkxyYl" + }, + "source": [ + "Notebooks allow a bit of \"magic\" (using \"%\") to avoid some of these limitations:\n" + ] + }, + { + "cell_type": "code", + "metadata": { + "colab_type": "code", + "id": "vLBPTX4rx3gd", + "colab": { + "base_uri": "https://localhost:8080/", + "height": 118 + }, + "outputId": "e7f9de58-5e26-4dc3-e937-bb8ea4621652" + }, + "source": [ + "!echo \"Technique 3:\"\n", + "!ls \n", + "%cd sample_data \n", + "!ls" + ], + "execution_count": 6, + "outputs": [ + { + "output_type": "stream", + "text": [ + "Technique 3:\n", + "sample_data\n", + "/content/sample_data\n", + "anscombe.json\t\t mnist_test.csv\n", + "california_housing_test.csv mnist_train_small.csv\n", + "california_housing_train.csv README.md\n" + ], + "name": "stdout" + } + ] + }, + { + "cell_type": "markdown", + "metadata": { + "colab_type": "text", + "id": "U8XpvPjcyH0w" + }, + "source": [ + "For our purposes, we are just going to explicitly start a new shell and interact with it in the output cell. Execute the following cell. You will be able to type and execute commands. Look around a bit using \"ls\" and \"cd. You can stop the cell from running by typing \"exit\". You may also stop the shell by pressing play/stop button." + ] + }, + { + "cell_type": "code", + "metadata": { + "colab_type": "code", + "id": "MIDFitLZyuZy", + "colab": { + "base_uri": "https://localhost:8080/", + "height": 252 + }, + "outputId": "cb8ad2cf-ffae-437f-990a-13258a10c7b2" + }, + "source": [ + "!/bin/bash --noediting" + ], + "execution_count": 7, + "outputs": [ + { + "output_type": "stream", + "text": [ + "bash: cannot set terminal process group (101): Inappropriate ioctl for device\n", + "bash: no job control in this shell\n", + "\u001b]0;root@04c8ce3a6d36: /content/sample_data\u0007\u001b[01;32mroot@04c8ce3a6d36\u001b[00m:\u001b[01;34m/content/sample_data\u001b[00m# !ls\n", + "bash: !ls: event not found\n", + "\u001b]0;root@04c8ce3a6d36: /content/sample_data\u0007\u001b[01;32mroot@04c8ce3a6d36\u001b[00m:\u001b[01;34m/content/sample_data\u001b[00m# !echo \"Technique \"\n", + "bash: !echo: event not found\n", + "\u001b]0;root@04c8ce3a6d36: /content/sample_data\u0007\u001b[01;32mroot@04c8ce3a6d36\u001b[00m:\u001b[01;34m/content/sample_data\u001b[00m# echo \"technique\"\n", + "technique\n", + "\u001b]0;root@04c8ce3a6d36: /content/sample_data\u0007\u001b[01;32mroot@04c8ce3a6d36\u001b[00m:\u001b[01;34m/content/sample_data\u001b[00m# ls\n", + "\u001b[0m\u001b[01;32manscombe.json\u001b[0m mnist_test.csv\n", + "california_housing_test.csv mnist_train_small.csv\n", + "california_housing_train.csv \u001b[01;32mREADME.md\u001b[0m\n", + "\u001b]0;root@04c8ce3a6d36: /content/sample_data\u0007\u001b[01;32mroot@04c8ce3a6d36\u001b[00m:\u001b[01;34m/content/sample_data\u001b[00m# exit\n", + "exit\n" + ], + "name": "stdout" + } + ] + }, + { + "cell_type": "markdown", + "metadata": { + "colab_type": "text", + "id": "q-4hfZBywW25" + }, + "source": [ + "While in this instance your shell is running in a this notebook, you can also run terminals natively on your own computer. On Linux or MacOS, you just have to run a program called terminal. In Windows you can start a \"command prompt\". \n", + "\n", + "Type in \"ls\" into the terminal above and press enter. The shell will find a program called \"ls\", a standard tool in Unix, and run it. \"ls\" lists the contents (files and directories) of your current directory. \n", + "\n", + "For your reference, [Unix/Linux Command Reference](https://github.com/UTA-DataScience/VersionControlSystem/blob/master/VersionControlSystem/linuxRef.pdf) summarizes some of the common shell commands.\n", + "\n", + "A subtle point to realize here is that while the terminal is running in the browser that is running on the computer in front of you, the shell is actually running on a machine on google hardware. The shell prompt typically displays the name of the machine you are using. What you are not seeing is that there is an intermidate program between the terminal running on your computer and the shell running on google. This intermidary program is taking your input from the terminal sending it over the network to google and bringing back the responses for you terminal to display.\n", + "\n", + "A bit of extra information. If you start a terminal on your own computer, the shell runs locally. The \"ls\" command would then list contents of a directory on your computer. You can typically connect to Unix computers by evoking a shell running on that machine over the network. In this case, you would have to initiate this intermidiary program yourself. The program is called \"ssh\" (secure shell). You can \"ssh\" to another machine from your machine, by simply typing \"ssh\" followed by the machine name or IP address. Most likely you would be prompted for a password, after which you would dropped into the prompt of a shell running on the remote machine. \n" + ] + }, + { + "cell_type": "markdown", + "metadata": { + "colab_type": "text", + "id": "51Eya4LBqvzs" + }, + "source": [ + "## Programs and Environment Variables\n", + "\n", + "You have a listing of your current directory, but you don't know where that directory resides. You can see what directory you are using the command \"pwd\" (print working directory). Issue the command and look at the response. You'll get a slash (\"/\") separated list, known as the path, of the directory hierarchy of your current working directory. On Colab, this will start with \"contents\"\n", + "\n", + "Now back to thinking about the command prompt. Since \"ls\" is a program, it most be stored somewhere. It is clearly not in your working directory, because you didn't see it when you executed \"ls\". We can ask the shell to tell us where it found \"ls\" using the \"which ls\" command. Note that \"which\" is also a program. \"which ls\" comes back with \"/bin/ls\", telling you the \"ls\" program is sitting in \"/bin\" directory of the system. \n", + "\n" + ] + }, + { + "cell_type": "code", + "metadata": { + "id": "de7X-fUGYGJa", + "colab_type": "code", + "colab": { + "base_uri": "https://localhost:8080/", + "height": 34 + }, + "outputId": "2fd923db-964d-42b2-f02e-0c5784a635fd" + }, + "source": [ + "!which ls" + ], + "execution_count": 8, + "outputs": [ + { + "output_type": "stream", + "text": [ + "/bin/ls\n" + ], + "name": "stdout" + } + ] + }, + { + "cell_type": "markdown", + "metadata": { + "id": "qJdqxZ8sYGJd", + "colab_type": "text" + }, + "source": [ + "Lets see what else is in there by issuing a \"ls /bin\" command. " + ] + }, + { + "cell_type": "code", + "metadata": { + "id": "rSOTDfHdYGJd", + "colab_type": "code", + "colab": { + "base_uri": "https://localhost:8080/", + "height": 638 + }, + "outputId": "968bdda2-2037-45bf-dfc5-b1d4e91aa27e" + }, + "source": [ + "!ls /bin" + ], + "execution_count": 9, + "outputs": [ + { + "output_type": "stream", + "text": [ + "bash\t hostname su\n", + "bunzip2 journalctl sync\n", + "bzcat\t kill\t systemctl\n", + "bzcmp\t kmod\t systemd\n", + "bzdiff\t less\t systemd-ask-password\n", + "bzegrep lessecho systemd-escape\n", + "bzexe\t lessfile systemd-hwdb\n", + "bzfgrep lesskey\t systemd-inhibit\n", + "bzgrep\t lesspipe systemd-machine-id-setup\n", + "bzip2\t ln\t systemd-notify\n", + "bzip2recover login\t systemd-sysusers\n", + "bzless\t loginctl systemd-tmpfiles\n", + "bzmore\t ls\t systemd-tty-ask-password-agent\n", + "cat\t lsblk\t tar\n", + "chgrp\t lsmod\t tempfile\n", + "chmod\t mkdir\t touch\n", + "chown\t mknod\t true\n", + "cp\t mktemp\t udevadm\n", + "dash\t more\t ulockmgr_server\n", + "date\t mount\t umount\n", + "dd\t mountpoint uname\n", + "df\t mv\t uncompress\n", + "dir\t networkctl vdir\n", + "dmesg\t nisdomainname wdctl\n", + "dnsdomainname pidof\t which\n", + "domainname ps\t ypdomainname\n", + "echo\t pwd\t zcat\n", + "egrep\t rbash\t zcmp\n", + "false\t readlink zdiff\n", + "fgrep\t rm\t zegrep\n", + "findmnt rmdir\t zfgrep\n", + "fuser\t run-parts zforce\n", + "fusermount sed\t zgrep\n", + "grep\t sh\t zless\n", + "gunzip\t sh.distrib zmore\n", + "gzexe\t sleep\t znew\n", + "gzip\t stty\n" + ], + "name": "stdout" + } + ] + }, + { + "cell_type": "markdown", + "metadata": { + "id": "7GSpUDI4YGJf", + "colab_type": "text" + }, + "source": [ + "You will get a long list of programs. You can run any of these programs by just typing their names and pressing enter. You may be able to guess what some of these programs do, but if you want to know, most of them provide you help, using \"--help\" or \"-h\" flag. For example execute \"ls --help\". Quick note that MacOS is a bit different and so \"--help\" doesn't seem to work." + ] + }, + { + "cell_type": "code", + "metadata": { + "id": "HMnYbeLZYGJg", + "colab_type": "code", + "colab": { + "base_uri": "https://localhost:8080/", + "height": 1000 + }, + "outputId": "3294a9ac-b7fd-4103-a5a1-28cbef6ea211" + }, + "source": [ + "!ls --help" + ], + "execution_count": 10, + "outputs": [ + { + "output_type": "stream", + "text": [ + "Usage: ls [OPTION]... [FILE]...\n", + "List information about the FILEs (the current directory by default).\n", + "Sort entries alphabetically if none of -cftuvSUX nor --sort is specified.\n", + "\n", + "Mandatory arguments to long options are mandatory for short options too.\n", + " -a, --all do not ignore entries starting with .\n", + " -A, --almost-all do not list implied . and ..\n", + " --author with -l, print the author of each file\n", + " -b, --escape print C-style escapes for nongraphic characters\n", + " --block-size=SIZE scale sizes by SIZE before printing them; e.g.,\n", + " '--block-size=M' prints sizes in units of\n", + " 1,048,576 bytes; see SIZE format below\n", + " -B, --ignore-backups do not list implied entries ending with ~\n", + " -c with -lt: sort by, and show, ctime (time of last\n", + " modification of file status information);\n", + " with -l: show ctime and sort by name;\n", + " otherwise: sort by ctime, newest first\n", + " -C list entries by columns\n", + " --color[=WHEN] colorize the output; WHEN can be 'always' (default\n", + " if omitted), 'auto', or 'never'; more info below\n", + " -d, --directory list directories themselves, not their contents\n", + " -D, --dired generate output designed for Emacs' dired mode\n", + " -f do not sort, enable -aU, disable -ls --color\n", + " -F, --classify append indicator (one of */=>@|) to entries\n", + " --file-type likewise, except do not append '*'\n", + " --format=WORD across -x, commas -m, horizontal -x, long -l,\n", + " single-column -1, verbose -l, vertical -C\n", + " --full-time like -l --time-style=full-iso\n", + " -g like -l, but do not list owner\n", + " --group-directories-first\n", + " group directories before files;\n", + " can be augmented with a --sort option, but any\n", + " use of --sort=none (-U) disables grouping\n", + " -G, --no-group in a long listing, don't print group names\n", + " -h, --human-readable with -l and/or -s, print human readable sizes\n", + " (e.g., 1K 234M 2G)\n", + " --si likewise, but use powers of 1000 not 1024\n", + " -H, --dereference-command-line\n", + " follow symbolic links listed on the command line\n", + " --dereference-command-line-symlink-to-dir\n", + " follow each command line symbolic link\n", + " that points to a directory\n", + " --hide=PATTERN do not list implied entries matching shell PATTERN\n", + " (overridden by -a or -A)\n", + " --hyperlink[=WHEN] hyperlink file names; WHEN can be 'always'\n", + " (default if omitted), 'auto', or 'never'\n", + " --indicator-style=WORD append indicator with style WORD to entry names:\n", + " none (default), slash (-p),\n", + " file-type (--file-type), classify (-F)\n", + " -i, --inode print the index number of each file\n", + " -I, --ignore=PATTERN do not list implied entries matching shell PATTERN\n", + " -k, --kibibytes default to 1024-byte blocks for disk usage\n", + " -l use a long listing format\n", + " -L, --dereference when showing file information for a symbolic\n", + " link, show information for the file the link\n", + " references rather than for the link itself\n", + " -m fill width with a comma separated list of entries\n", + " -n, --numeric-uid-gid like -l, but list numeric user and group IDs\n", + " -N, --literal print entry names without quoting\n", + " -o like -l, but do not list group information\n", + " -p, --indicator-style=slash\n", + " append / indicator to directories\n", + " -q, --hide-control-chars print ? instead of nongraphic characters\n", + " --show-control-chars show nongraphic characters as-is (the default,\n", + " unless program is 'ls' and output is a terminal)\n", + " -Q, --quote-name enclose entry names in double quotes\n", + " --quoting-style=WORD use quoting style WORD for entry names:\n", + " literal, locale, shell, shell-always,\n", + " shell-escape, shell-escape-always, c, escape\n", + " -r, --reverse reverse order while sorting\n", + " -R, --recursive list subdirectories recursively\n", + " -s, --size print the allocated size of each file, in blocks\n", + " -S sort by file size, largest first\n", + " --sort=WORD sort by WORD instead of name: none (-U), size (-S),\n", + " time (-t), version (-v), extension (-X)\n", + " --time=WORD with -l, show time as WORD instead of default\n", + " modification time: atime or access or use (-u);\n", + " ctime or status (-c); also use specified time\n", + " as sort key if --sort=time (newest first)\n", + " --time-style=STYLE with -l, show times using style STYLE:\n", + " full-iso, long-iso, iso, locale, or +FORMAT;\n", + " FORMAT is interpreted like in 'date'; if FORMAT\n", + " is FORMAT1FORMAT2, then FORMAT1 applies\n", + " to non-recent files and FORMAT2 to recent files;\n", + " if STYLE is prefixed with 'posix-', STYLE\n", + " takes effect only outside the POSIX locale\n", + " -t sort by modification time, newest first\n", + " -T, --tabsize=COLS assume tab stops at each COLS instead of 8\n", + " -u with -lt: sort by, and show, access time;\n", + " with -l: show access time and sort by name;\n", + " otherwise: sort by access time, newest first\n", + " -U do not sort; list entries in directory order\n", + " -v natural sort of (version) numbers within text\n", + " -w, --width=COLS set output width to COLS. 0 means no limit\n", + " -x list entries by lines instead of by columns\n", + " -X sort alphabetically by entry extension\n", + " -Z, --context print any security context of each file\n", + " -1 list one file per line. Avoid '\\n' with -q or -b\n", + " --help display this help and exit\n", + " --version output version information and exit\n", + "\n", + "The SIZE argument is an integer and optional unit (example: 10K is 10*1024).\n", + "Units are K,M,G,T,P,E,Z,Y (powers of 1024) or KB,MB,... (powers of 1000).\n", + "\n", + "Using color to distinguish file types is disabled both by default and\n", + "with --color=never. With --color=auto, ls emits color codes only when\n", + "standard output is connected to a terminal. The LS_COLORS environment\n", + "variable can change the settings. Use the dircolors command to set it.\n", + "\n", + "Exit status:\n", + " 0 if OK,\n", + " 1 if minor problems (e.g., cannot access subdirectory),\n", + " 2 if serious trouble (e.g., cannot access command-line argument).\n", + "\n", + "GNU coreutils online help: \n", + "Full documentation at: \n", + "or available locally via: info '(coreutils) ls invocation'\n" + ], + "name": "stdout" + } + ] + }, + { + "cell_type": "markdown", + "metadata": { + "id": "SP9u_kU-YGJi", + "colab_type": "text" + }, + "source": [ + " For more information about a program or command, you can use Unix's manual pages using the \"man\" command. Try typing \"man ls\". Note that you will need to press space to scroll through lengthy manual pages and \"q\" to exit back to the shell prompt. " + ] + }, + { + "cell_type": "code", + "metadata": { + "id": "w03eh-7QYGJj", + "colab_type": "code", + "colab": { + "base_uri": "https://localhost:8080/", + "height": 1000 + }, + "outputId": "ec6b173b-9c32-4f50-dcf1-514d6b7a2a67" + }, + "source": [ + "!man ls" + ], + "execution_count": 11, + "outputs": [ + { + "output_type": "stream", + "text": [ + "LS(1POSIX) POSIX Programmer's Manual LS(1POSIX)\n", + "\n", + "P\bPR\bRO\bOL\bLO\bOG\bG\n", + " This manual page is part of the POSIX Programmer's Manual. The Linux\n", + " implementation of this interface may differ (consult the corresponding\n", + " Linux manual page for details of Linux behavior), or the interface may\n", + " not be implemented on Linux.\n", + "\n", + "N\bNA\bAM\bME\bE\n", + " ls — list directory contents\n", + "\n", + "S\bSY\bYN\bNO\bOP\bPS\bSI\bIS\bS\n", + " ls [\b[−ikqrs]\b] [\b[−glno]\b] [\b[−A|−a]\b] [\b[−C|−m|−x|−1]\b] \\\n", + " [\b[−F|−p]\b] [\b[−H|−L]\b] [\b[−R|−d]\b] [\b[−S|−f|−t]\b] [\b[−c|−u]\b] [\b[_\bf_\bi_\bl_\be...]\b]\n", + "\n", + "D\bDE\bES\bSC\bCR\bRI\bIP\bPT\bTI\bIO\bON\bN\n", + " For each operand that names a file of a type other than directory or\n", + " symbolic link to a directory, _\bl_\bs shall write the name of the file as\n", + " well as any requested, associated information. For each operand that\n", + " names a file of type directory, _\bl_\bs shall write the names of files con‐\n", + " tained within the directory as well as any requested, associated infor‐\n", + " mation. Filenames beginning with a ('\b'.\b.'\b') and any associated\n", + " information shall not be written out unless explicitly referenced, the\n", + " −\b−A\bA or −\b−a\ba option is supplied, or an implementation-defined condition\n", + " causes them to be written. If one or more of the −\b−d\bd, −\b−F\bF, or −\b−l\bl options\n", + " are specified, and neither the −\b−H\bH nor the −\b−L\bL option is specified, for\n", + " each operand that names a file of type symbolic link to a directory, _\bl_\bs\n", + " shall write the name of the file as well as any requested, associated\n", + " information. If none of the −\b−d\bd, −\b−F\bF, or −\b−l\bl options are specified, or the\n", + " −\b−H\bH or −\b−L\bL options are specified, for each operand that names a file of\n", + " type symbolic link to a directory, _\bl_\bs shall write the names of files\n", + " contained within the directory as well as any requested, associated\n", + " information. In each case where the names of files contained within a\n", + " directory are written, if the directory contains any symbolic links\n", + " then _\bl_\bs shall evaluate the file information and file type to be those\n", + " of the symbolic link itself, unless the −\b−L\bL option is specified.\n", + "\n", + " If no operands are specified, _\bl_\bs shall behave as if a single operand of\n", + " dot ('\b'.\b.'\b') had been specified. If more than one operand is specified,\n", + " _\bl_\bs shall write non-directory operands first; it shall sort directory\n", + " and non-directory operands separately according to the collating\n", + " sequence in the current locale.\n", + "\n", + " The _\bl_\bs utility shall detect infinite loops; that is, entering a previ‐\n", + " ously visited directory that is an ancestor of the last file encoun‐\n", + " tered. When it detects an infinite loop, _\bl_\bs shall write a diagnostic\n", + " message to standard error and shall either recover its position in the\n", + " hierarchy or terminate.\n", + "\n", + "O\bOP\bPT\bTI\bIO\bON\bNS\bS\n", + " The _\bl_\bs utility shall conform to the Base Definitions volume of\n", + " POSIX.1‐2008, _\bS_\be_\bc_\bt_\bi_\bo_\bn _\b1_\b2_\b._\b2, _\bU_\bt_\bi_\bl_\bi_\bt_\by _\bS_\by_\bn_\bt_\ba_\bx _\bG_\bu_\bi_\bd_\be_\bl_\bi_\bn_\be_\bs.\n", + "\n", + " The following options shall be supported:\n", + "\n", + " −\b−A\bA Write out all directory entries, including those whose names\n", + " begin with a ('\b'.\b.'\b') but excluding the entries dot\n", + " and dot-dot (if they exist).\n", + "\n", + " −\b−C\bC Write multi-text-column output with entries sorted down the\n", + " columns, according to the collating sequence. The number of\n", + " text columns and the column separator characters are unspeci‐\n", + " fied, but should be adapted to the nature of the output\n", + " device. This option disables long format output.\n", + "\n", + " −\b−F\bF Do not follow symbolic links named as operands unless the −\b−H\bH\n", + " or −\b−L\bL options are specified. Write a ('\b'/\b/'\b') immedi‐\n", + " ately after each pathname that is a directory, an \n", + " ('\b'*\b*'\b') after each that is executable, a ('\b'|\b|'\b')\n", + " after each that is a FIFO, and an at-sign ('\b'@\b@'\b') after each\n", + " that is a symbolic link. For other file types, other symbols\n", + " may be written.\n", + "\n", + " −\b−H\bH Evaluate the file information and file type for symbolic\n", + " links specified on the command line to be those of the file\n", + " referenced by the link, and not the link itself; however, _\bl_\bs\n", + " shall write the name of the link itself and not the file ref‐\n", + " erenced by the link.\n", + "\n", + " −\b−L\bL Evaluate the file information and file type for all symbolic\n", + " links (whether named on the command line or encountered in a\n", + " file hierarchy) to be those of the file referenced by the\n", + " link, and not the link itself; however, _\bl_\bs shall write the\n", + " name of the link itself and not the file referenced by the\n", + " link. When −\b−L\bL is used with −\b−l\bl, write the contents of symbolic\n", + " links in the long format (see the STDOUT section).\n", + "\n", + " −\b−R\bR Recursively list subdirectories encountered. When a symbolic\n", + " link to a directory is encountered, the directory shall not\n", + " be recursively listed unless the −\b−L\bL option is specified. The\n", + " use of −\b−R\bR with −\b−d\bd or −\b−f\bf produces unspecified results.\n", + "\n", + " −\b−S\bS Sort with the primary key being file size (in decreasing\n", + " order) and the secondary key being filename in the collating\n", + " sequence (in increasing order).\n", + "\n", + " −\b−a\ba Write out all directory entries, including those whose names\n", + " begin with a ('\b'.\b.'\b').\n", + "\n", + " −\b−c\bc Use time of last modification of the file status information\n", + " (see the Base Definitions volume of POSIX.1‐2008,\n", + " <\b\b>) instead of last modification of the file itself\n", + " for sorting (−\b−t\bt) or writing (−\b−l\bl).\n", + "\n", + " −\b−d\bd Do not follow symbolic links named as operands unless the −\b−H\bH\n", + " or −\b−L\bL options are specified. Do not treat directories differ‐\n", + " ently than other types of files. The use of −\b−d\bd with −\b−R\bR or −\b−f\bf\n", + " produces unspecified results.\n", + "\n", + " −\b−f\bf List the entries in directory operands in the order they\n", + " appear in the directory. The behavior for non-directory oper‐\n", + " ands is unspecified. This option shall turn on −\b−a\ba. When −\b−f\bf\n", + " is specified, any occurrences of the −\b−r\br, −\b−S\bS, and −\b−t\bt options\n", + " shall be ignored and any occurrences of the −\b−A\bA, −\b−g\bg, −\b−l\bl, −\b−n\bn,\n", + " −\b−o\bo, and −\b−s\bs options may be ignored. The use of −\b−f\bf with −\b−R\bR or\n", + " −\b−d\bd produces unspecified results.\n", + "\n", + " −\b−g\bg Turn on the −\b−l\bl (ell) option, but disable writing the file's\n", + " owner name or number. Disable the −\b−C\bC, −\b−m\bm, and −\b−x\bx options.\n", + "\n", + " −\b−i\bi For each file, write the file's file serial number (see\n", + " _\bs_\bt_\ba_\bt() in the System Interfaces volume of POSIX.1‐2008).\n", + "\n", + " −\b−k\bk Set the block size for the −\b−s\bs option and the per-directory\n", + " block count written for the −\b−l\bl, −\b−n\bn, −\b−s\bs, −\b−g\bg, and −\b−o\bo options\n", + " (see the STDOUT section) to 1024 bytes.\n", + "\n", + " −\b−l\bl (The letter ell.) Do not follow symbolic links named as oper‐\n", + " ands unless the −\b−H\bH or −\b−L\bL options are specified. Write out in\n", + " long format (see the STDOUT section). Disable the −\b−C\bC, −\b−m\bm, and\n", + " −\b−x\bx options.\n", + "\n", + " −\b−m\bm Stream output format; list pathnames across the page, sepa‐\n", + " rated by a character followed by a character.\n", + " Use a character as the list terminator and after\n", + " the separator sequence when there is not room on a line for\n", + " the next list entry. This option disables long format output.\n", + "\n", + " −\b−n\bn Turn on the −\b−l\bl (ell) option, but when writing the file's\n", + " owner or group, write the file's numeric UID or GID rather\n", + " than the user or group name, respectively. Disable the −\b−C\bC,\n", + " −\b−m\bm, and −\b−x\bx options.\n", + "\n", + " −\b−o\bo Turn on the −\b−l\bl (ell) option, but disable writing the file's\n", + " group name or number. Disable the −\b−C\bC, −\b−m\bm, and −\b−x\bx options.\n", + "\n", + " −\b−p\bp Write a ('\b'/\b/'\b') after each filename if that file is a\n", + " directory.\n", + "\n", + " −\b−q\bq Force each instance of non-printable filename characters and\n", + " characters to be written as the ('\b'?\b?'\b')\n", + " character. Implementations may provide this option by default\n", + " if the output is to a terminal device.\n", + "\n", + " −\b−r\br Reverse the order of the sort to get reverse collating\n", + " sequence oldest first, or smallest file size first depending\n", + " on the other options given.\n", + "\n", + " −\b−s\bs Indicate the total number of file system blocks consumed by\n", + " each file displayed. If the −\b−k\bk option is also specified, the\n", + " block size shall be 1024 bytes; otherwise, the block size is\n", + " implementation-defined.\n", + "\n", + " −\b−t\bt Sort with the primary key being time modified (most recently\n", + " modified first) and the secondary key being filename in the\n", + " collating sequence. For a symbolic link, the time used as\n", + " the sort key is that of the symbolic link itself, unless _\bl_\bs\n", + " is evaluating its file information to be that of the file\n", + " referenced by the link (see the −\b−H\bH and −\b−L\bL options).\n", + "\n", + " −\b−u\bu Use time of last access (see the Base Definitions volume of\n", + " POSIX.1‐2008, <\b\b>) instead of last modification of\n", + " the file for sorting (−\b−t\bt) or writing (−\b−l\bl).\n", + "\n", + " −\b−x\bx The same as −\b−C\bC, except that the multi-text-column output is\n", + " produced with entries sorted across, rather than down, the\n", + " columns. This option disables long format output.\n", + "\n", + " −\b−1\b1 (The numeric digit one.) Force output to be one entry per\n", + " line. This option does not disable long format output. (Long\n", + " format output is enabled by −\b−g\bg, −\b−l\bl (ell), −\b−n\bn, and −\b−o\bo; and\n", + " disabled by −\b−C\bC, −\b−m\bm, and −\b−x\bx.)\n", + "\n", + " If an option that enables long format output (−\b−g\bg, −\b−l\bl (ell), −\b−n\bn, and −\b−o\bo\n", + " is given with an option that disables long format output (−\b−C\bC, −\b−m\bm, and\n", + " −\b−x\bx), this shall not be considered an error. The last of these options\n", + " specified shall determine whether long format output is written.\n", + "\n", + " If −\b−R\bR, −\b−d\bd, or −\b−f\bf are specified, the results of specifying these mutu‐\n", + " ally-exclusive options are specified by the descriptions of these\n", + " options above. If more than one of any of the other options shown in\n", + " the SYNOPSIS section in mutually-exclusive sets are given, this shall\n", + " not be considered an error; the last option specified in each set shall\n", + " determine the output.\n", + "\n", + " Note that if −\b−t\bt is specified, −\b−c\bc and −\b−u\bu are not only mutually-exclusive\n", + " with each other, they are also mutually-exclusive with −\b−S\bS when deter‐\n", + " mining sort order. But even if −\b−S\bS is specified after all occurrences of\n", + " −\b−c\bc, −\b−t\bt, and −\b−u\bu, the last use of −\b−c\bc or −\b−u\bu determines the timestamp\n", + " printed when producing long format output.\n", + "\n", + "O\bOP\bPE\bER\bRA\bAN\bND\bDS\bS\n", + " The following operand shall be supported:\n", + "\n", + " _\bf_\bi_\bl_\be A pathname of a file to be written. If the file specified is\n", + " not found, a diagnostic message shall be output on standard\n", + " error.\n", + "\n", + "S\bST\bTD\bDI\bIN\bN\n", + " Not used.\n", + "\n", + "I\bIN\bNP\bPU\bUT\bT F\bFI\bIL\bLE\bES\bS\n", + " None.\n", + "\n", + "E\bEN\bNV\bVI\bIR\bRO\bON\bNM\bME\bEN\bNT\bT V\bVA\bAR\bRI\bIA\bAB\bBL\bLE\bES\bS\n", + " The following environment variables shall affect the execution of _\bl_\bs:\n", + "\n", + " _\bC_\bO_\bL_\bU_\bM_\bN_\bS Determine the user's preferred column position width for\n", + " writing multiple text-column output. If this variable con‐\n", + " tains a string representing a decimal integer, the _\bl_\bs utility\n", + " shall calculate how many pathname text columns to write (see\n", + " −\b−C\bC) based on the width provided. If _\bC_\bO_\bL_\bU_\bM_\bN_\bS is not set or\n", + " invalid, an implementation-defined number of column positions\n", + " shall be assumed, based on the implementation's knowledge of\n", + " the output device. The column width chosen to write the names\n", + " of files in any given directory shall be constant. Filenames\n", + " shall not be truncated to fit into the multiple text-column\n", + " output.\n", + "\n", + " _\bL_\bA_\bN_\bG Provide a default value for the internationalization vari‐\n", + " ables that are unset or null. (See the Base Definitions vol‐\n", + " ume of POSIX.1‐2008, _\bS_\be_\bc_\bt_\bi_\bo_\bn _\b8_\b._\b2, _\bI_\bn_\bt_\be_\br_\bn_\ba_\bt_\bi_\bo_\bn_\ba_\bl_\bi_\bz_\ba_\bt_\bi_\bo_\bn _\bV_\ba_\br_\bi_\b‐\n", + " _\ba_\bb_\bl_\be_\bs for the precedence of internationalization variables\n", + " used to determine the values of locale categories.)\n", + "\n", + " _\bL_\bC_\b__\bA_\bL_\bL If set to a non-empty string value, override the values of\n", + " all the other internationalization variables.\n", + "\n", + " _\bL_\bC_\b__\bC_\bO_\bL_\bL_\bA_\bT_\bE\n", + " Determine the locale for character collation information in\n", + " determining the pathname collation sequence.\n", + "\n", + " _\bL_\bC_\b__\bC_\bT_\bY_\bP_\bE Determine the locale for the interpretation of sequences of\n", + " bytes of text data as characters (for example, single-byte as\n", + " opposed to multi-byte characters in arguments) and which\n", + " characters are defined as printable (character class p\bpr\bri\bin\bnt\bt).\n", + "\n", + " _\bL_\bC_\b__\bM_\bE_\bS_\bS_\bA_\bG_\bE_\bS\n", + " Determine the locale that should be used to affect the format\n", + " and contents of diagnostic messages written to standard\n", + " error.\n", + "\n", + " _\bL_\bC_\b__\bT_\bI_\bM_\bE Determine the format and contents for date and time strings\n", + " written by _\bl_\bs.\n", + "\n", + " _\bN_\bL_\bS_\bP_\bA_\bT_\bH Determine the location of message catalogs for the processing\n", + " of _\bL_\bC_\b__\bM_\bE_\bS_\bS_\bA_\bG_\bE_\bS.\n", + "\n", + " _\bT_\bZ Determine the timezone for date and time strings written by\n", + " _\bl_\bs. If _\bT_\bZ is unset or null, an unspecified default timezone\n", + " shall be used.\n", + "\n", + "A\bAS\bSY\bYN\bNC\bCH\bHR\bRO\bON\bNO\bOU\bUS\bS E\bEV\bVE\bEN\bNT\bTS\bS\n", + " Default.\n", + "\n", + "S\bST\bTD\bDO\bOU\bUT\bT\n", + " The default format shall be to list one entry per line to standard out‐\n", + " put; the exceptions are to terminals or when one of the −\b−C\bC, −\b−m\bm, or −\b−x\bx\n", + " options is specified. If the output is to a terminal, the format is\n", + " implementation-defined.\n", + "\n", + " When −\b−m\bm is specified, the format used for the last element of the list\n", + " shall be:\n", + "\n", + " \"\b\"%\b%s\bs\\\b\\n\bn\"\b\",\b, <\b<_\bf_\bi_\bl_\be_\bn_\ba_\bm_\be>\n", + "\n", + " The format used for each other element of the list shall be:\n", + "\n", + " \"\b\"%\b%s\bs,\b,%\b%s\bs\"\b\",\b, <\b<_\bf_\bi_\bl_\be_\bn_\ba_\bm_\be>, <_\bs_\be_\bp_\ba_\br_\ba_\bt_\bo_\br>\n", + "\n", + " where, if there is not room for the next element of the list to fit\n", + " within the current line length, <_\bs_\be_\bp_\ba_\br_\ba_\bt_\bo_\br> is a string containing an\n", + " optional character and a mandatory character; other‐\n", + " wise it is a single character.\n", + "\n", + " If the −\b−i\bi option is specified, the file's file serial number (see the\n", + " Base Definitions volume of POSIX.1‐2008, <\b\b>) shall be written\n", + " in the following format before any other output for the corresponding\n", + " entry:\n", + "\n", + " %\b%u\bu \"\b\",\b, <\b<_\bf_\bi_\bl_\be _\bs_\be_\br_\bi_\ba_\bl _\bn_\bu_\bm_\bb_\be_\br>\n", + "\n", + " If the −\b−l\bl option is specified, the following information shall be writ‐\n", + " ten for files other than character special and block special files:\n", + "\n", + " \"\b\"%\b%s\bs %\b%u\bu %\b%s\bs %\b%s\bs %\b%u\bu %\b%s\bs %\b%s\bs\\\b\\n\bn\"\b\",\b, <\b<_\bf_\bi_\bl_\be _\bm_\bo_\bd_\be>, <_\bn_\bu_\bm_\bb_\be_\br _\bo_\bf _\bl_\bi_\bn_\bk_\bs>,\n", + " <_\bo_\bw_\bn_\be_\br _\bn_\ba_\bm_\be>, <_\bg_\br_\bo_\bu_\bp _\bn_\ba_\bm_\be>, <_\bs_\bi_\bz_\be>, <_\bd_\ba_\bt_\be _\ba_\bn_\bd _\bt_\bi_\bm_\be>,\n", + " <_\bp_\ba_\bt_\bh_\bn_\ba_\bm_\be>\n", + "\n", + " If the −\b−l\bl option is specified, the following information shall be writ‐\n", + " ten for character special and block special files:\n", + "\n", + " \"\b\"%\b%s\bs %\b%u\bu %\b%s\bs %\b%s\bs %\b%s\bs %\b%s\bs %\b%s\bs\\\b\\n\bn\"\b\",\b, <\b<_\bf_\bi_\bl_\be _\bm_\bo_\bd_\be>, <_\bn_\bu_\bm_\bb_\be_\br _\bo_\bf _\bl_\bi_\bn_\bk_\bs>,\n", + " <_\bo_\bw_\bn_\be_\br _\bn_\ba_\bm_\be>, <_\bg_\br_\bo_\bu_\bp _\bn_\ba_\bm_\be>, <_\bd_\be_\bv_\bi_\bc_\be _\bi_\bn_\bf_\bo>, <_\bd_\ba_\bt_\be _\ba_\bn_\bd _\bt_\bi_\bm_\be>,\n", + " <_\bp_\ba_\bt_\bh_\bn_\ba_\bm_\be>\n", + "\n", + " In both cases if the file is a symbolic link and the −\b−L\bL option is also\n", + " specified, this information shall be for the file resolved from the\n", + " symbolic link, except that the <_\bp_\ba_\bt_\bh_\bn_\ba_\bm_\be> field shall contain the path‐\n", + " name of the symbolic link itself. If the file is a symbolic link and\n", + " the −\b−L\bL option is not specified, this information shall be about the\n", + " link itself and the <_\bp_\ba_\bt_\bh_\bn_\ba_\bm_\be> field shall be of the form:\n", + "\n", + " \"\b\"%\b%s\bs −\b−>\b> %\b%s\bs\"\b\",\b, <\b<_\bp_\ba_\bt_\bh_\bn_\ba_\bm_\be _\bo_\bf _\bl_\bi_\bn_\bk>, <_\bc_\bo_\bn_\bt_\be_\bn_\bt_\bs _\bo_\bf _\bl_\bi_\bn_\bk>\n", + "\n", + " The −\b−n\bn, −\b−g\bg, and −\b−o\bo options use the same format as −\b−l\bl, but with omitted\n", + " items and their associated characters. See the OPTIONS section.\n", + "\n", + " In both the preceding −\b−l\bl forms, if <_\bo_\bw_\bn_\be_\br _\bn_\ba_\bm_\be> or <_\bg_\br_\bo_\bu_\bp _\bn_\ba_\bm_\be> cannot\n", + " be determined, or if −\b−n\bn is given, they shall be replaced with their\n", + " associated numeric values using the format %\b%u\bu.\n", + "\n", + " The <_\bs_\bi_\bz_\be> field shall contain the value that would be returned for the\n", + " file in the _\bs_\bt_\b__\bs_\bi_\bz_\be field of s\bst\btr\bru\buc\bct\bt s\bst\bta\bat\bt (see the Base Definitions vol‐\n", + " ume of POSIX.1‐2008, <\b\b>). Note that for some file types this\n", + " value is unspecified.\n", + "\n", + " The <_\bd_\be_\bv_\bi_\bc_\be _\bi_\bn_\bf_\bo> field shall contain implementation-defined informa‐\n", + " tion associated with the device in question.\n", + "\n", + " The <_\bd_\ba_\bt_\be _\ba_\bn_\bd _\bt_\bi_\bm_\be> field shall contain the appropriate date and time‐\n", + " stamp of when the file was last modified. In the POSIX locale, the\n", + " field shall be the equivalent of the output of the following _\bd_\ba_\bt_\be com‐\n", + " mand:\n", + "\n", + " d\bda\bat\bte\be \"\b\"+\b+%\b%b\bb %\b%e\be %\b%H\bH:\b:%\b%M\bM\"\b\"\n", + "\n", + " if the file has been modified in the last six months, or:\n", + "\n", + " d\bda\bat\bte\be \"\b\"+\b+%\b%b\bb %\b%e\be %\b%Y\bY\"\b\"\n", + "\n", + " (where two characters are used between %\b%e\be and %\b%Y\bY) if the file\n", + " has not been modified in the last six months or if the modification\n", + " date is in the future, except that, in both cases, the final \n", + " produced by _\bd_\ba_\bt_\be shall not be included and the output shall be as if\n", + " the _\bd_\ba_\bt_\be command were executed at the time of the last modification\n", + " date of the file rather than the current time. When the _\bL_\bC_\b__\bT_\bI_\bM_\bE locale\n", + " category is not set to the POSIX locale, a different format and order\n", + " of presentation of this field may be used.\n", + "\n", + " If the pathname was specified as a _\bf_\bi_\bl_\be operand, it shall be written as\n", + " specified.\n", + "\n", + " The file mode written under the −\b−l\bl, −\b−n\bn, −\b−g\bg, and −\b−o\bo options shall con‐\n", + " sist of the following format:\n", + "\n", + " \"\b\"%\b%c\bc%\b%s\bs%\b%s\bs%\b%s\bs%\b%s\bs\"\b\",\b, <\b<_\be_\bn_\bt_\br_\by _\bt_\by_\bp_\be>, <_\bo_\bw_\bn_\be_\br _\bp_\be_\br_\bm_\bi_\bs_\bs_\bi_\bo_\bn_\bs>,\n", + " <_\bg_\br_\bo_\bu_\bp _\bp_\be_\br_\bm_\bi_\bs_\bs_\bi_\bo_\bn_\bs>, <_\bo_\bt_\bh_\be_\br _\bp_\be_\br_\bm_\bi_\bs_\bs_\bi_\bo_\bn_\bs>,\n", + " <_\bo_\bp_\bt_\bi_\bo_\bn_\ba_\bl _\ba_\bl_\bt_\be_\br_\bn_\ba_\bt_\be _\ba_\bc_\bc_\be_\bs_\bs _\bm_\be_\bt_\bh_\bo_\bd _\bf_\bl_\ba_\bg>\n", + "\n", + " The <_\bo_\bp_\bt_\bi_\bo_\bn_\ba_\bl _\ba_\bl_\bt_\be_\br_\bn_\ba_\bt_\be _\ba_\bc_\bc_\be_\bs_\bs _\bm_\be_\bt_\bh_\bo_\bd _\bf_\bl_\ba_\bg> shall be the empty string\n", + " if there is no alternate or additional access control method associated\n", + " with the file; otherwise, it shall be a string containing a single\n", + " printable character that is not a .\n", + "\n", + " The <_\be_\bn_\bt_\br_\by _\bt_\by_\bp_\be> character shall describe the type of file, as follows:\n", + "\n", + " d Directory.\n", + "\n", + " b Block special file.\n", + "\n", + " c Character special file.\n", + "\n", + " l (ell) Symbolic link.\n", + "\n", + " p FIFO.\n", + "\n", + " − Regular file.\n", + "\n", + " Implementations may add other characters to this list to represent\n", + " other implementation-defined file types.\n", + "\n", + " The next three fields shall be three characters each:\n", + "\n", + " <_\bo_\bw_\bn_\be_\br _\bp_\be_\br_\bm_\bi_\bs_\bs_\bi_\bo_\bn_\bs>\n", + " Permissions for the file owner class (see the Base Definitions\n", + " volume of POSIX.1‐2008, _\bS_\be_\bc_\bt_\bi_\bo_\bn _\b4_\b._\b4, _\bF_\bi_\bl_\be _\bA_\bc_\bc_\be_\bs_\bs _\bP_\be_\br_\bm_\bi_\bs_\bs_\bi_\bo_\bn_\bs).\n", + "\n", + " <_\bg_\br_\bo_\bu_\bp _\bp_\be_\br_\bm_\bi_\bs_\bs_\bi_\bo_\bn_\bs>\n", + " Permissions for the file group class.\n", + "\n", + " <_\bo_\bt_\bh_\be_\br _\bp_\be_\br_\bm_\bi_\bs_\bs_\bi_\bo_\bn_\bs>\n", + " Permissions for the file other class.\n", + "\n", + " Each field shall have three character positions:\n", + "\n", + " 1. If '\b'r\br'\b', the file is readable; if '\b'−\b−'\b', the file is not readable.\n", + "\n", + " 2. If '\b'w\bw'\b', the file is writable; if '\b'−\b−'\b', the file is not writable.\n", + "\n", + " 3. The first of the following that applies:\n", + "\n", + " S If in <_\bo_\bw_\bn_\be_\br _\bp_\be_\br_\bm_\bi_\bs_\bs_\bi_\bo_\bn_\bs>, the file is not executable and\n", + " set-user-ID mode is set. If in <_\bg_\br_\bo_\bu_\bp _\bp_\be_\br_\bm_\bi_\bs_\bs_\bi_\bo_\bn_\bs>, the file\n", + " is not executable and set-group-ID mode is set.\n", + "\n", + " s If in <_\bo_\bw_\bn_\be_\br _\bp_\be_\br_\bm_\bi_\bs_\bs_\bi_\bo_\bn_\bs>, the file is executable and set-\n", + " user-ID mode is set. If in <_\bg_\br_\bo_\bu_\bp _\bp_\be_\br_\bm_\bi_\bs_\bs_\bi_\bo_\bn_\bs>, the file is\n", + " executable and set-group-ID mode is set.\n", + "\n", + " T If in <_\bo_\bt_\bh_\be_\br _\bp_\be_\br_\bm_\bi_\bs_\bs_\bi_\bo_\bn_\bs> and the file is a directory, search\n", + " permission is not granted to others, and the restricted dele‐\n", + " tion flag is set.\n", + "\n", + " t If in <_\bo_\bt_\bh_\be_\br _\bp_\be_\br_\bm_\bi_\bs_\bs_\bi_\bo_\bn_\bs> and the file is a directory, search\n", + " permission is granted to others, and the restricted deletion\n", + " flag is set.\n", + "\n", + " x The file is executable or the directory is searchable.\n", + "\n", + " − None of the attributes of '\b'S\bS'\b', '\b's\bs'\b', '\b'T\bT'\b', '\b't\bt'\b', or '\b'x\bx'\b' applies.\n", + "\n", + " Implementations may add other characters to this list for the third\n", + " character position. Such additions shall, however, be written in\n", + " lowercase if the file is executable or searchable, and in uppercase\n", + " if it is not.\n", + "\n", + " If any of the −\b−l\bl, −\b−n\bn, −\b−s\bs, −\b−g\bg, or −\b−o\bo options is specified, each list of\n", + " files within the directory shall be preceded by a status line indicat‐\n", + " ing the number of file system blocks occupied by files in the directory\n", + " in 512-byte units if the −\b−k\bk option is not specified, or 1024-byte units\n", + " if the −\b−k\bk option is specified, rounded up to the next integral number\n", + " of units, if necessary. In the POSIX locale, the format shall be:\n", + "\n", + " \"\b\"t\bto\bot\bta\bal\bl %\b%u\bu\\\b\\n\bn\"\b\",\b, <\b<_\bn_\bu_\bm_\bb_\be_\br _\bo_\bf _\bu_\bn_\bi_\bt_\bs _\bi_\bn _\bt_\bh_\be _\bd_\bi_\br_\be_\bc_\bt_\bo_\br_\by>\n", + "\n", + " If more than one directory, or a combination of non-directory files and\n", + " directories are written, either as a result of specifying multiple op‐\n", + " erands, or the −\b−R\bR option, each list of files within a directory shall\n", + " be preceded by:\n", + "\n", + " \"\b\"\\\b\\n\bn%\b%s\bs:\b:\\\b\\n\bn\"\b\",\b, <\b<_\bd_\bi_\br_\be_\bc_\bt_\bo_\br_\by _\bn_\ba_\bm_\be>\n", + "\n", + " If this string is the first thing to be written, the first \n", + " shall not be written. This output shall precede the number of units in\n", + " the directory.\n", + "\n", + " If the −\b−s\bs option is given, each file shall be written with the number\n", + " of blocks used by the file. Along with −\b−C\bC, −\b−1\b1, −\b−m\bm, or −\b−x\bx, the number\n", + " and a shall precede the filename; with −\b−l\bl, −\b−n\bn, −\b−g\bg, or −\b−o\bo, they\n", + " shall precede each line describing a file.\n", + "\n", + "S\bST\bTD\bDE\bER\bRR\bR\n", + " The standard error shall be used only for diagnostic messages.\n", + "\n", + "O\bOU\bUT\bTP\bPU\bUT\bT F\bFI\bIL\bLE\bES\bS\n", + " None.\n", + "\n", + "E\bEX\bXT\bTE\bEN\bND\bDE\bED\bD D\bDE\bES\bSC\bCR\bRI\bIP\bPT\bTI\bIO\bON\bN\n", + " None.\n", + "\n", + "E\bEX\bXI\bIT\bT S\bST\bTA\bAT\bTU\bUS\bS\n", + " The following exit values shall be returned:\n", + "\n", + " 0 Successful completion.\n", + "\n", + " >0 An error occurred.\n", + "\n", + "C\bCO\bON\bNS\bSE\bEQ\bQU\bUE\bEN\bNC\bCE\bES\bS O\bOF\bF E\bER\bRR\bRO\bOR\bRS\bS\n", + " Default.\n", + "\n", + " _\bT_\bh_\be _\bf_\bo_\bl_\bl_\bo_\bw_\bi_\bn_\bg _\bs_\be_\bc_\bt_\bi_\bo_\bn_\bs _\ba_\br_\be _\bi_\bn_\bf_\bo_\br_\bm_\ba_\bt_\bi_\bv_\be_\b.\n", + "\n", + "A\bAP\bPP\bPL\bLI\bIC\bCA\bAT\bTI\bIO\bON\bN U\bUS\bSA\bAG\bGE\bE\n", + " Many implementations use the ('\b'=\b='\b') to denote sockets\n", + " bound to the file system for the −\b−F\bF option. Similarly, many historical\n", + " implementations use the '\b's\bs'\b' character to denote sockets as the entry\n", + " type characters for the −\b−l\bl option.\n", + "\n", + " It is difficult for an application to use every part of the file modes\n", + " field of _\bl_\bs −\b−l\bl in a portable manner. Certain file types and executable\n", + " bits are not guaranteed to be exactly as shown, as implementations may\n", + " have extensions. Applications can use this field to pass directly to a\n", + " user printout or prompt, but actions based on its contents should gen‐\n", + " erally be deferred, instead, to the _\bt_\be_\bs_\bt utility.\n", + "\n", + " The output of _\bl_\bs (with the −\b−l\bl and related options) contains information\n", + " that logically could be used by utilities such as _\bc_\bh_\bm_\bo_\bd and _\bt_\bo_\bu_\bc_\bh to\n", + " restore files to a known state. However, this information is presented\n", + " in a format that cannot be used directly by those utilities or be eas‐\n", + " ily translated into a format that can be used. A character has been\n", + " added to the end of the permissions string so that applications at\n", + " least have an indication that they may be working in an area they do\n", + " not understand instead of assuming that they can translate the permis‐\n", + " sions string into something that can be used. Future versions or\n", + " related documents may define one or more specific characters to be used\n", + " based on different standard additional or alternative access control\n", + " mechanisms.\n", + "\n", + " As with many of the utilities that deal with filenames, the output of\n", + " _\bl_\bs for multiple files or in one of the long listing formats must be\n", + " used carefully on systems where filenames can contain embedded white\n", + " space. Systems and system administrators should institute policies and\n", + " user training to limit the use of such filenames.\n", + "\n", + " The number of disk blocks occupied by the file that it reports varies\n", + " depending on underlying file system type, block size units reported,\n", + " and the method of calculating the number of blocks. On some file system\n", + " types, the number is the actual number of blocks occupied by the file\n", + " (counting indirect blocks and ignoring holes in the file); on others it\n", + " is calculated based on the file size (usually making an allowance for\n", + " indirect blocks, but ignoring holes).\n", + "\n", + "E\bEX\bXA\bAM\bMP\bPL\bLE\bES\bS\n", + " An example of a small directory tree being fully listed with _\bl_\bs −\b−l\bla\baR\bRF\bF a\ba\n", + " in the POSIX locale:\n", + "\n", + " t\bto\bot\bta\bal\bl 1\b11\b1\n", + " d\bdr\brw\bwx\bxr\br-\b-x\bxr\br-\b-x\bx 3\b3 f\bfo\box\bx p\bpr\bro\bog\bg 6\b64\b4 J\bJu\bul\bl 4\b4 1\b12\b2:\b:0\b07\b7 .\b./\b/\n", + " d\bdr\brw\bwx\bxr\brw\bwx\bxr\brw\bwx\bx 4\b4 f\bfo\box\bx p\bpr\bro\bog\bg 3\b32\b26\b64\b4 J\bJu\bul\bl 4\b4 1\b12\b2:\b:0\b09\b9 .\b..\b./\b/\n", + " d\bdr\brw\bwx\bxr\br-\b-x\bxr\br-\b-x\bx 2\b2 f\bfo\box\bx p\bpr\bro\bog\bg 4\b48\b8 J\bJu\bul\bl 4\b4 1\b12\b2:\b:0\b07\b7 b\bb/\b/\n", + " -\b-r\brw\bwx\bxr\br-\b--\b-r\br-\b--\b- 1\b1 f\bfo\box\bx p\bpr\bro\bog\bg 5\b57\b72\b2 J\bJu\bul\bl 4\b4 1\b12\b2:\b:0\b07\b7 f\bfo\boo\bo*\b*\n", + "\n", + " a/b:\n", + " total 4\n", + " drwxr-xr-x 2 fox prog 48 Jul 4 12:07 ./\n", + " drwxr-xr-x 3 fox prog 64 Jul 4 12:07 ../\n", + " -rw-r--r-- 1 fox prog 700 Jul 4 12:07 bar\n", + "\n", + "R\bRA\bAT\bTI\bIO\bON\bNA\bAL\bLE\bE\n", + " Some historical implementations of the _\bl_\bs utility show all entries in a\n", + " directory except dot and dot-dot when a superuser invokes _\bl_\bs without\n", + " specifying the −\b−a\ba option. When ``normal'' users invoke _\bl_\bs without spec‐\n", + " ifying −\b−a\ba, they should not see information about any files with names\n", + " beginning with a unless they were named as _\bf_\bi_\bl_\be operands.\n", + "\n", + " Implementations are expected to traverse arbitrary depths when process‐\n", + " ing the −\b−R\bR option. The only limitation on depth should be based on run‐\n", + " ning out of physical storage for keeping track of untraversed directo‐\n", + " ries.\n", + "\n", + " The −\b−1\b1 (one) option was historically found in BSD and BSD-derived\n", + " implementations only. It is required in this volume of POSIX.1‐2008 so\n", + " that conforming applications might ensure that output is one entry per\n", + " line, even if the output is to a terminal.\n", + "\n", + " The −\b−S\bS option was added in Issue 7, but had been provided by several\n", + " implementations for many years. The description given in the standard\n", + " documents historic practice, but does not match much of the documenta‐\n", + " tion that described its behavior. Historical documentation typically\n", + " described it as something like:\n", + "\n", + " −\b−S\bS Sort by size (largest size first) instead of by name. Special\n", + " character devices (listed last) are sorted by name.\n", + "\n", + " even though the file type was never considered when sorting the output.\n", + " Character special files do typically sort close to the end of the list\n", + " because their file size on most implementations is zero. But they are\n", + " sorted alphabetically with any other files that happen to have the same\n", + " file size (zero), not sorted separately and added to the end.\n", + "\n", + " This volume of POSIX.1‐2008 is frequently silent about what happens\n", + " when mutually-exclusive options are specified. Except for −\b−R\bR, −\b−d\bd, and\n", + " −\b−f\bf, the _\bl_\bs utility is required to accept multiple options from each\n", + " mutually-exclusive option set without treating them as errors and to\n", + " use the behavior specified by the last option given in each mutually-\n", + " exclusive set. Since _\bl_\bs is one of the most aliased commands, it is\n", + " important that the implementation perform intuitively. For example, if\n", + " the alias were:\n", + "\n", + " a\bal\bli\bia\bas\bs l\bls\bs=\b=\"\b\"l\bls\bs −\b−C\bC\"\b\"\n", + "\n", + " and the user typed _\bl_\bs −\b−1\b1 (one), single-text-column output should\n", + " result, not an error.\n", + "\n", + " The −\b−g\bg, −\b−l\bl (ell), −\b−n\bn, and −\b−o\bo options are not mutually-exclusive\n", + " options. They all enable long format output. They work together to\n", + " determine whether the file's owner is written (no if −\b−g\bg is present),\n", + " file's group is written (no if −\b−o\bo is present), and if the file's group\n", + " or owner is written whether it is written as the name (default) or a\n", + " string representation of the UID or GID number (if −\b−n\bn is present). The\n", + " −\b−C\bC, −\b−m\bm, −\b−x\bx, and −\b−1\b1 (one) are mutually-exclusive options and the first\n", + " three of these disable long format output. The −\b−1\b1 (one) option does not\n", + " directly change whether or not long format output is enabled, but by\n", + " overriding −\b−C\bC, −\b−m\bm, and −\b−x\bx, it can re-enable long format output that had\n", + " been disabled by one of these options.\n", + "\n", + " Earlier versions of this standard did not describe the BSD −\b−A\bA option\n", + " (like −\b−a\ba, but dot and dot-dot are not written out). It has been added\n", + " due to widespread implementation.\n", + "\n", + " Implementations may make −\b−q\bq the default for terminals to prevent trojan\n", + " horse attacks on terminals with special escape sequences. This is not\n", + " required because:\n", + "\n", + " * Some control characters may be useful on some terminals; for exam‐\n", + " ple, a system might write them as \"\b\"\\\b\\0\b00\b01\b1\"\b\" or \"\b\"^\b^A\bA\"\b\".\n", + "\n", + " * Special behavior for terminals is not relevant to applications\n", + " portability.\n", + "\n", + " An early proposal specified that the <_\bo_\bp_\bt_\bi_\bo_\bn_\ba_\bl _\ba_\bl_\bt_\be_\br_\b‐\n", + " _\bn_\ba_\bt_\be _\ba_\bc_\bc_\be_\bs_\bs _\bm_\be_\bt_\bh_\bo_\bd _\bf_\bl_\ba_\bg> had to be '\b'+\b+'\b' if there was an alternate access\n", + " method used on the file or if there was not. This was changed\n", + " to be if there is not and a single printable character if there\n", + " is. This was done for three reasons:\n", + "\n", + " 1. There are historical implementations using characters other than\n", + " '\b'+\b+'\b'.\n", + "\n", + " 2. There are implementations that vary this character used in that\n", + " position to distinguish between various alternate access methods in\n", + " use.\n", + "\n", + " 3. The standard developers did not want to preclude future specifica‐\n", + " tions that might need a way to specify more than one alternate\n", + " access method.\n", + "\n", + " Nonetheless, implementations providing a single alternate access method\n", + " are encouraged to use '\b'+\b+'\b'.\n", + "\n", + " Earlier versions of this standard did not have the −\b−k\bk option, which\n", + " meant that the −\b−s\bs option could not be used portably as its block size\n", + " was implementation-defined, and the units used to specify the number of\n", + " blocks occupied by files in a directory in an _\bl_\bs −\b−l\bl listing were fixed\n", + " as 512-byte units. The −\b−k\bk option has been added to provide a way for\n", + " the −\b−s\bs option to be used portably, and for consistency it also changes\n", + " the aforementioned units from 512-byte to 1024-byte.\n", + "\n", + " The <_\bd_\ba_\bt_\be _\ba_\bn_\bd _\bt_\bi_\bm_\be> field in the −\b−l\bl format is specified only for the\n", + " POSIX locale. As noted, the format can be different in other locales.\n", + " No mechanism for defining this is present in this volume of\n", + " POSIX.1‐2008, as the appropriate vehicle is a messaging system; that\n", + " is, the format should be specified as a ``message''.\n", + "\n", + "F\bFU\bUT\bTU\bUR\bRE\bE D\bDI\bIR\bRE\bEC\bCT\bTI\bIO\bON\bNS\bS\n", + " Allowing −\b−f\bf to ignore the −\b−A\bA, −\b−g\bg, −\b−l\bl, −\b−n\bn, −\b−o\bo, and −\b−s\bs options may be\n", + " removed in a future version.\n", + "\n", + "S\bSE\bEE\bE A\bAL\bLS\bSO\bO\n", + " _\bc_\bh_\bm_\bo_\bd, _\bf_\bi_\bn_\bd\n", + "\n", + " The Base Definitions volume of POSIX.1‐2008, _\bS_\be_\bc_\bt_\bi_\bo_\bn _\b4_\b._\b4, _\bF_\bi_\bl_\be _\bA_\bc_\bc_\be_\bs_\bs\n", + " _\bP_\be_\br_\bm_\bi_\bs_\bs_\bi_\bo_\bn_\bs, _\bC_\bh_\ba_\bp_\bt_\be_\br _\b8, _\bE_\bn_\bv_\bi_\br_\bo_\bn_\bm_\be_\bn_\bt _\bV_\ba_\br_\bi_\ba_\bb_\bl_\be_\bs, _\bS_\be_\bc_\bt_\bi_\bo_\bn _\b1_\b2_\b._\b2, _\bU_\bt_\bi_\bl_\bi_\bt_\by\n", + " _\bS_\by_\bn_\bt_\ba_\bx _\bG_\bu_\bi_\bd_\be_\bl_\bi_\bn_\be_\bs, <\b\b>\n", + "\n", + " The System Interfaces volume of POSIX.1‐2008, _\bf_\bs_\bt_\ba_\bt_\ba_\bt()\n", + "\n", + "C\bCO\bOP\bPY\bYR\bRI\bIG\bGH\bHT\bT\n", + " Portions of this text are reprinted and reproduced in electronic form\n", + " from IEEE Std 1003.1, 2013 Edition, Standard for Information Technology\n", + " -- Portable Operating System Interface (POSIX), The Open Group Base\n", + " Specifications Issue 7, Copyright (C) 2013 by the Institute of Electri‐\n", + " cal and Electronics Engineers, Inc and The Open Group. (This is\n", + " POSIX.1-2008 with the 2013 Technical Corrigendum 1 applied.) In the\n", + " event of any discrepancy between this version and the original IEEE and\n", + " The Open Group Standard, the original IEEE and The Open Group Standard\n", + " is the referee document. The original Standard can be obtained online\n", + " at http://www.unix.org/online.html .\n", + "\n", + " Any typographical or formatting errors that appear in this page are\n", + " most likely to have been introduced during the conversion of the source\n", + " files to man page format. To report such errors, see https://www.ker‐\n", + " nel.org/doc/man-pages/reporting_bugs.html .\n", + "\n", + "IEEE/The Open Group 2013 LS(1POSIX)\n" + ], + "name": "stdout" + } + ] + }, + { + "cell_type": "markdown", + "metadata": { + "id": "nbl97GCVYGJl", + "colab_type": "text" + }, + "source": [ + "Another command interesting is \"echo\". \"echo\" simply prints whatever you put after it to the screen. " + ] + }, + { + "cell_type": "code", + "metadata": { + "id": "Sr6vUQRjYGJm", + "colab_type": "code", + "colab": { + "base_uri": "https://localhost:8080/", + "height": 34 + }, + "outputId": "e2cf3725-4c71-46d4-83d3-c7d708ebcc3e" + }, + "source": [ + "!echo \"Hello World\"" + ], + "execution_count": 12, + "outputs": [ + { + "output_type": "stream", + "text": [ + "Hello World\n" + ], + "name": "stdout" + } + ] + }, + { + "cell_type": "markdown", + "metadata": { + "id": "uVww9yisYGJo", + "colab_type": "text" + }, + "source": [ + "At this point, you may wonder how was it that the shell knew to look for programs in \"/bin\"? The shell keeps a list of places to look for programs an environment variable with the name \"PATH\". The shell keeps a table that map string variable names to string expressions. When the shell starts, its configuration files set some environment variables that it uses. You can see the full list of defined environment variables using the command \"printenv\".\n", + "\n", + "You can use a environment variable in a shell by prepending name of the variable with a dollar sign character. So you can print out the PATH environment variable using the command \"echo $PATH\". What you will see is a colon (\":\") separated list of directories that the shell will search (in order) whenever you type in anything." + ] + }, + { + "cell_type": "code", + "metadata": { + "id": "T3bQW-lcYGJo", + "colab_type": "code", + "colab": { + "base_uri": "https://localhost:8080/", + "height": 34 + }, + "outputId": "04283df6-f616-42fd-9934-264686278669" + }, + "source": [ + "!echo $PATH" + ], + "execution_count": 13, + "outputs": [ + { + "output_type": "stream", + "text": [ + "/usr/local/nvidia/bin:/usr/local/cuda/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/tools/node/bin:/tools/google-cloud-sdk/bin:/opt/bin\n" + ], + "name": "stdout" + } + ] + }, + { + "cell_type": "markdown", + "metadata": { + "id": "3zUzfIosYGJr", + "colab_type": "text" + }, + "source": [ + "You can set you own environment variables. Different shells have different syntax. Lets first figure out what shell we are running. \n", + "\n", + "*Exercise 1:* Use the \"echo\" command to print out the value of the \"SHELL\" environment variable:" + ] + }, + { + "cell_type": "code", + "metadata": { + "id": "qV-tPsZ_FsDh", + "colab_type": "code", + "colab": { + "base_uri": "https://localhost:8080/", + "height": 118 + }, + "outputId": "d7359443-ae4b-4cca-aa26-5e87bea0860f" + }, + "source": [ + "!/bin/bash --noediting" + ], + "execution_count": 17, + "outputs": [ + { + "output_type": "stream", + "text": [ + "bash: cannot set terminal process group (101): Inappropriate ioctl for device\n", + "bash: no job control in this shell\n", + "\u001b]0;root@04c8ce3a6d36: /content/sample_data\u0007\u001b[01;32mroot@04c8ce3a6d36\u001b[00m:\u001b[01;34m/content/sample_data\u001b[00m# echo $SHELL\n", + "/bin/bash\n", + "\u001b]0;root@04c8ce3a6d36: /content/sample_data\u0007\u001b[01;32mroot@04c8ce3a6d36\u001b[00m:\u001b[01;34m/content/sample_data\u001b[00m# exit\n", + "exit\n" + ], + "name": "stdout" + } + ] + }, + { + "cell_type": "markdown", + "metadata": { + "colab_type": "text", + "id": "YoEgruUhqvzw" + }, + "source": [ + "## Navigating Directories\n", + "\n", + "You can change your current directory using the \"cd\" shell command. Note that \"cd\" is not a Unix program. Once in a directory, you can use the \"ls\" command to list the contents or \"pwd\" to remind yourself your current working directory. You can move back one level in your current directory hierarchy using \"cd ..\". In general \"..\" represents the path to a directory one level above your current directory, \"../..\" represents two levels up, and so on. \".\" represents the current directory. If you look at the PATH environment variable, you'll notice that the last item is \".\", telling the shell to look into your current directory for commands. Finally the \"~\" character always refers to your home directory.\n", + "\n", + "Some other file manipulation commands:\n", + "\n", + " - The \"mkdir\" command creates new directories. \n", + " - \"cp\" and \"mv\" allow you to copy and move (or rename) files, taking 2 arguments: the original path/filename and the target path/filename. \n", + " - The \"rm\" and \"rmdir\" commands remove (delete) files and directories.\n", + "\n", + "\n", + "*Exercise 2:* Create a new directory called \"Data-1441\", and another directory inside \"Data-1441\" called \"Lab-1-Solutions\". Perform the rest of the lab in this directory." + ] + }, + { + "cell_type": "code", + "metadata": { + "colab_type": "code", + "id": "A16VzZ3G0J8x", + "colab": { + "base_uri": "https://localhost:8080/", + "height": 202 + }, + "outputId": "7b1372d3-595a-4fb3-e23e-9856f76a5a15" + }, + "source": [ + "!/bin/bash --noediting" + ], + "execution_count": 18, + "outputs": [ + { + "output_type": "stream", + "text": [ + "bash: cannot set terminal process group (101): Inappropriate ioctl for device\n", + "bash: no job control in this shell\n", + "\u001b]0;root@04c8ce3a6d36: /content/sample_data\u0007\u001b[01;32mroot@04c8ce3a6d36\u001b[00m:\u001b[01;34m/content/sample_data\u001b[00m# mkdir \"DATA 1441\"\n", + "\u001b]0;root@04c8ce3a6d36: /content/sample_data\u0007\u001b[01;32mroot@04c8ce3a6d36\u001b[00m:\u001b[01;34m/content/sample_data\u001b[00m# mkdir \"Lab-1-Solutions\"\n", + "\u001b]0;root@04c8ce3a6d36: /content/sample_data\u0007\u001b[01;32mroot@04c8ce3a6d36\u001b[00m:\u001b[01;34m/content/sample_data\u001b[00m# mv \"Lab-1-Solutions\" to \"DATA 1441\"\n", + "mv: cannot stat 'to': No such file or directory\n", + "\u001b]0;root@04c8ce3a6d36: /content/sample_data\u0007\u001b[01;32mroot@04c8ce3a6d36\u001b[00m:\u001b[01;34m/content/sample_data\u001b[00m# mv \"Lab-1-Solutions\" .. \"DATA 1441\"\n", + "mv: cannot stat 'Lab-1-Solutions': No such file or directory\n", + "mv: cannot move '..' to 'DATA 1441/..': Device or resource busy\n", + "\u001b]0;root@04c8ce3a6d36: /content/sample_data\u0007\u001b[01;32mroot@04c8ce3a6d36\u001b[00m:\u001b[01;34m/content/sample_data\u001b[00m# exit\n", + "exit\n" + ], + "name": "stdout" + } + ] + }, + { + "cell_type": "markdown", + "metadata": { + "colab_type": "text", + "id": "o38c4lbsqvzy" + }, + "source": [ + "## Exploring Unix Filesystem\n", + "\n", + "You can look at the root directory of the system by issuing \"ls /\". As explained in lecture, Unix uses the file system to communicate with devices and between processes. \"/etc\" keeps the configuration files of the system. \"/bin\" and \"/sbin\" store most of the standard Unix programs. \"/usr\" stores installed programs and their associate files, with \"/usr/bin\" usually storing the commands you can run. \n", + "\n", + "*Exercise 3:* List the \"/dev\" directory. How many SSD storage devices do you see? How many partitions does each device have? (Answer in box below)" + ] + }, + { + "cell_type": "code", + "metadata": { + "colab_type": "code", + "id": "yNj2LXzP2ksl", + "colab": { + "base_uri": "https://localhost:8080/", + "height": 202 + }, + "outputId": "396a2cb5-63fc-424d-e927-860db6d7dcb3" + }, + "source": [ + "!/bin/bash --noediting" + ], + "execution_count": 20, + "outputs": [ + { + "output_type": "stream", + "text": [ + "bash: cannot set terminal process group (101): Inappropriate ioctl for device\n", + "bash: no job control in this shell\n", + "\u001b]0;root@04c8ce3a6d36: /content/sample_data\u0007\u001b[01;32mroot@04c8ce3a6d36\u001b[00m:\u001b[01;34m/content/sample_data\u001b[00m# ls/ dev\n", + "bash: ls/: No such file or directory\n", + "\u001b]0;root@04c8ce3a6d36: /content/sample_data\u0007\u001b[01;32mroot@04c8ce3a6d36\u001b[00m:\u001b[01;34m/content/sample_data\u001b[00m# ls /dev\n", + "\u001b[0m\u001b[01;36mcore\u001b[0m \u001b[40;33;01mfull\u001b[0m \u001b[30;42mmqueue\u001b[0m \u001b[01;36mptmx\u001b[0m \u001b[40;33;01mrandom\u001b[0m \u001b[01;36mstderr\u001b[0m \u001b[01;36mstdout\u001b[0m \u001b[40;33;01murandom\u001b[0m\n", + "\u001b[01;36mfd\u001b[0m \u001b[40;33;01mfuse\u001b[0m \u001b[40;33;01mnull\u001b[0m \u001b[01;34mpts\u001b[0m \u001b[30;42mshm\u001b[0m \u001b[01;36mstdin\u001b[0m \u001b[40;33;01mtty\u001b[0m \u001b[40;33;01mzero\u001b[0m\n", + "\u001b]0;root@04c8ce3a6d36: /content/sample_data\u0007\u001b[01;32mroot@04c8ce3a6d36\u001b[00m:\u001b[01;34m/content/sample_data\u001b[00m# /bin /dev\n", + "bash: /bin: Is a directory\n", + "\u001b]0;root@04c8ce3a6d36: /content/sample_data\u0007\u001b[01;32mroot@04c8ce3a6d36\u001b[00m:\u001b[01;34m/content/sample_data\u001b[00m# exit\n", + "exit\n" + ], + "name": "stdout" + } + ] + }, + { + "cell_type": "markdown", + "metadata": { + "id": "vSdVhj3SJrsb", + "colab_type": "text" + }, + "source": [ + "SSD Storage- 6\n", + "partations -4" + ] + }, + { + "cell_type": "markdown", + "metadata": { + "colab_type": "text", + "id": "7P9EG0KOqvz2" + }, + "source": [ + "## Text File Manipulation\n", + "\n", + "As explained in lecture, Unix stores most information in text files. For example, the list of all users and their home directories are stored in \"/etc/passwd\". Let get some familiarity with the most commonly used commands to manipulate files.\n", + "\n", + " - You can see the contents contents a file using the \"cat\" (concatenate) command. Try executing \"cat /etc/passwd\". You'll get a huge list that will go by your screen quickly. \n", + " \n", + " - To go through the file page by page, you can use the \"less\" or \"more\" commands. \n", + " \n", + " - You can see the first or last N (N=10 by default) lines of a file using \"head\" or \"tail\" commands. For example \"tail -20 /etc/passwd\" will list the last 20 lines. \n", + " \n", + " - You can search a test file using the \"grep\" command, which takes a string keyword as the first argument and a filename as the second, and by default prints out every line in the file that contrains the string. So for example you can do \"grep \\$USER /etc/passwd\" to find the line corresponding to your account. Some useful flags: \n", + " \n", + " - \"-i\" ignores the case of the keyword\n", + " - \"-v\" display those lines that do NOT match \n", + " - \"-n\" precede each matching line with the line number \n", + " - \"-c\" print only the total count of matched lines \n", + " \n", + " For example \"grep -c \\$USER /etc/passwd\" should show that you are in the password file just once. \n", + " \n", + " - The \"wc\" (word count) command counts the number of lines, words, and characters in a file. By default \"wc\" gives you all three numbers, but \"-w\", \"-l\", or \"-c\" flags \n", + "\n", + "*Exercise 4:* Count how many lines in the password file contain the letter \"w\". " + ] + }, + { + "cell_type": "code", + "metadata": { + "colab_type": "code", + "id": "UlsANMuf2qMs", + "colab": { + "base_uri": "https://localhost:8080/", + "height": 655 + }, + "outputId": "bfeabd20-ab72-4be8-eb10-0aa5b5240185" + }, + "source": [ + "!/bin/bash --noediting" + ], + "execution_count": 21, + "outputs": [ + { + "output_type": "stream", + "text": [ + "bash: cannot set terminal process group (101): Inappropriate ioctl for device\n", + "bash: no job control in this shell\n", + "\u001b]0;root@04c8ce3a6d36: /content/sample_data\u0007\u001b[01;32mroot@04c8ce3a6d36\u001b[00m:\u001b[01;34m/content/sample_data\u001b[00m# cat /etc/passwd\n", + "root:x:0:0:root:/root:/bin/bash\n", + "daemon:x:1:1:daemon:/usr/sbin:/usr/sbin/nologin\n", + "bin:x:2:2:bin:/bin:/usr/sbin/nologin\n", + "sys:x:3:3:sys:/dev:/usr/sbin/nologin\n", + "sync:x:4:65534:sync:/bin:/bin/sync\n", + "games:x:5:60:games:/usr/games:/usr/sbin/nologin\n", + "man:x:6:12:man:/var/cache/man:/usr/sbin/nologin\n", + "lp:x:7:7:lp:/var/spool/lpd:/usr/sbin/nologin\n", + "mail:x:8:8:mail:/var/mail:/usr/sbin/nologin\n", + "news:x:9:9:news:/var/spool/news:/usr/sbin/nologin\n", + "uucp:x:10:10:uucp:/var/spool/uucp:/usr/sbin/nologin\n", + "proxy:x:13:13:proxy:/bin:/usr/sbin/nologin\n", + "www-data:x:33:33:www-data:/var/www:/usr/sbin/nologin\n", + "backup:x:34:34:backup:/var/backups:/usr/sbin/nologin\n", + "list:x:38:38:Mailing List Manager:/var/list:/usr/sbin/nologin\n", + "irc:x:39:39:ircd:/var/run/ircd:/usr/sbin/nologin\n", + "gnats:x:41:41:Gnats Bug-Reporting System (admin):/var/lib/gnats:/usr/sbin/nologin\n", + "nobody:x:65534:65534:nobody:/nonexistent:/usr/sbin/nologin\n", + "_apt:x:100:65534::/nonexistent:/usr/sbin/nologin\n", + "systemd-network:x:101:104:systemd Network Management,,,:/run/systemd/netif:/usr/sbin/nologin\n", + "systemd-resolve:x:102:105:systemd Resolver,,,:/run/systemd/resolve:/usr/sbin/nologin\n", + "nvidia-persistenced:x:103:107:NVIDIA Persistence Daemon,,,:/nonexistent:/usr/sbin/nologin\n", + "messagebus:x:104:108::/nonexistent:/usr/sbin/nologin\n", + "\u001b]0;root@04c8ce3a6d36: /content/sample_data\u0007\u001b[01;32mroot@04c8ce3a6d36\u001b[00m:\u001b[01;34m/content/sample_data\u001b[00m# tail-20 /etc/passwd\n", + "bash: tail-20: command not found\n", + "\u001b]0;root@04c8ce3a6d36: /content/sample_data\u0007\u001b[01;32mroot@04c8ce3a6d36\u001b[00m:\u001b[01;34m/content/sample_data\u001b[00m# tail -20/etc/passwd\n", + "tail: option used in invalid context -- 2\n", + "\u001b]0;root@04c8ce3a6d36: /content/sample_data\u0007\u001b[01;32mroot@04c8ce3a6d36\u001b[00m:\u001b[01;34m/content/sample_data\u001b[00m# grep $USER /etc/passwd\n", + "grep -i $w/etc/passwd\n", + "grep -i $w\u001b[01;31m\u001b[K/etc/passwd\u001b[m\u001b[K\n", + "exit\n", + "\n", + "\u001b]0;root@04c8ce3a6d36: /content/sample_data\u0007\u001b[01;32mroot@04c8ce3a6d36\u001b[00m:\u001b[01;34m/content/sample_data\u001b[00m# \n", + "\u001b]0;root@04c8ce3a6d36: /content/sample_data\u0007\u001b[01;32mroot@04c8ce3a6d36\u001b[00m:\u001b[01;34m/content/sample_data\u001b[00m# \n", + "\u001b]0;root@04c8ce3a6d36: /content/sample_data\u0007\u001b[01;32mroot@04c8ce3a6d36\u001b[00m:\u001b[01;34m/content/sample_data\u001b[00m# ^C\n" + ], + "name": "stdout" + } + ] + }, + { + "cell_type": "markdown", + "metadata": { + "colab_type": "text", + "id": "SZuhLbD8qvz5" + }, + "source": [ + "## Redirection\n", + "\n", + "Unix provides programs \"pipes\" for input and output. Most of what you see on the screen when you run a program was written to the \"stdout\" (standard output) pipe. Other pipes are \"stdin\" (standard input) and \"stderr\" (standard error), where error messages are written.\n", + "\n", + "As discussed in lecture, the basic commands of are simple, but you can chain them to do complicated things. Redirection is how you chain these commands, directing the output of one command to the input of the next.\n", + "\n", + "As an example, consider the \"cat\" command. Cat takes stdin and outputs it to stdout. Type \"cat\" and press enter and confirm. You can get back to the command prompt by pressing \"control-c\" (sends terminate singal) or \"control-d\" (end of file character). Note that from now on we will use the convention: \"control-d\" = \"^D\"\n", + "\n", + "*Exercise 5a:* Using \"cat\" and indirection you can write things into a file. The \">\" symbol directs stdout into a file. Try \"cat > favorite-colors-list.txt\" and then type in your 3 favorite colors, each on it's own line. Use \"^D\" to end your input." + ] + }, + { + "cell_type": "code", + "metadata": { + "id": "8AjwtGHFUCoD", + "colab_type": "code", + "colab": { + "base_uri": "https://localhost:8080/", + "height": 84 + }, + "outputId": "ab764931-12db-41af-e31b-dd37505599dd" + }, + "source": [ + "!/bin/bash --noediting" + ], + "execution_count": 22, + "outputs": [ + { + "output_type": "stream", + "text": [ + "bash: cannot set terminal process group (101): Inappropriate ioctl for device\n", + "bash: no job control in this shell\n", + "\u001b]0;root@04c8ce3a6d36: /content/sample_data\u0007\u001b[01;32mroot@04c8ce3a6d36\u001b[00m:\u001b[01;34m/content/sample_data\u001b[00m# exit\n", + "exit\n" + ], + "name": "stdout" + } + ] + }, + { + "cell_type": "markdown", + "metadata": { + "colab_type": "text", + "id": "H5vxtcXnqvz6" + }, + "source": [ + "Use \"cat\", \"more\", or \"less\" to confirm that you file is as you expect it. \">>\" allows you to append to the file. \n", + "\n", + "*Exercise 5b:* Append 2 more colors to your file." + ] + }, + { + "cell_type": "code", + "metadata": { + "colab_type": "code", + "id": "twRKNaGy3XGw", + "colab": {} + }, + "source": [ + "!/bin/bash --noediting" + ], + "execution_count": null, + "outputs": [] + }, + { + "cell_type": "markdown", + "metadata": { + "colab_type": "text", + "id": "DZODNKiAqvz8" + }, + "source": [ + "The \"sort\" command sorts what it sees on stdin. Instead of taking input from the terminal, you can direct the shell to take stdin from a file using \"<\". Try \"sort < favorite-color-list.txt\" and \"sort < favorite-color-list.txt > sorted-favorite-color-list.txt\".\n", + "\n", + "Finally, instead of piping input / output into files, you can directly chain one program into another using \"|\". So for example, you can do \"cat /etc/passwd | grep -i \\$USER | wc -l\". \n", + "\n", + "*Exercise 5c:* Use indirection to count the number of users on TACC with your first name. Copy the command you used into box below." + ] + }, + { + "cell_type": "code", + "metadata": { + "colab_type": "code", + "id": "oP9XlZl_3iZD", + "colab": {} + }, + "source": [ + "!/bin/bash --noediting" + ], + "execution_count": null, + "outputs": [] + }, + { + "cell_type": "markdown", + "metadata": { + "colab_type": "text", + "id": "v5IaZXNyqvz_" + }, + "source": [ + "## Git\n", + "\n", + "`git` is a Version Control System (VCS), typically used to organize the source code of software project but also good source of documents or web-pages. An instance of `git` server stores repositories, each typically containing the code relevant to a specific project. Users create local `clones` of repositories, change and develop the local copies of the code, `commit` the changes to their local repository, `push` to the server as a contribution, \n", + "`pull` updates from the server, and `merge` changes between local and remote versions. \n", + "\n", + "Besides cloning, repositories can be branched or forked. A repository generally starts with a `master` branch that evolves as push requests are merged in. Creating a new branch from an existing branch creates a snapshot of the which can evolve independently or be merged in later. Branches are easy to make and delete, and can serve various purposes. They can represent a stable version of software package. Or a parallel development for different operating system. A fork of a repository is a standalone instance of the repository which can be stored and managed independently from the original, where you can work independently without constraints or interference. \n", + "\n", + "[GitHub](github.com) provides a massive publically accessible instance of a `git` system besides sharing code, projects can be developed by the open source community. It provides tools for managing your repository and a wiki for documentation. Contributions to public software on GitHub generally require making a merge request which would be judged by the managers of the repository. That's why most software packages enourage you to create a new fork, so you can work independently.\n", + "\n", + "Lets take a look at some repositories:\n", + "\n", + "* [This class](https://github.com/UTA-DataScience/DATA1401.2020.Fall)\n", + "\n", + "\n", + "Read through [Version Control System Lecture](https://github.com/UTA-DataScience/VersionControlSystem/blob/master/VersionControlSystem/README.md) to better understand `git`. Note that you do not need to do the exercises at the end of the lecture.\n" + ] + }, + { + "cell_type": "markdown", + "metadata": { + "colab_type": "text", + "id": "J_R64sQDqv0A" + }, + "source": [ + "## Plan\n", + "\n", + "You made a clone of the class repository at start of this lab. We will create a new fork where you can keep track and submit your work, following [these instructions](https://help.github.com/articles/fork-a-repo/).\n", + "\n", + "Goto to github.com and log in.\n", + "\n", + "Next, lets create a fork of the [class repository](https://github.com/afarbin/DATA1401-Spring-2019). Click the link and press the \"Fork\" button on the top right. Select your repository as where you want to place the fork.\n" + ] + }, + { + "cell_type": "markdown", + "metadata": { + "colab_type": "text", + "id": "edTvE6rOqv0C" + }, + "source": [ + "Now we will check out your fork in your Google Drive / Colab.\n", + "\n", + "Note: Jupyter allows you to run shell directly in a notebook. We will use `!` and `%` to call shell commands directly in this notebook. Follow along yourself. Either create a new notebook or open a terminal. \n", + "\n", + "Start by listing the contents of your current directory." + ] + }, + { + "cell_type": "code", + "metadata": { + "colab_type": "code", + "id": "e5tXg0f8qv0D", + "colab": { + "base_uri": "https://localhost:8080/", + "height": 67 + }, + "outputId": "87c97308-1d64-47bf-8f2d-b0d7ffa0a568" + }, + "source": [ + "!ls" + ], + "execution_count": 23, + "outputs": [ + { + "output_type": "stream", + "text": [ + " anscombe.json\t\t 'DATA 1441'\t README.md\n", + " california_housing_test.csv mnist_test.csv\n", + " california_housing_train.csv mnist_train_small.csv\n" + ], + "name": "stdout" + } + ] + }, + { + "cell_type": "markdown", + "metadata": { + "colab_type": "text", + "id": "WYsyYcg1qv0J" + }, + "source": [ + "Make a new directory:" + ] + }, + { + "cell_type": "code", + "metadata": { + "colab_type": "code", + "id": "Z7noY1hMqv0L", + "colab": { + "base_uri": "https://localhost:8080/", + "height": 34 + }, + "outputId": "30e804f9-3ea6-443a-8ab9-ac99648d3a08" + }, + "source": [ + "!mkdir Data-1401-Repo\n", + "%cd Data-1401-Repo" + ], + "execution_count": 24, + "outputs": [ + { + "output_type": "stream", + "text": [ + "/content/sample_data/Data-1401-Repo\n" + ], + "name": "stdout" + } + ] + }, + { + "cell_type": "markdown", + "metadata": { + "colab_type": "text", + "id": "fwsBdTnYqv0Q" + }, + "source": [ + "From the github page for your fork, press the green \"Clone or download\" button and copy the URL.\n", + "\n", + "Goto to your notebook and use the following command to clone the repository, pasting the URL you just copied:\n" + ] + }, + { + "cell_type": "code", + "metadata": { + "colab_type": "code", + "id": "8w42MH6Jqv0S", + "colab": {} + }, + "source": [ + "# What you past here should look like:\n", + "#!git clone https://github.com//DATA1401.2020.Fall.git" + ], + "execution_count": 26, + "outputs": [] + }, + { + "cell_type": "markdown", + "metadata": { + "colab_type": "text", + "id": "cOAuqTVUqv0V" + }, + "source": [ + "Go into the directory:" + ] + }, + { + "cell_type": "code", + "metadata": { + "colab_type": "code", + "id": "b1Ew4tEZqv0X", + "colab": { + "base_uri": "https://localhost:8080/", + "height": 50 + }, + "outputId": "6c0c909f-5eed-4c42-fb8c-abea857dc9fb" + }, + "source": [ + "%cd DATA1401.2020.Fall\n", + "!ls" + ], + "execution_count": 27, + "outputs": [ + { + "output_type": "stream", + "text": [ + "[Errno 2] No such file or directory: 'DATA1401.2020.Fall'\n", + "/content/sample_data/Data-1401-Repo\n" + ], + "name": "stdout" + } + ] + }, + { + "cell_type": "markdown", + "metadata": { + "colab_type": "text", + "id": "IrhWToc-qv0a" + }, + "source": [ + "We will now connect your fork to the original so you can pull changes from there. \n", + "\n", + "Check remote status:" + ] + }, + { + "cell_type": "code", + "metadata": { + "colab_type": "code", + "id": "JxtMYR-9qv0c", + "colab": { + "base_uri": "https://localhost:8080/", + "height": 34 + }, + "outputId": "1860849c-91cb-4a0e-bd6f-38f8d5704563" + }, + "source": [ + "!git remote -v" + ], + "execution_count": 28, + "outputs": [ + { + "output_type": "stream", + "text": [ + "fatal: not a git repository (or any of the parent directories): .git\n" + ], + "name": "stdout" + } + ] + }, + { + "cell_type": "markdown", + "metadata": { + "colab_type": "text", + "id": "9ud3X0fBqv0f" + }, + "source": [ + "Now use the original class URL to set your upstream:" + ] + }, + { + "cell_type": "code", + "metadata": { + "colab_type": "code", + "id": "pgJlKxBqqv0h", + "colab": {} + }, + "source": [ + "!git remote add upstream https://github.com/UTA-DataScience/DATA1401.2020.Fall" + ], + "execution_count": null, + "outputs": [] + }, + { + "cell_type": "code", + "metadata": { + "colab_type": "code", + "id": "id2yUEt9qv0k", + "colab": {} + }, + "source": [ + "!git remote -v" + ], + "execution_count": null, + "outputs": [] + }, + { + "cell_type": "markdown", + "metadata": { + "colab_type": "text", + "id": "sAkgeJ6Iqv0n" + }, + "source": [ + "From now on, you can get the newest version of class material by using:" + ] + }, + { + "cell_type": "code", + "metadata": { + "colab_type": "code", + "id": "AGDsfTFLqv0o", + "colab": { + "base_uri": "https://localhost:8080/", + "height": 34 + }, + "outputId": "b6c6693d-b7a9-425a-e6dc-4c59cf958105" + }, + "source": [ + "!git pull" + ], + "execution_count": 29, + "outputs": [ + { + "output_type": "stream", + "text": [ + "fatal: not a git repository (or any of the parent directories): .git\n" + ], + "name": "stdout" + } + ] + }, + { + "cell_type": "markdown", + "metadata": { + "colab_type": "text", + "id": "u9RAhs5b4vXY" + }, + "source": [ + "We will submit your Lab 1 using git at the next Lab." + ] + } + ] +} \ No newline at end of file diff --git a/Labs/Lab.3/Copy_of_Lab_3.ipynb b/Labs/Lab.3/Copy_of_Lab_3.ipynb new file mode 100644 index 0000000..b6a5609 --- /dev/null +++ b/Labs/Lab.3/Copy_of_Lab_3.ipynb @@ -0,0 +1,532 @@ +{ + "nbformat": 4, + "nbformat_minor": 0, + "metadata": { + "kernelspec": { + "display_name": "Python 3", + "language": "python", + "name": "python3" + }, + "language_info": { + "codemirror_mode": { + "name": "ipython", + "version": 3 + }, + "file_extension": ".py", + "mimetype": "text/x-python", + "name": "python", + "nbconvert_exporter": "python", + "pygments_lexer": "ipython3", + "version": "3.8.0" + }, + "colab": { + "name": "Copy of Lab.3.ipynb", + "provenance": [] + } + }, + "cells": [ + { + "cell_type": "markdown", + "metadata": { + "id": "_jGzat99oZoz" + }, + "source": [ + "# Lab 3- Tic Tac Toe\n", + "\n", + "[![Open In Colab](https://colab.research.google.com/assets/colab-badge.svg)](https://colab.research.google.com/github/UTA-DataScience/DATA1401.2020.Fall/blob/master/Labs/Lab.3/Lab.3.ipynb)\n", + "\n", + "In this lab your will build a n x n Tic Tac Toe game. As you do the exercises, make sure your solutions work for any size Tic Tac Toe game. " + ] + }, + { + "cell_type": "markdown", + "metadata": { + "id": "pCZYvurioZo0" + }, + "source": [ + "*Exercise 1:* Write a function that creates an n by n matrix (of list of lists) which will represent the state of a Tie Tac Toe game. Let 0, 1, and 2 represent empty, \"X\", or \"O\".\n" + ] + }, + { + "cell_type": "code", + "metadata": { + "id": "GyKnoxY2oZo2" + }, + "source": [ + "# Write you solution here\n", + "def make_n_matrix(size):\n", + " empty=0\n", + " player_1=1\n", + " player_2=2\n", + " board= list()\n", + " for i in range(size):\n", + " row=list()\n", + " for j in range(size):\n", + " row.append(empty)\n", + " board.append(row)\n", + " return board" + ], + "execution_count": null, + "outputs": [] + }, + { + "cell_type": "code", + "metadata": { + "id": "oMSAZq2NoZo9", + "outputId": "5d4c8506-6cab-4f2d-cb6b-c688cdecacaf", + "colab": { + "base_uri": "https://localhost:8080/", + "height": 118 + } + }, + "source": [ + "# Test your solution here\n", + "make_n_matrix(6)" + ], + "execution_count": null, + "outputs": [ + { + "output_type": "execute_result", + "data": { + "text/plain": [ + "[[0, 0, 0, 0, 0, 0],\n", + " [0, 0, 0, 0, 0, 0],\n", + " [0, 0, 0, 0, 0, 0],\n", + " [0, 0, 0, 0, 0, 0],\n", + " [0, 0, 0, 0, 0, 0],\n", + " [0, 0, 0, 0, 0, 0]]" + ] + }, + "metadata": { + "tags": [] + }, + "execution_count": 3 + } + ] + }, + { + "cell_type": "markdown", + "metadata": { + "id": "OZlYfoA0oZpD" + }, + "source": [ + "*Exercise 2:* Write a function that takes a `n` by `n` matrix representing a tic-tac-toe game, and returns -1, 0, 1, or 2 indicating the game is incomplete, the game is a draw, player 1 has won, or player 2 has one, respectively. Here are some example inputs you can use to test your code:" + ] + }, + { + "cell_type": "code", + "metadata": { + "id": "-1iH3mj1oZpI" + }, + "source": [ + "winner_is_2 = [[2, 2, 0],\n", + "\t[2, 1, 0],\n", + "\t[2, 1, 1]]\n", + "\n", + "winner_is_1 = [[1, 2, 0],\n", + "\t[2, 1, 0],\n", + "\t[2, 1, 1]]\n", + "\n", + "winner_is_also_1 = [[0, 1, 0],\n", + "\t[2, 1, 0],\n", + "\t[2, 1, 1]]\n", + "\n", + "no_winner = [[1, 2, 0],\n", + "\t[2, 1, 0],\n", + "\t[2, 1, 2]]\n", + "\n", + "also_no_winner = [[1, 2, 0],\n", + "\t[2, 1, 0],\n", + "\t[2, 1, 0]]" + ], + "execution_count": null, + "outputs": [] + }, + { + "cell_type": "code", + "metadata": { + "id": "Q866S3D7oZpP" + }, + "source": [ + "# Write you solution here\n", + "def winner_check(board):\n", + " board_list= list(board)\n", + " #turning a matrix into list to compare the elements \n", + " #counting the elements in the list\n", + " count=0\n", + " for i in range(0,len(board_list)):\n", + " if i==1 or i==2:\n", + " count +=1\n", + " return (count)\n", + " #to start comparing the list must have atleast 5 games played in total\n", + " if count>=5:\n", + " if board_list[0]==board_list[1]==board_list[2]==1:\n", + " print(\"Winner=1!\")\n", + " elif board_list[0]==board_list[1]==board_list[2]==2:\n", + " print(\"winner==2\")\n", + " elif board_list[3]==board_list[4]==board_list[5]==1:\n", + " print(\"Winner=1!\")\n", + " elif board_list[3]==board_list[4]==board_list[5]==2:\n", + " print(\"Winner=2!\")\n", + " elif board_list[6]==board_list[7]==board_list[8]==1:\n", + " print(\"Winner=1!\")\n", + " elif board_list[6]==board_list[7]==board_list[8]==2:\n", + " print(\"Winner=2!\")\n", + " elif board_list[0]==board_list[3]==board_list[6]==1:\n", + " print(\"Winner=1!\")\n", + " elif board_list[1]==board_list[4]==board_list[7]==1:\n", + " print(\"Winner=1!\")\n", + " elif board_list[2]==board_list[5]==board_list[8]==1:\n", + " print(\"Winner=1!\")\n", + " elif board_list[0]==board_list[4]==board_list[8]==1:\n", + " print(\"Winner=1!\")\n", + " elif board_list[2]==board_list[4]==board_list[6]==1:\n", + " print(\"Winner=1!\")\n", + " elif board_list[0]==board_list[3]==board_list[6]==2:\n", + " print(\"Winner=2!\")\n", + " elif board_list[1]==board_list[4]==board_list[7]==2:\n", + " print(\"Winner=2!\")\n", + " elif board_list[2]==board_list[5]==board_list[8]==2:\n", + " print(\"Winner=2!\")\n", + " elif board_list[0]==board_list[4]==board_list[8]==2:\n", + " print(\"Winner=2!\")\n", + " elif board_list[2]==board_list[4]==board_list[6]==2:\n", + " print(\"Winner=2!\")\n", + " else:\n", + " print(\"its a draw: 0\")\n", + " else:\n", + " print(\"The game is incomplete!!=-1!\")" + ], + "execution_count": null, + "outputs": [] + }, + { + "cell_type": "code", + "metadata": { + "id": "Ldk4lorVoZpX", + "outputId": "043e80e6-c59a-427b-e6f0-5af6dc1ced23", + "colab": { + "base_uri": "https://localhost:8080/", + "height": 128 + } + }, + "source": [ + "# Test your solution here\n", + "def winner_check([1, 2, 0],\n", + "\t[2, 1, 0],\n", + "\t[2, 1, 0])" + ], + "execution_count": null, + "outputs": [ + { + "output_type": "error", + "ename": "SyntaxError", + "evalue": "ignored", + "traceback": [ + "\u001b[0;36m File \u001b[0;32m\"\"\u001b[0;36m, line \u001b[0;32m2\u001b[0m\n\u001b[0;31m def winner_check([1, 2, 0],\u001b[0m\n\u001b[0m ^\u001b[0m\n\u001b[0;31mSyntaxError\u001b[0m\u001b[0;31m:\u001b[0m invalid syntax\n" + ] + } + ] + }, + { + "cell_type": "markdown", + "metadata": { + "id": "wFKxXtd_oZpe" + }, + "source": [ + "*Exercise 3:* Write a function that takes 2 integers `n` and `m` as input and draws a `n` by `m` game board. For example the following is a 3x3 board:\n", + "```\n", + " --- --- --- \n", + " | | | | \n", + " --- --- --- \n", + " | | | | \n", + " --- --- --- \n", + " | | | | \n", + " --- --- --- \n", + " ```" + ] + }, + { + "cell_type": "code", + "metadata": { + "id": "cu80wyzOoZpf" + }, + "source": [ + "# Write you solution here\n", + "def board_structure(n,m):\n", + " for n in range(n):\n", + " if n%2==1:\n", + " rows1= [\"---\"]*(n-1)\n", + " print(rows1)\n", + " else:\n", + " rows2=[\"l\"]*(n-1)\n", + " print(rows2)\n", + " " + ], + "execution_count": null, + "outputs": [] + }, + { + "cell_type": "code", + "metadata": { + "id": "uTT83IISoZpo", + "outputId": "03d380fe-69ea-434b-a9f8-26f9ac979fa2", + "colab": { + "base_uri": "https://localhost:8080/", + "height": 34 + } + }, + "source": [ + "# Test your solution here\n", + "board_structure(3,3)" + ], + "execution_count": null, + "outputs": [ + { + "output_type": "stream", + "text": [ + "[]\n" + ], + "name": "stdout" + } + ] + }, + { + "cell_type": "markdown", + "metadata": { + "id": "QrpWg-qVoZpv" + }, + "source": [ + "*Exercise 4:* Modify exercise 3, so that it takes a matrix of the form from exercise 2 and draws a tic-tac-tie board with \"X\"s and \"O\"s. " + ] + }, + { + "cell_type": "code", + "metadata": { + "id": "cWqKtQDxoZpw" + }, + "source": [ + "# Write you solution here" + ], + "execution_count": null, + "outputs": [] + }, + { + "cell_type": "code", + "metadata": { + "id": "j-dEUPgKoZp2" + }, + "source": [ + "# Test your solution here" + ], + "execution_count": null, + "outputs": [] + }, + { + "cell_type": "markdown", + "metadata": { + "id": "a4DngO7PoZp-" + }, + "source": [ + "*Exercise 5:* Write a function that takes a game board, player number, and `(x,y)` coordinates and places \"X\" or \"O\" in the correct location of the game board. Make sure that you only allow filling previously empty locations. Return `True` or `False` to indicate successful placement of \"X\" or \"O\"." + ] + }, + { + "cell_type": "code", + "metadata": { + "id": "Ph1SE-8woZp_" + }, + "source": [ + "# Write you solution here" + ], + "execution_count": null, + "outputs": [] + }, + { + "cell_type": "code", + "metadata": { + "id": "rM2_E2L8oZqG" + }, + "source": [ + "# Test your solution here" + ], + "execution_count": null, + "outputs": [] + }, + { + "cell_type": "markdown", + "metadata": { + "id": "N-8T1sgqoZqM" + }, + "source": [ + "*Exercise 6:* Modify Exercise 4 to show column and row labels so that players can specify location using \"A2\" or \"C1\"." + ] + }, + { + "cell_type": "code", + "metadata": { + "id": "amt-O3RSoZqN" + }, + "source": [ + "# Write you solution here" + ], + "execution_count": null, + "outputs": [] + }, + { + "cell_type": "code", + "metadata": { + "id": "gKOnt7QPoZqU" + }, + "source": [ + "# Test your solution here" + ], + "execution_count": null, + "outputs": [] + }, + { + "cell_type": "markdown", + "metadata": { + "id": "W6BmhXlEoZqb" + }, + "source": [ + "*Exercise 7:* Write a function that takes a board, player number, and location specified as in exercise 6 and then calls exercise 5 to correctly modify the board. " + ] + }, + { + "cell_type": "code", + "metadata": { + "id": "93dgegFdoZqc" + }, + "source": [ + "# Write you solution here" + ], + "execution_count": null, + "outputs": [] + }, + { + "cell_type": "code", + "metadata": { + "id": "DgGJOyomoZqi" + }, + "source": [ + "# Test your solution here" + ], + "execution_count": null, + "outputs": [] + }, + { + "cell_type": "markdown", + "metadata": { + "id": "26XZZgJMoZqq" + }, + "source": [ + "*Exercise 8:* Write a function is called with a board and player number, takes input from the player using python's `input`, and modifies the board using your function from exercise 7. Note that you should keep asking for input until you have gotten a valid input that results in a valid move." + ] + }, + { + "cell_type": "code", + "metadata": { + "id": "zkjwIwEIoZqr" + }, + "source": [ + "# Write you solution here" + ], + "execution_count": null, + "outputs": [] + }, + { + "cell_type": "code", + "metadata": { + "id": "Ffc11E82oZqy" + }, + "source": [ + "# Test your solution here" + ], + "execution_count": null, + "outputs": [] + }, + { + "cell_type": "markdown", + "metadata": { + "id": "-L-NFG4toZq3" + }, + "source": [ + "*Exercise 9:* Use all of the previous exercises to implement a full tic-tac-toe game, where an appropriate board is drawn, 2 players are repeatedly asked for a location coordinates of where they wish to place a mark, and the game status is checked until a player wins or a draw occurs." + ] + }, + { + "cell_type": "code", + "metadata": { + "id": "p5WzvRk4oZq4" + }, + "source": [ + "# Write you solution here" + ], + "execution_count": null, + "outputs": [] + }, + { + "cell_type": "code", + "metadata": { + "id": "epo7XaaxoZq-" + }, + "source": [ + "# Test your solution here" + ], + "execution_count": null, + "outputs": [] + }, + { + "cell_type": "markdown", + "metadata": { + "id": "XiNNsHC1oZrD" + }, + "source": [ + "*Exercise 10:* Test that your game works for 5x5 Tic Tac Toe. " + ] + }, + { + "cell_type": "code", + "metadata": { + "id": "Iz87iT2qoZrE" + }, + "source": [ + "# Test your solution here" + ], + "execution_count": null, + "outputs": [] + }, + { + "cell_type": "markdown", + "metadata": { + "id": "x-ruOL42oZrL" + }, + "source": [ + "*Exercise 11: (Extra Credit)* Develop a version of the game where one player is the computer. Note that you don't need to do an extensive seach for the best move. You can have the computer simply protect against loosing and otherwise try to win with straight or diagonal patterns." + ] + }, + { + "cell_type": "code", + "metadata": { + "id": "3PAcMjK_oZrN" + }, + "source": [ + "# Write you solution here" + ], + "execution_count": null, + "outputs": [] + }, + { + "cell_type": "code", + "metadata": { + "id": "KAGgBM6RoZrZ" + }, + "source": [ + "# Test your solution here" + ], + "execution_count": null, + "outputs": [] + } + ] +} \ No newline at end of file diff --git a/Quizzes/Quiz.1/Copy_of_Quiz_1.ipynb b/Quizzes/Quiz.1/Copy_of_Quiz_1.ipynb new file mode 100644 index 0000000..34b48d8 --- /dev/null +++ b/Quizzes/Quiz.1/Copy_of_Quiz_1.ipynb @@ -0,0 +1,248 @@ +{ + "nbformat": 4, + "nbformat_minor": 0, + "metadata": { + "kernelspec": { + "display_name": "Python 3", + "language": "python", + "name": "python3" + }, + "language_info": { + "codemirror_mode": { + "name": "ipython", + "version": 3 + }, + "file_extension": ".py", + "mimetype": "text/x-python", + "name": "python", + "nbconvert_exporter": "python", + "pygments_lexer": "ipython3", + "version": "3.8.0" + }, + "colab": { + "name": "Copy of Quiz.1.ipynb", + "provenance": [] + } + }, + "cells": [ + { + "cell_type": "markdown", + "metadata": { + "id": "AXZSLiqEk1oW" + }, + "source": [ + "# Quiz 1\n", + "\n", + "[![Open In Colab](https://colab.research.google.com/assets/colab-badge.svg)](https://colab.research.google.com/github/UTA-DataScience/DATA1401.2020.Fall/blob/master/Quizzes/Quiz.1/Quiz.1.ipynb)\n", + "\n", + "\n", + "\n", + "\n", + "1. Using the lists below, create a function (`make_deck`) that returns a list of the 52 cards in a usual playing card deck. Represent each card as a tuple (e.g. `('Clubs', 3)`). " + ] + }, + { + "cell_type": "code", + "metadata": { + "id": "j1r26SJxk1oY", + "outputId": "f8d5a292-f90c-4766-85c1-e8b6495416bc", + "colab": { + "base_uri": "https://localhost:8080/", + "height": 50 + } + }, + "source": [ + "suits = [\"Clubs\", \"Diamonds\", \"Hearts\", \"Spades\"]\n", + "values = list(range(2,11)) + [ \"Jack\", \"Queen\", \"King\", \"Ace\"]\n", + "print(suits)\n", + "print(values)" + ], + "execution_count": 1, + "outputs": [ + { + "output_type": "stream", + "text": [ + "['Clubs', 'Diamonds', 'Hearts', 'Spades']\n", + "[2, 3, 4, 5, 6, 7, 8, 9, 10, 'Jack', 'Queen', 'King', 'Ace']\n" + ], + "name": "stdout" + } + ] + }, + { + "cell_type": "code", + "metadata": { + "id": "TREa-XJLk1od" + }, + "source": [ + "# Your solution here\n", + "def make_deck():\n", + " deck=[(i,j) for j in values for i in suits]\n", + " return deck" + ], + "execution_count": 15, + "outputs": [] + }, + { + "cell_type": "code", + "metadata": { + "id": "W0PjdmU1k1oh", + "outputId": "9163c098-ad19-42ec-e894-b52b7d374900", + "colab": { + "base_uri": "https://localhost:8080/", + "height": 890 + } + }, + "source": [ + "# Test your solution here\n", + "make_deck()" + ], + "execution_count": 16, + "outputs": [ + { + "output_type": "execute_result", + "data": { + "text/plain": [ + "[('Clubs', 2),\n", + " ('Diamonds', 2),\n", + " ('Hearts', 2),\n", + " ('Spades', 2),\n", + " ('Clubs', 3),\n", + " ('Diamonds', 3),\n", + " ('Hearts', 3),\n", + " ('Spades', 3),\n", + " ('Clubs', 4),\n", + " ('Diamonds', 4),\n", + " ('Hearts', 4),\n", + " ('Spades', 4),\n", + " ('Clubs', 5),\n", + " ('Diamonds', 5),\n", + " ('Hearts', 5),\n", + " ('Spades', 5),\n", + " ('Clubs', 6),\n", + " ('Diamonds', 6),\n", + " ('Hearts', 6),\n", + " ('Spades', 6),\n", + " ('Clubs', 7),\n", + " ('Diamonds', 7),\n", + " ('Hearts', 7),\n", + " ('Spades', 7),\n", + " ('Clubs', 8),\n", + " ('Diamonds', 8),\n", + " ('Hearts', 8),\n", + " ('Spades', 8),\n", + " ('Clubs', 9),\n", + " ('Diamonds', 9),\n", + " ('Hearts', 9),\n", + " ('Spades', 9),\n", + " ('Clubs', 10),\n", + " ('Diamonds', 10),\n", + " ('Hearts', 10),\n", + " ('Spades', 10),\n", + " ('Clubs', 'Jack'),\n", + " ('Diamonds', 'Jack'),\n", + " ('Hearts', 'Jack'),\n", + " ('Spades', 'Jack'),\n", + " ('Clubs', 'Queen'),\n", + " ('Diamonds', 'Queen'),\n", + " ('Hearts', 'Queen'),\n", + " ('Spades', 'Queen'),\n", + " ('Clubs', 'King'),\n", + " ('Diamonds', 'King'),\n", + " ('Hearts', 'King'),\n", + " ('Spades', 'King'),\n", + " ('Clubs', 'Ace'),\n", + " ('Diamonds', 'Ace'),\n", + " ('Hearts', 'Ace'),\n", + " ('Spades', 'Ace')]" + ] + }, + "metadata": { + "tags": [] + }, + "execution_count": 16 + } + ] + }, + { + "cell_type": "markdown", + "metadata": { + "id": "HRoKNtoZk1ou" + }, + "source": [ + "2. Create the following functions that take in a list of [usually 5] cards (`hand`) and return True/False:\n", + " * `flush(hand)`: Checks if the cards in the hand are of the same suit.\n", + " * `straight(hand)`: Checks if the cards in the hand are in a order.\n", + " * You can start with just checking numerical cards.\n", + " * Extra Credit: Include all cards.\n", + " * `straight_flush(hand)`: Combination of both." + ] + }, + { + "cell_type": "code", + "metadata": { + "id": "sa2Z1J36k1ov" + }, + "source": [ + "# Your solution here\n", + "#flush(hand)\n", + "def flush(hand):\n", + " hand_list=list(hand)\n", + " if hand_list[0]==hand_list[2]==hand_list[4]==hand_list[6]==hand_list[8]:\n", + " print(\"True\")" + ], + "execution_count": 21, + "outputs": [] + }, + { + "cell_type": "code", + "metadata": { + "id": "FHxuMy4Dk1oz" + }, + "source": [ + "# Test your solution here\n" + ], + "execution_count": 22, + "outputs": [] + }, + { + "cell_type": "code", + "metadata": { + "id": "9Rs34q5ApuOk" + }, + "source": [ + "#straight(hand)\n", + "def straight(hand):\n", + " list_values=()\n", + " for i in range(len(hand)):\n", + " if i%2==1:\n", + " list_values.append(i)\n", + " return (list_values)\n" + ], + "execution_count": 23, + "outputs": [] + }, + { + "cell_type": "code", + "metadata": { + "id": "D6lFfSR4siZe" + }, + "source": [ + "" + ], + "execution_count": 27, + "outputs": [] + }, + { + "cell_type": "code", + "metadata": { + "id": "Rc0bqIBPswVK" + }, + "source": [ + "" + ], + "execution_count": null, + "outputs": [] + } + ] +} \ No newline at end of file