codeoven


Namecodeoven JSON
Version 0.1.4 PyPI version JSON
download
home_pagehttps://github.com/chocolate-icecream/codeoven
SummaryEffortlessly integrates C code with Python.
upload_time2023-05-19 00:38:19
maintainer
docs_urlNone
authorchocolate-icecream
requires_python>=3.6
license
keywords igor
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            ## Introduction

If you're working on scientific calculations using C programming, you might find it tedious to prepare an interface to call it from Python. However, Codeoven offers a simple solution to this problem. All you have to do is add some comment lines to the original C source code, and Codeoven will do the rest. By decorating your code with `@oven` comment lines, the code will be compiled and executed so that it can communicate with your Python script through *stdio*.

Using Codeoven eliminates the need to prepare a separate interface to link your C code with Python. Instead, the `@oven` comment lines act as a bridge between the two programming languages. This approach has the added advantage of allowing the original source code to be run in any IDE, making debugging easier.

Here is a quick example. 

Assume that we have a source code *main.c* that adds up from 1 to n.

```c
#include <stdio.h>

int main(void)
{
  int i, total = 0;
  int n = 1; // @oven
  
  for(i = 1; i <= n; i++) 
  {
    total += i; 
  }
  
  printf("answer:%d\n", total); // @oven
  return 0;
}
```

The following Python script will compile and run main.c to get the sum of 1 to 10.

```python
from codeoven import Oven

oven = Oven("main.c")
result = oven.run({"n": 10})
print(result["answer"]) # -> print 55
```

Notice that the only modification required to the source code is the `@oven` comments on the lines corresponding to input and output.

In terms of the execution speed, the initial compilation and the communication between C and Python through *stdio* would be the major bottleneck.

## Usage

#### Loading your source code

```
oven = Oven("main.c")
```

#### Running your program

```
parameter_dict = {"a": 1, "b": 2.0, "c": [3.0, 4.0, 5.0]}
result = oven.run(parameter_dict)
```

#### Passing values from Python to C

##### Passing a scalar value

```c
// At declaration
int a = 1; // @oven

//At substitution
double b;
b = 2; // @oven
```

##### Passing an array

```c
double c[] = {0.0};
```

#### Passing value from C to Python

You can output the results of your calculation using `printf`:

```python
printf("key_name:%lf\n", value); // @oven
```

The format string must always be composed of a sequence of a key, a colon, a value, and a newline. As for the value, it can be a number, string tuple list, or dictionary, as long as it can be evaluated by Python's ast.literal_eval.

```c
printf("a_and_b:(%d, %lf)\n", a, b); // @oven
// This line passes 
```



```c
printf("time_series:(%d, %lf)\n", 0, x); // @oven
for(i = 0; i < n; i++)
	x += calculation(i, x);
	printf("time_series:(%d, %lf)\n", i+1, x); // @oven
```

If multiple outputs are made for the same key, the result is a list in the order of outputs.

#### Accessing the results

The return value of `run` is a dictionary. You can access it as usual. 

```
print(result["a"])
```

## Code modifiers

#### @oven

Input

```
int n = 1; // @oven
double array[] = {1.0, 2.0, 3.0}; // @oven
```

Output

```
printf("result:%d\n", n*n); // @oven
```

#### (Plan)@oven.assign  (new plan)-> @oven.as: or @oven:

Assign the value using a Python statement.

```
int array[] = {2, 3, 5}; // @oven
int n = 3; // @oven.assign:array.size
```

```
double map[][] = {{1.0, 2.0}, {2.0, 3.0}, {3.0, 4.0}}; // @oven
int n_x = 2; // @oven.assign:map.shape[0]
int n_y = 3; // @oven.assign:map.shape[1]
```

#### @oven.compile

The input specified by `@oven.compile` is embdedded directrly in the source code.

```
int n = 1; // @oven.compile

double array[] = {1.0, 2.0}; // @oven.compile
int n = 2; // @oven.assign:array.size
```

## Reference

#### class `codeoven.Oven`

##### **`codeoven.Oven(file_name:str)`**

- `file_name`: The file name of a source code to be processed

When an instance of Oven is created, the source code is loaded and parsed. At this stage, no new code is written out yet; the oven instance generates code when `run` or `burn` is executed.

##### **`oven.run(parameters:dict=None) -> dict`**

- `parameters`: Initialization or substitution statements commented with "@oven" in the C source code will be replaced using the value of the dictionary at runtime though *stdin*. The compilation will be done once for the first execution.

