{ "cells": [ { "cell_type": "raw", "metadata": {}, "source": [ "---\n", "sidebar_label: \"Prolog-Hello-World\"\n", "sidebar_position: 10\n", "---" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "# Prolog Hello World\n", "\n", "[![Open In Colab](https://colab.research.google.com/assets/colab-badge.svg)](https://colab.research.google.com/github/bacalhau-project/examples/blob/main/workload-onboarding/Prolog-Hello-World/index.ipynb)\n", "[![Open In Binder](https://mybinder.org/badge.svg)](https://mybinder.org/v2/gh/bacalhau-project/examples/HEAD?labpath=workload-onboarding/Prolog-Hello-World/index.ipynb)" ] }, { "cell_type": "markdown", "metadata": { "id": "nj1-Kp2gw7kU" }, "source": [ "## Introduction\n", "Prolog is intended primarily as a declarative programming language: the program logic is expressed in terms of relations, represented as facts and rules. A computation is initiated by running a query over these relations.\n", "Prolog is well-suited for specific tasks that benefit from rule-based logical queries such as searching databases, voice control systems, and filling templates.\n", "In this example we will run a hello world prolog script on bacalhau\n", "\n" ] }, { "cell_type": "markdown", "metadata": { "id": "DrdQTcaPxDll" }, "source": [ "## Running Locally​\n" ] }, { "cell_type": "markdown", "metadata": { "id": "IvMPtL4xxGFj" }, "source": [ "Install swipl \n" ] }, { "cell_type": "code", "execution_count": null, "metadata": { "colab": { "base_uri": "https://localhost:8080/" }, "id": "exnVKu_pxH_r", "outputId": "1d536b36-3864-4efa-c27c-071b9b3ac1f6", "tags": [ "skip-execution" ] }, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ " Comprehensive Prolog implementation with extensive libraries and development tools. Primarily targetted at teaching, RDF processing and web-related tasks, such as creating web services or analysing web content.\n", "\n", "Official PPAs for SWI-Prolog. See https://www.swi-prolog.org for further information.\n", " More info: https://launchpad.net/~swi-prolog/+archive/ubuntu/stable\n", "Hit:1 https://cloud.r-project.org/bin/linux/ubuntu bionic-cran40/ InRelease\n", "Hit:2 http://ppa.launchpad.net/c2d4u.team/c2d4u4.0+/ubuntu bionic InRelease\n", "Hit:3 http://archive.ubuntu.com/ubuntu bionic InRelease\n", "Get:4 http://security.ubuntu.com/ubuntu bionic-security InRelease [88.7 kB]\n", "Ign:5 https://developer.download.nvidia.com/compute/machine-learning/repos/ubuntu1804/x86_64 InRelease\n", "Hit:6 https://developer.download.nvidia.com/compute/cuda/repos/ubuntu1804/x86_64 InRelease\n", "Hit:7 https://developer.download.nvidia.com/compute/machine-learning/repos/ubuntu1804/x86_64 Release\n", "Get:8 http://archive.ubuntu.com/ubuntu bionic-updates InRelease [88.7 kB]\n", "Hit:9 http://ppa.launchpad.net/cran/libgit2/ubuntu bionic InRelease\n", "Hit:10 http://ppa.launchpad.net/deadsnakes/ppa/ubuntu bionic InRelease\n", "Get:11 http://archive.ubuntu.com/ubuntu bionic-backports InRelease [83.3 kB]\n", "Hit:12 http://ppa.launchpad.net/graphics-drivers/ppa/ubuntu bionic InRelease\n", "Hit:13 http://ppa.launchpad.net/swi-prolog/stable/ubuntu bionic InRelease\n", "Fetched 261 kB in 2s (141 kB/s)\n", "Reading package lists...\n", "Hit:1 https://cloud.r-project.org/bin/linux/ubuntu bionic-cran40/ InRelease\n", "Ign:2 https://developer.download.nvidia.com/compute/machine-learning/repos/ubuntu1804/x86_64 InRelease\n", "Hit:3 https://developer.download.nvidia.com/compute/cuda/repos/ubuntu1804/x86_64 InRelease\n", "Hit:4 https://developer.download.nvidia.com/compute/machine-learning/repos/ubuntu1804/x86_64 Release\n", "Hit:6 http://ppa.launchpad.net/c2d4u.team/c2d4u4.0+/ubuntu bionic InRelease\n", "Get:7 http://security.ubuntu.com/ubuntu bionic-security InRelease [88.7 kB]\n", "Hit:8 http://ppa.launchpad.net/cran/libgit2/ubuntu bionic InRelease\n", "Hit:9 http://archive.ubuntu.com/ubuntu bionic InRelease\n", "Get:10 http://archive.ubuntu.com/ubuntu bionic-updates InRelease [88.7 kB]\n", "Get:11 http://archive.ubuntu.com/ubuntu bionic-backports InRelease [83.3 kB]\n", "Hit:12 http://ppa.launchpad.net/deadsnakes/ppa/ubuntu bionic InRelease\n", "Hit:13 http://ppa.launchpad.net/graphics-drivers/ppa/ubuntu bionic InRelease\n", "Hit:14 http://ppa.launchpad.net/swi-prolog/stable/ubuntu bionic InRelease\n", "Fetched 261 kB in 5s (57.4 kB/s)\n", "Reading package lists...\n", "Reading package lists...\n", "Building dependency tree...\n", "Reading state information...\n", "swi-prolog is already the newest version (8.4.3-0-bionicppa2).\n", "The following package was automatically installed and is no longer required:\n", " libnvidia-common-460\n", "Use 'sudo apt autoremove' to remove it.\n", "0 upgraded, 0 newly installed, 0 to remove and 5 not upgraded.\n" ] } ], "source": [ "%%bash\n", "sudo add-apt-repository ppa:swi-prolog/stable\n", "sudo apt-get update\n", "sudo apt-get install swi-prolog" ] }, { "cell_type": "markdown", "metadata": { "id": "DmWJsNYVxNzk" }, "source": [ "Create a file called helloworld.pl \n", "\n", "The following script prints ‘Hello World’ to the stdout\n" ] }, { "cell_type": "code", "execution_count": null, "metadata": { "colab": { "base_uri": "https://localhost:8080/" }, "id": "f6mZ2BJBxK_A", "outputId": "8b5129d1-fb7e-4f48-a5f2-368aa3d2df62", "tags": [ "skip-execution" ] }, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ "Overwriting helloworld.pl\n" ] } ], "source": [ "%%writefile helloworld.pl\n", "hello_world :- write('Hello World'), nl, \n", " halt." ] }, { "cell_type": "markdown", "metadata": { "id": "ob7hpDK8xblS" }, "source": [ "Running the script\n" ] }, { "cell_type": "code", "execution_count": null, "metadata": { "colab": { "base_uri": "https://localhost:8080/" }, "id": "eGKyvFesxdkC", "outputId": "c261cf03-9a48-405f-bef0-38661b436e13", "tags": [ "skip-execution" ] }, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ "Hello World\n" ] } ], "source": [ "%%bash\n", "swipl -q -s helloworld.pl -g hello_world" ] }, { "cell_type": "markdown", "metadata": { "id": "S_0U_66dzGUB" }, "source": [ "After the script has run successfully locally we can now run it on bacalhau\n", "\n", "For that we upload our script to IPFS since the script is only present locally\n", "ipfs add helloworld.pl\n", "\n", "Using IPFS cli\n" ] }, { "cell_type": "code", "execution_count": null, "metadata": { "colab": { "base_uri": "https://localhost:8080/" }, "id": "aCfmI2YY4JFE", "outputId": "b106a21f-1513-4305-9203-151c369df2c5", "tags": [ "skip-execution" ] }, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ "--2022-11-12 08:44:36-- https://dist.ipfs.io/go-ipfs/v0.4.2/go-ipfs_v0.4.2_linux-amd64.tar.gz\n", "Resolving dist.ipfs.io (dist.ipfs.io)... 209.94.78.1, 2602:fea2:3::1\n", "Connecting to dist.ipfs.io (dist.ipfs.io)|209.94.78.1|:443... connected.\n", "HTTP request sent, awaiting response... 200 OK\n", "Length: 7642422 (7.3M) [application/gzip]\n", "Saving to: ‘go-ipfs_v0.4.2_linux-amd64.tar.gz.4’\n", "\n", "\r go-ipfs_v 0%[ ] 0 --.-KB/s \rgo-ipfs_v0.4.2_linu 100%[===================>] 7.29M --.-KB/s in 0.04s \n", "\n", "2022-11-12 08:44:36 (206 MB/s) - ‘go-ipfs_v0.4.2_linux-amd64.tar.gz.4’ saved [7642422/7642422]\n", "\n", "go-ipfs/build-log\n", "go-ipfs/install.sh\n", "go-ipfs/ipfs\n", "go-ipfs/LICENSE\n", "go-ipfs/README.md\n", "Error: ipfs daemon is running. please stop it to run this command\n", "Use 'ipfs init --help' for information about this command\n", "Hello and Welcome to IPFS!\n", "\n", "██╗██████╗ ███████╗███████╗\n", "██║██╔══██╗██╔════╝██╔════╝\n", "██║██████╔╝█████╗ ███████╗\n", "██║██╔═══╝ ██╔══╝ ╚════██║\n", "██║██║ ██║ ███████║\n", "╚═╝╚═╝ ╚═╝ ╚══════╝\n", "\n", "If you're seeing this, you have successfully installed\n", "IPFS and are now interfacing with the ipfs merkledag!\n", "\n", " -------------------------------------------------------\n", "| Warning: |\n", "| This is alpha software. Use at your own discretion! |\n", "| Much is missing or lacking polish. There are bugs. |\n", "| Not yet secure. Read the security notes for more. |\n", " -------------------------------------------------------\n", "\n", "Check out some of the other files in this directory:\n", "\n", " ./about\n", " ./help\n", " ./quick-start <-- usage examples\n", " ./readme <-- this file\n", " ./security-notes\n", "nohup: redirecting stderr to stdout\n" ] } ], "source": [ "!wget https://dist.ipfs.io/go-ipfs/v0.4.2/go-ipfs_v0.4.2_linux-amd64.tar.gz\n", "!tar xvfz go-ipfs_v0.4.2_linux-amd64.tar.gz\n", "!mv go-ipfs/ipfs /usr/local/bin/ipfs\n", "!ipfs init\n", "!ipfs cat /ipfs/QmYwAPJzv5CZsnA625s3Xf2nemtYgPpHdWEz79ojWnPbdG/readme\n", "!ipfs config Addresses.Gateway /ip4/127.0.0.1/tcp/8082\n", "!ipfs config Addresses.API /ip4/127.0.0.1/tcp/5002\n", "!nohup ipfs daemon > startup.log &" ] }, { "cell_type": "code", "execution_count": null, "metadata": { "colab": { "base_uri": "https://localhost:8080/" }, "id": "fnDSoKm44NQj", "outputId": "cc31251c-c29d-48bf-b282-22105cfa68b3", "tags": [ "skip-execution" ] }, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ "\r62 B / 62 B 100.00 % 0\u001b[2K\radded QmYq9ipYf3vsj7iLv5C67BXZcpLHxZbvFAJbtj7aKN5qii helloworld.pl\n" ] } ], "source": [ "!ipfs add helloworld.pl" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "Copy the CID of the file which in this case is `QmYq9ipYf3vsj7iLv5C67BXZcpLHxZbvFAJbtj7aKN5qii`" ] }, { "cell_type": "markdown", "metadata": { "id": "1EthK_pazMcY" }, "source": [ "Since the data Uploaded To IPFS isn’t pinned or will be garbage collected\n", "\n", "The Data needs to be Pinned, Pinning is the mechanism that allows you to tell IPFS to always keep a given object somewhere, the default being your local node, though this can be different if you use a third-party remote pinning service.\n", "\n", "Using NFTup\n", "\n", "### [NFT.Storage](https://nft.storage/) (Recommneded Option)\n", "\n", "[Upload files and directories with NFTUp](https://nft.storage/docs/how-to/nftup/) \n", "\n", "To upload your dataset using NFTup just drag and drop your directory it will upload it to IPFS" ] }, { "cell_type": "markdown", "metadata": { "id": "pip7Jgwsy8dZ" }, "source": [ "![image.png]()" ] }, { "cell_type": "markdown", "metadata": { "id": "XX_26vGczhUZ" }, "source": [ "Running on bacalhau\n", "\n", "We will use the official [swipl docker image](https://hub.docker.com/_/swipl/)\n" ] }, { "cell_type": "code", "execution_count": null, "metadata": { "colab": { "base_uri": "https://localhost:8080/" }, "id": "8Rt_B9bjEPlC", "outputId": "5fa4c875-3d83-4a13-88b5-f3a80844f813", "tags": [ "skip-execution" ] }, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ "Your system is linux_amd64\n", "No BACALHAU detected. Installing fresh BACALHAU CLI...\n", "Getting the latest BACALHAU CLI...\n", "Installing v0.3.11 BACALHAU CLI...\n", "Downloading https://github.com/filecoin-project/bacalhau/releases/download/v0.3.11/bacalhau_v0.3.11_linux_amd64.tar.gz ...\n", "Downloading sig file https://github.com/filecoin-project/bacalhau/releases/download/v0.3.11/bacalhau_v0.3.11_linux_amd64.tar.gz.signature.sha256 ...\n", "Verified OK\n", "Extracting tarball ...\n", "NOT verifying Bin\n", "bacalhau installed into /usr/local/bin successfully.\n", "Client Version: v0.3.11\n", "Server Version: v0.3.11\n" ] } ], "source": [ "!curl -sL https://get.bacalhau.org/install.sh | bash" ] }, { "cell_type": "markdown", "metadata": { "id": "P1Hoiqf10hr_" }, "source": [ "Command\n" ] }, { "cell_type": "code", "execution_count": null, "metadata": { "id": "0sToMfZa0kqq", "tags": [ "skip-execution" ] }, "outputs": [], "source": [ "%%bash --out job_id\n", "bacalhau docker run \\\n", "-v QmYq9ipYf3vsj7iLv5C67BXZcpLHxZbvFAJbtj7aKN5qii:/helloworld.pl \\\n", "--wait \\\n", "--id-only \\\n", "swipl \\\n", " -- swipl -q -s helloworld.pl -g hello_world" ] }, { "cell_type": "markdown", "metadata": { "id": "6CbHWnN009Rw" }, "source": [ "then we will mount the script to the container using the -v flag\n", "\n", "-v < CID >:/< name-of-the-script >\n", "\n", "Swipl flag\n", "\n", "-q running in quiet mode\n", "\n", "-s load file as a script in this case we want to run the script helloworld.pl\n", "\n", "-g is the name of the function you want to execute in this case its hello_world\n" ] }, { "cell_type": "code", "execution_count": null, "metadata": { "colab": { "base_uri": "https://localhost:8080/" }, "id": "Gg6riPesa5BN", "outputId": "7ad204f8-ba7d-47b3-b729-dd1ba5666d5d", "tags": [ "skip-execution", "remove_cell" ] }, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ "env: JOB_ID=ddd22db1-61c7-4302-bbe2-f38f8ffa2f44\n" ] } ], "source": [ "%env JOB_ID={job_id}" ] }, { "cell_type": "code", "execution_count": null, "metadata": { "colab": { "base_uri": "https://localhost:8080/" }, "id": "q0pc73fqa5BO", "outputId": "96c40b17-39b0-42db-8e8b-42e7a370311e", "tags": [ "skip-execution" ] }, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ "\u001b[92;100m CREATED \u001b[0m\u001b[92;100m ID \u001b[0m\u001b[92;100m JOB \u001b[0m\u001b[92;100m STATE \u001b[0m\u001b[92;100m VERIFIED \u001b[0m\u001b[92;100m PUBLISHED \u001b[0m\n", "\u001b[97;40m 22-11-12-08:00:51 \u001b[0m\u001b[97;40m ddd22db1-61c7-4302-bbe2-f38f8ffa2f44 \u001b[0m\u001b[97;40m Docker swipl swipl -q -s helloworld.pl -g hello_world \u001b[0m\u001b[97;40m Completed \u001b[0m\u001b[97;40m \u001b[0m\u001b[97;40m /ipfs/QmYnaUZLWmbRTJzpx6kgxoAVT3ZAmhqWY6qWZm33v8PjNm \u001b[0m\n" ] } ], "source": [ "%%bash\n", "bacalhau list --id-filter ${JOB_ID} --wide" ] }, { "cell_type": "markdown", "metadata": { "id": "wElIl4UYa5BO" }, "source": [ "Where it says \"Completed\", that means the job is done, and we can get the results.\n", "\n", "To find out more information about your job, run the following command:\n" ] }, { "cell_type": "code", "execution_count": null, "metadata": { "id": "gRgrNAm7a5BO", "tags": [ "skip-execution" ] }, "outputs": [], "source": [ "%%bash\n", "bacalhau describe ${JOB_ID}" ] }, { "cell_type": "code", "execution_count": null, "metadata": { "colab": { "base_uri": "https://localhost:8080/" }, "id": "duvEDPr-a5BO", "outputId": "b90c0d5f-9cf9-49e0-e7ac-ef55fd262891", "tags": [ "skip-execution" ] }, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ "Fetching results of job 'ddd22db1-61c7-4302-bbe2-f38f8ffa2f44'...\n", "Results for job 'ddd22db1-61c7-4302-bbe2-f38f8ffa2f44' have been written to...\n", "results\n" ] }, { "name": "stderr", "output_type": "stream", "text": [ "2022/11/12 08:01:59 failed to sufficiently increase receive buffer size (was: 208 kiB, wanted: 2048 kiB, got: 416 kiB). See https://github.com/lucas-clemente/quic-go/wiki/UDP-Receive-Buffer-Size for details.\n" ] } ], "source": [ "%%bash\n", "rm -rf results && mkdir -p results\n", "bacalhau get $JOB_ID --output-dir results" ] }, { "cell_type": "markdown", "metadata": { "id": "YZEeFzMEa5BO" }, "source": [ "Viewing the outputs" ] }, { "cell_type": "code", "execution_count": null, "metadata": { "colab": { "base_uri": "https://localhost:8080/" }, "id": "zhk8g_LMa5BO", "outputId": "dc11348a-7dc4-451c-d5b3-5c218c7076a4", "tags": [ "skip-execution" ] }, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ "Hello World\n" ] } ], "source": [ "%%bash\n", "cat results/combined_results/stdout" ] } ], "metadata": { "colab": { "collapsed_sections": [], "provenance": [] }, "kernelspec": { "display_name": "Python 3.10.6 64-bit", "language": "python", "name": "python3" }, "language_info": { "name": "python", "version": "3.10.6" }, "vscode": { "interpreter": { "hash": "916dbcbb3f70747c44a77c7bcd40155683ae19c65e1c03b4aa3499c5328201f1" } } }, "nbformat": 4, "nbformat_minor": 0 }