sarina-cli


Namesarina-cli JSON
Version 0.0.22 PyPI version JSON
download
home_pagehttps://github.com/AminAlam/Sarina
SummaryASCII Art Generator
upload_time2023-03-27 14:40:06
maintainer
docs_urlNone
authorAmin Alam
requires_python>=3.5
licenseMIT
keywords ascii-art word-cloud-generator
VCS
bugtrack_url
requirements tqdm click numpy opencv-python pillow
Travis-CI No Travis.
coveralls test coverage No coveralls.
            
<div align="center">
<img src="https://github.com/AminAlam/Sarina/blob/dev/other_files/sarina/text_on_contour.png" width=400>
<br/>
<h1>Sarina</h1>
<br/>
<img src="https://img.shields.io/badge/Python-14354C?style=for-the-badge&logo=python&logoColor=white" alt="built with Python3" />
<img src="https://img.shields.io/badge/C%2B%2B-00599C?style=for-the-badge&logo=c%2B%2B&logoColor=white" alt="built with C++" />

</div>

----------
Sarina: An ASCII Art generator command line tool to create word clouds from text words based on contours of the given image.

<table border="0">
 <tr>
    <td>The program is dedicated to <a href="https://en.wikipedia.org/wiki/Death_of_Sarina_Esmailzadeh">Sarina Esmailzadeh</a>, a 16-year-old teenager who lost her life during the <a href="https://en.wikipedia.org/wiki/Mahsa_Amini_protests">Mahsa Amini protests</a>, as a result of violence inflicted by the IRGC forces. Her memory serves as a reminder of the importance of justice and human rights.

</td>
    <td><img src="https://github.com/AminAlam/Sarina/blob/dev/sarina/assets/images/Sarina.png" alt="Sarina Esmailzadeh" width=400 /></td>
 </tr>
</table>