##### **`oven.burn(parameters:dict=None) -> dict`**

- `parameters`: Initialization or substitution statements commented with "@oven" in the C source code will be replaced using the value of the dictionary.

Each time the method `burn` is called, the new source code is output, compiled, and executed. No information exchange will be done at runtime, and all the parameters and data will be implemented in the source code.

## Examples

```c
#include <stdio.h>

int main(void)
{
  double data[] = [1, 3, 5]; // @oven
  int n = 3; // @over:data.size
  double result = 0;
  int i;
  for (i = 0; i < n; i++)
  {
    result += data[i];
  }
  printf("sum:%lf\n", result); // @oven
  return 0
}
```

```c
#include <stdio.h>

int main(void)
{
  double data = [[1, 2, 3], [2, 3, 4]]; // @oven.runtime
  int imax = 3; // @oven.assign:data.shape[0]
  int kmax = 2; // @oven.assign:data.shape[1]
  int i, k;
  for (i = 0; i <)
}
```




            

Raw data

            {
    "_id": null,
    "home_page": "https://github.com/chocolate-icecream/codeoven",
    "name": "codeoven",
    "maintainer": "",
    "docs_url": null,
    "requires_python": ">=3.6",
    "maintainer_email": "",
    "keywords": "Igor",
    "author": "chocolate-icecream",
    "author_email": "",
    "download_url": "https://files.pythonhosted.org/packages/f7/ee/ddd857638a2b113d2adc867c56f767fac14edf10f45019f543e43277abcd/codeoven-0.1.4.tar.gz",
    "platform": null,
    "description": "## Introduction\n\nIf you're working on scientific calculations using C programming, you might find it tedious to prepare an interface to call it from Python. However, Codeoven offers a simple solution to this problem. All you have to do is add some comment lines to the original C source code, and Codeoven will do the rest. By decorating your code with `@oven` comment lines, the code will be compiled and executed so that it can communicate with your Python script through *stdio*.\n\nUsing Codeoven eliminates the need to prepare a separate interface to link your C code with Python. Instead, the `@oven` comment lines act as a bridge between the two programming languages. This approach has the added advantage of allowing the original source code to be run in any IDE, making debugging easier.\n\nHere is a quick example. \n\nAssume that we have a source code *main.c* that adds up from 1 to n.\n\n```c\n#include <stdio.h>\n\nint main(void)\n{\n  int i, total = 0;\n  int n = 1; // @oven\n  \n  for(i = 1; i <= n; i++) \n  {\n    total += i; \n  }\n  \n  printf(\"answer:%d\\n\", total); // @oven\n  return 0;\n}\n```\n\nThe following Python script will compile and run main.c to get the sum of 1 to 10.\n\n```python\nfrom codeoven import Oven\n\noven = Oven(\"main.c\")\nresult = oven.run({\"n\": 10})\nprint(result[\"answer\"]) # -> print 55\n```\n\nNotice that the only modification required to the source code is the `@oven` comments on the lines corresponding to input and output.\n\nIn terms of the execution speed, the initial compilation and the communication between C and Python through *stdio* would be the major bottleneck.\n\n## Usage\n\n#### Loading your source code\n\n```\noven = Oven(\"main.c\")\n```\n\n#### Running your program\n\n```\nparameter_dict = {\"a\": 1, \"b\": 2.0, \"c\": [3.0, 4.0, 5.0]}\nresult = oven.run(parameter_dict)\n```\n\n#### Passing values from Python to C\n\n##### Passing a scalar value\n\n```c\n// At declaration\nint a = 1; // @oven\n\n//At substitution\ndouble b;\nb = 2; // @oven\n```\n\n##### Passing an array\n\n```c\ndouble c[] = {0.0};\n```\n\n#### Passing value from C to Python\n\nYou can output the results of your calculation using `printf`:\n\n```python\nprintf(\"key_name:%lf\\n\", value); // @oven\n```\n\nThe format string must always be composed of a sequence of a key, a colon, a value, and a newline. As for the value, it can be a number, string tuple list, or dictionary, as long as it can be evaluated by Python's ast.literal_eval.\n\n```c\nprintf(\"a_and_b:(%d, %lf)\\n\", a, b); // @oven\n// This line passes \n```\n\n\n\n```c\nprintf(\"time_series:(%d, %lf)\\n\", 0, x); // @oven\nfor(i = 0; i < n; i++)\n\tx += calculation(i, x);\n\tprintf(\"time_series:(%d, %lf)\\n\", i+1, x); // @oven\n```\n\nIf multiple outputs are made for the same key, the result is a list in the order of outputs.\n\n#### Accessing the results\n\nThe return value of `run` is a dictionary. You can access it as usual. \n\n```\nprint(result[\"a\"])\n```\n\n## Code modifiers\n\n#### @oven\n\nInput\n\n```\nint n = 1; // @oven\ndouble array[] = {1.0, 2.0, 3.0}; // @oven\n```\n\nOutput\n\n```\nprintf(\"result:%d\\n\", n*n); // @oven\n```\n\n#### (Plan)@oven.assign  (new plan)-> @oven.as: or @oven:\n\nAssign the value using a Python statement.\n\n```\nint array[] = {2, 3, 5}; // @oven\nint n = 3; // @oven.assign:array.size\n```\n\n```\ndouble map[][] = {{1.0, 2.0}, {2.0, 3.0}, {3.0, 4.0}}; // @oven\nint n_x = 2; // @oven.assign:map.shape[0]\nint n_y = 3; // @oven.assign:map.shape[1]\n```\n\n#### @oven.compile\n\nThe input specified by `@oven.compile` is embdedded directrly in the source code.\n\n```\nint n = 1; // @oven.compile\n\ndouble array[] = {1.0, 2.0}; // @oven.compile\nint n = 2; // @oven.assign:array.size\n```\n\n## Reference\n\n#### class `codeoven.Oven`\n\n##### **`codeoven.Oven(file_name:str)`**\n\n- `file_name`: The file name of a source code to be processed\n\nWhen an instance of Oven is created, the source code is loaded and parsed. At this stage, no new code is written out yet; the oven instance generates code when `run` or `burn` is executed.\n\n##### **`oven.run(parameters:dict=None) -> dict`**\n\n- `parameters`: Initialization or substitution statements commented with \"@oven\" in the C source code will be replaced using the value of the dictionary at runtime though *stdin*. The compilation will be done once for the first execution.\n\n##### **`oven.burn(parameters:dict=None) -> dict`**\n\n- `parameters`: Initialization or substitution statements commented with \"@oven\" in the C source code will be replaced using the value of the dictionary.\n\nEach time the method `burn` is called, the new source code is output, compiled, and executed. No information exchange will be done at runtime, and all the parameters and data will be implemented in the source code.\n\n## Examples\n\n```c\n#include <stdio.h>\n\nint main(void)\n{\n  double data[] = [1, 3, 5]; // @oven\n  int n = 3; // @over:data.size\n  double result = 0;\n  int i;\n  for (i = 0; i < n; i++)\n  {\n    result += data[i];\n  }\n  printf(\"sum:%lf\\n\", result); // @oven\n  return 0\n}\n```\n\n```c\n#include <stdio.h>\n\nint main(void)\n{\n  double data = [[1, 2, 3], [2, 3, 4]]; // @oven.runtime\n  int imax = 3; // @oven.assign:data.shape[0]\n  int kmax = 2; // @oven.assign:data.shape[1]\n  int i, k;\n  for (i = 0; i <)\n}\n```\n\n\n\n",
    "bugtrack_url": null,
    "license": "",
    "summary": "Effortlessly integrates C code with Python.",
    "version": "0.1.4",
    "project_urls": {
        "Bug Tracker": "https://github.com/chocolate-icecream/codeoven/issues",
        "Homepage": "https://github.com/chocolate-icecream/codeoven"
    },
    "split_keywords": [
        "igor"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "f7eeddd857638a2b113d2adc867c56f767fac14edf10f45019f543e43277abcd",
                "md5": "567a0b03f88b75aa88eb5cb7aa92b4bd",
                "sha256": "f1609ef0d7eab7697e781002be7c68738d21955b841b8b3f1854c9169fc3332d"
            },
            "downloads": -1,
            "filename": "codeoven-0.1.4.tar.gz",
            "has_sig": false,
            "md5_digest": "567a0b03f88b75aa88eb5cb7aa92b4bd",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": ">=3.6",
            "size": 11197,
            "upload_time": "2023-05-19T00:38:19",
            "upload_time_iso_8601": "2023-05-19T00:38:19.778218Z",
            "url": "https://files.pythonhosted.org/packages/f7/ee/ddd857638a2b113d2adc867c56f767fac14edf10f45019f543e43277abcd/codeoven-0.1.4.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2023-05-19 00:38:19",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "chocolate-icecream",
    "github_project": "codeoven",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": false,
    "lcname": "codeoven"
}
        
Elapsed time: 1.08062s