----------
## Table of contents			
   * [Introduction](https://github.com/AminAlam/Sarina#overview)
   * [Installation](https://github.com/AminAlam/Sarina#installation)
   * [Usage](https://github.com/AminAlam/Sarina#usage)
   * [How It Works](https://github.com/AminAlam/Sarina#how-it-works)

----------
## Overview
<p align="justify">
 Sarina is an ASCII art generator written in Python3 and C++. It transforms an input image and a text file containing words and their weights into a unique ASCII art representation. The algorithm behind Sarina is randomized, ensuring that every output is distinct, even for identical inputs.
</p>

----------
## Installation

### PyPI
- Check [Python Packaging User Guide](https://packaging.python.org/installing/)     
- Run `pip install sarina-cli` or `pip3 install sarina-cli`

### Source code
- Clone the repository or download the source code.
- Run `pip3 install -r requirements.txt` or `pip install -r requirements.txt`

## Usage

### Default image and words
```console
Amin@Maximus:Sarina $ sarina
Sarina is generating your word cloud...
100%|███████████████████████████████████████████████████████████| 132/132 [01:09<00:00,  1.89it/s]
Done!
Images are saved in ./results
```
<table border="0">
<tr>
<td> Input Image </td>
<td> Generated Output </td>
<td> Generated Output </td>
<td> Generated Output </td>
<td> Generated Output </td>
<td> Generated Output </td>
</tr>
 <tr>
    <td><img src="https://github.com/AminAlam/Sarina/blob/dev/sarina/assets/images/iran_map.png" width=400 /></td>
    <td><img src="https://github.com/AminAlam/Sarina/blob/dev/other_files/iran_map/just_text.png" width=400 /></td>
    <td><img src="https://github.com/AminAlam/Sarina/blob/dev/other_files/iran_map/just_text_reverse.png" width=400 /></td>
    <td><img src="https://github.com/AminAlam/Sarina/blob/dev/other_files/iran_map/text_on_contour.png" width=400 /></td>
    <td><img src="https://github.com/AminAlam/Sarina/blob/dev/other_files/iran_map/text_on_contour_reverse.png" width=400 /></td>
    <td><img src="https://github.com/AminAlam/Sarina/blob/dev/other_files/iran_map/text_on_main_image.png" width=400 /></td>
 </tr>
</table>

### Custom image and options
```console
Amin@Maximus:Sarina $ sarina  -if 'assets/images/Sarina.png' -ct 100 -ft 20 -tc [255,255,255] -pc -cs
Enter the contour indices to keep (+) or to remove (-) (separated by space): +1 -2 -3 -4
Sarina is generating your word cloud...
100%|███████████████████████████████████████████████████████████| 132/132 [01:06<00:00,  1.98it/s]
Done!
Images are saved in ./results
```
<table border="0">
<tr>
<td> Input Image </td>
<td> Generated Output </td>
<td> Generated Output </td>
<td> Generated Output </td>
<td> Generated Output </td>
<td> Generated Output </td>
</tr>
 <tr>
    <td><img src="https://github.com/AminAlam/Sarina/blob/dev/sarina/assets/images/Sarina.png" width=400 /></td>
    <td><img src="https://github.com/AminAlam/Sarina/blob/dev/other_files/sarina/just_text.png" width=400 /></td>
    <td><img src="https://github.com/AminAlam/Sarina/blob/dev/other_files/sarina/just_text_reverse.png" width=400 /></td>
    <td><img src="https://github.com/AminAlam/Sarina/blob/dev/other_files/sarina/text_on_contour.png" width=400 /></td>
    <td><img src="https://github.com/AminAlam/Sarina/blob/dev/other_files/sarina/text_on_contour_reverse.png" width=400 /></td>
    <td><img src="https://github.com/AminAlam/Sarina/blob/dev/other_files/sarina/text_on_main_image.png" width=400 /></td>
 </tr>
</table>




To learn more about the options, you can use the following command:
```console
Amin@Maximus:Sarina $ sarina --help
Usage: sarina [OPTIONS]

  Sarina: An ASCII Art Generator to create word clouds from text files based
  on image contours

Options:

  -if, --img_file PATH            Path to image file
  
  -tf, --txt_file PATH            Path to text file. Each line of the text
                                  file should be in the following format:
                                  WORD|WEIGHT

  -cs, --contour_selection        Contour selection - if selected, user will
                                  be prompted to enter the contours index. For
                                  example, if you want to keep the contours
                                  with index 0, 3, 4, and remove contours with
                                  index 1, 2, you should enter +0 +3 +4 -1 -2
                                  
  -ct, --contour_treshold INTEGER RANGE
                                  Threshold value to detect the contours.
                                  Sarina uses intensity thresholding to detect
                                  the contours. The higher the value, the more
                                  contours will be detected but the less
                                  accurate the result will be  [default: 100;
                                  0<=x<=255]
                                  
  --max_iter INTEGER RANGE        Maximum number of iterations. Higher number
                                  of iterations will result in more consistent
                                  results with the given texts and weights,
                                  but it will take more time to generate the
                                  result  [default: 1000; 100<=x<=10000]
                                  
  --decay_rate FLOAT RANGE        Decay rate for font scale. Higher decay rate
                                  will result in more consistent results with
                                  the given texts and weights, but it will
                                  take more time to generate the result
                                  [default: 0.9; 0.1<=x<=1.0]
                                  
  -ft, --font_thickness INTEGER   Font thickness. Higher values will make the
                                  texts font thicker. Choose this value based
                                  on the size of the image  [default: 10]
                                  
  --margin INTEGER RANGE          Margin between texts in pixels. Higher
                                  values will result in more space between the
                                  texts  [default: 20; 0<=x<=100]
                                  
  -tc, --text_color TEXT          Text color in RGB format. For example,
                                  [255,0,0] is red. Note to use square
                                  brackets and commas. Also, just enter the
                                  numbers, do not use spaces  [default:
                                  [0,0,0]]
                                  
  -pc, --plot_contour             Plot contour on the generated images. If
                                  selected, the generated images will be
                                  plotted with the detected/selected contours
                                  
  -op, --opacity                  If selected, opacity of each text will be
                                  selected based on its weight  [default:
                                  True]
                                  
  -sp, --save_path PATH           Path to save the generated images. If not
                                  selected, the generated images will be saved
                                  in the same results folder in the directory
                                  as the function is called.
```




            

Raw data

            {
    "_id": null,
    "home_page": "https://github.com/AminAlam/Sarina",
    "name": "sarina-cli",
    "maintainer": "",
    "docs_url": null,
    "requires_python": ">=3.5",
    "maintainer_email": "",
    "keywords": "ASCII-Art Word-Cloud-Generator",
    "author": "Amin Alam",
    "author_email": "",
    "download_url": "https://files.pythonhosted.org/packages/9f/09/b98373e72585eb538324891e72d8bc6c6891ab43cbc519a6714b01b6989e/sarina-cli-0.0.22.tar.gz",
    "platform": null,
    "description": "\n<div align=\"center\">\n<img src=\"https://github.com/AminAlam/Sarina/blob/dev/other_files/sarina/text_on_contour.png\" width=400>\n<br/>\n<h1>Sarina</h1>\n<br/>\n<img src=\"https://img.shields.io/badge/Python-14354C?style=for-the-badge&logo=python&logoColor=white\" alt=\"built with Python3\" />\n<img src=\"https://img.shields.io/badge/C%2B%2B-00599C?style=for-the-badge&logo=c%2B%2B&logoColor=white\" alt=\"built with C++\" />\n\n</div>\n\n----------\nSarina: An ASCII Art generator command line tool to create word clouds from text words based on contours of the given image.\n\n<table border=\"0\">\n <tr>\n    <td>The program is dedicated to <a href=\"https://en.wikipedia.org/wiki/Death_of_Sarina_Esmailzadeh\">Sarina Esmailzadeh</a>, a 16-year-old teenager who lost her life during the <a href=\"https://en.wikipedia.org/wiki/Mahsa_Amini_protests\">Mahsa Amini protests</a>, as a result of violence inflicted by the IRGC forces. Her memory serves as a reminder of the importance of justice and human rights.\n\n</td>\n    <td><img src=\"https://github.com/AminAlam/Sarina/blob/dev/sarina/assets/images/Sarina.png\" alt=\"Sarina Esmailzadeh\" width=400 /></td>\n </tr>\n</table>\n\n----------\n## Table of contents\t\t\t\n   * [Introduction](https://github.com/AminAlam/Sarina#overview)\n   * [Installation](https://github.com/AminAlam/Sarina#installation)\n   * [Usage](https://github.com/AminAlam/Sarina#usage)\n   * [How It Works](https://github.com/AminAlam/Sarina#how-it-works)\n\n----------\n## Overview\n<p align=\"justify\">\n Sarina is an ASCII art generator written in Python3 and C++. It transforms an input image and a text file containing words and their weights into a unique ASCII art representation. The algorithm behind Sarina is randomized, ensuring that every output is distinct, even for identical inputs.\n</p>\n\n----------\n## Installation\n\n### PyPI\n- Check [Python Packaging User Guide](https://packaging.python.org/installing/)     \n- Run `pip install sarina-cli` or `pip3 install sarina-cli`\n\n### Source code\n- Clone the repository or download the source code.\n- Run `pip3 install -r requirements.txt` or `pip install -r requirements.txt`\n\n## Usage\n\n### Default image and words\n```console\nAmin@Maximus:Sarina $ sarina\nSarina is generating your word cloud...\n100%|\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588| 132/132 [01:09<00:00,  1.89it/s]\nDone!\nImages are saved in ./results\n```\n<table border=\"0\">\n<tr>\n<td> Input Image </td>\n<td> Generated Output </td>\n<td> Generated Output </td>\n<td> Generated Output </td>\n<td> Generated Output </td>\n<td> Generated Output </td>\n</tr>\n <tr>\n    <td><img src=\"https://github.com/AminAlam/Sarina/blob/dev/sarina/assets/images/iran_map.png\" width=400 /></td>\n    <td><img src=\"https://github.com/AminAlam/Sarina/blob/dev/other_files/iran_map/just_text.png\" width=400 /></td>\n    <td><img src=\"https://github.com/AminAlam/Sarina/blob/dev/other_files/iran_map/just_text_reverse.png\" width=400 /></td>\n    <td><img src=\"https://github.com/AminAlam/Sarina/blob/dev/other_files/iran_map/text_on_contour.png\" width=400 /></td>\n    <td><img src=\"https://github.com/AminAlam/Sarina/blob/dev/other_files/iran_map/text_on_contour_reverse.png\" width=400 /></td>\n    <td><img src=\"https://github.com/AminAlam/Sarina/blob/dev/other_files/iran_map/text_on_main_image.png\" width=400 /></td>\n </tr>\n</table>\n\n### Custom image and options\n```console\nAmin@Maximus:Sarina $ sarina  -if 'assets/images/Sarina.png' -ct 100 -ft 20 -tc [255,255,255] -pc -cs\nEnter the contour indices to keep (+) or to remove (-) (separated by space): +1 -2 -3 -4\nSarina is generating your word cloud...\n100%|\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588| 132/132 [01:06<00:00,  1.98it/s]\nDone!\nImages are saved in ./results\n```\n<table border=\"0\">\n<tr>\n<td> Input Image </td>\n<td> Generated Output </td>\n<td> Generated Output </td>\n<td> Generated Output </td>\n<td> Generated Output </td>\n<td> Generated Output </td>\n</tr>\n <tr>\n    <td><img src=\"https://github.com/AminAlam/Sarina/blob/dev/sarina/assets/images/Sarina.png\" width=400 /></td>\n    <td><img src=\"https://github.com/AminAlam/Sarina/blob/dev/other_files/sarina/just_text.png\" width=400 /></td>\n    <td><img src=\"https://github.com/AminAlam/Sarina/blob/dev/other_files/sarina/just_text_reverse.png\" width=400 /></td>\n    <td><img src=\"https://github.com/AminAlam/Sarina/blob/dev/other_files/sarina/text_on_contour.png\" width=400 /></td>\n    <td><img src=\"https://github.com/AminAlam/Sarina/blob/dev/other_files/sarina/text_on_contour_reverse.png\" width=400 /></td>\n    <td><img src=\"https://github.com/AminAlam/Sarina/blob/dev/other_files/sarina/text_on_main_image.png\" width=400 /></td>\n </tr>\n</table>\n\n\n\n\nTo learn more about the options, you can use the following command:\n```console\nAmin@Maximus:Sarina $ sarina --help\nUsage: sarina [OPTIONS]\n\n  Sarina: An ASCII Art Generator to create word clouds from text files based\n  on image contours\n\nOptions:\n\n  -if, --img_file PATH            Path to image file\n  \n  -tf, --txt_file PATH            Path to text file. Each line of the text\n                                  file should be in the following format:\n                                  WORD|WEIGHT\n\n  -cs, --contour_selection        Contour selection - if selected, user will\n                                  be prompted to enter the contours index. For\n                                  example, if you want to keep the contours\n                                  with index 0, 3, 4, and remove contours with\n                                  index 1, 2, you should enter +0 +3 +4 -1 -2\n                                  \n  -ct, --contour_treshold INTEGER RANGE\n                                  Threshold value to detect the contours.\n                                  Sarina uses intensity thresholding to detect\n                                  the contours. The higher the value, the more\n                                  contours will be detected but the less\n                                  accurate the result will be  [default: 100;\n                                  0<=x<=255]\n                                  \n  --max_iter INTEGER RANGE        Maximum number of iterations. Higher number\n                                  of iterations will result in more consistent\n                                  results with the given texts and weights,\n                                  but it will take more time to generate the\n                                  result  [default: 1000; 100<=x<=10000]\n                                  \n  --decay_rate FLOAT RANGE        Decay rate for font scale. Higher decay rate\n                                  will result in more consistent results with\n                                  the given texts and weights, but it will\n                                  take more time to generate the result\n                                  [default: 0.9; 0.1<=x<=1.0]\n                                  \n  -ft, --font_thickness INTEGER   Font thickness. Higher values will make the\n                                  texts font thicker. Choose this value based\n                                  on the size of the image  [default: 10]\n                                  \n  --margin INTEGER RANGE          Margin between texts in pixels. Higher\n                                  values will result in more space between the\n                                  texts  [default: 20; 0<=x<=100]\n                                  \n  -tc, --text_color TEXT          Text color in RGB format. For example,\n                                  [255,0,0] is red. Note to use square\n                                  brackets and commas. Also, just enter the\n                                  numbers, do not use spaces  [default:\n                                  [0,0,0]]\n                                  \n  -pc, --plot_contour             Plot contour on the generated images. If\n                                  selected, the generated images will be\n                                  plotted with the detected/selected contours\n                                  \n  -op, --opacity                  If selected, opacity of each text will be\n                                  selected based on its weight  [default:\n                                  True]\n                                  \n  -sp, --save_path PATH           Path to save the generated images. If not\n                                  selected, the generated images will be saved\n                                  in the same results folder in the directory\n                                  as the function is called.\n```\n\n\n\n",
    "bugtrack_url": null,
    "license": "MIT",
    "summary": "ASCII Art Generator",
    "version": "0.0.22",
    "split_keywords": [
        "ascii-art",
        "word-cloud-generator"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "9f09b98373e72585eb538324891e72d8bc6c6891ab43cbc519a6714b01b6989e",
                "md5": "873afac3388b40f33faa07fe22ec2534",
                "sha256": "d9a3bd93b0f3d7282622d9e4ab9c69b30e6b043b14b669f344fb6f172fb0d0d3"
            },
            "downloads": -1,
            "filename": "sarina-cli-0.0.22.tar.gz",
            "has_sig": false,
            "md5_digest": "873afac3388b40f33faa07fe22ec2534",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": ">=3.5",
            "size": 2239172,
            "upload_time": "2023-03-27T14:40:06",
            "upload_time_iso_8601": "2023-03-27T14:40:06.645625Z",
            "url": "https://files.pythonhosted.org/packages/9f/09/b98373e72585eb538324891e72d8bc6c6891ab43cbc519a6714b01b6989e/sarina-cli-0.0.22.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2023-03-27 14:40:06",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "github_user": "AminAlam",
    "github_project": "Sarina",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": false,
    "requirements": [
        {
            "name": "tqdm",
            "specs": [
                [
                    ">=",
                    "4.64.1"
                ]
            ]
        },
        {
            "name": "click",
            "specs": [
                [
                    ">=",
                    "8.1.3"
                ]
            ]
        },
        {
            "name": "numpy",
            "specs": [
                [
                    ">=",
                    "1.24.1"
                ]
            ]
        },
        {
            "name": "opencv-python",
            "specs": [
                [
                    ">=",
                    "4.7.0.68"
                ]
            ]
        },
        {
            "name": "pillow",
            "specs": [
                [
                    ">=",
                    "9.4.0"
                ]
            ]
        }
    ],
    "lcname": "sarina-cli"
}
        
Elapsed time: 0.11958s