# [emachinery](https://pypi.org/project/emachinery/)
*<u>A package for analysis of electric machinery.</u>*
# Instructions to use emy-c
## [A]. Install
To run the source code, git clone the repo and create a virtual environment via conda:
```shell
conda create --name emy python=3.10 streamlit numpy pandas control matplotlib numba openpyxl psutil pyyaml
```
The package further requires the following free softwares to compile c source codes:
- gcc (comes with [Minimalist GNU for Windows](https://sourceforge.net/projects/mingw/)---See this [awesome page](https://www3.ntu.edu.sg/home/ehchua/programming/howto/Cygwin_HowTo.html) for info)
- gmake.exe (I use the one from [TI's CCS](https://www.ti.com/tool/download/CCSTUDIO), it is located at somewhere like: `D:\ti\ccs930\ccs\utils\bin\gmake.exe`. Anyway, I decided to just copy-paste gmake.exe to `/emachinery/acmsimc/c/gmake.exe`. So no need to install CCS anymore.)
- It also works with CMake with some minor modification.
Alternatively, the package can be installed via pip.
```shell
pip install emachinery
emy
```
Command `emy` is an entry point for starting the main program of this package, which is equivalent to `python emachinery/main.py`
## [B]. Functions (outdated)
### 1. Machine Quantities Calculations & Conversion
### 2. PI Regulator Tuner based on Texas Instruments' InstaSPIN
### 3. Run C-based Numerical Integration Simulation
### 4. Sweep Frequency Analysis
### 5. Run Python- and Numba-based Realtime Numerical Integration Simulation
### 6. FEA based Machine Design and Multi-Objective Optimization (develop)
### 7. PC User GUI for Serial Communication to DSP (develop)
## [C]. Simulation Tips
1. Field oriented control is an asymptotic input-output linearizing (IOL) control. This means the IOL is achieved only when flux modulus is regulated to its reference. So before motor starts, we must wait for the motor to build up its magnetic air gap field or else the starting transient would be disturbed. Refer to the figure below.![1](https://github.com/horychen/emachinery/blob/main/gallery/readme-pic-flux-to-build.png?raw=true)
2. The inductance of the motor matters. For a small "DC" servo PM motor, the inductance is relatively designed to be low because the DC source is usually only 24 V or 48 V. However, an induction motor usually has higher inductance, which limits the bandwidth of the current loop, I think. For example, this is what happens to d-axis current regulation when I set desired velocity loop bandwidth from 50 Hz up to 100 Hz. Refer to the figure below.![2](https://github.com/horychen/emachinery/blob/main/gallery/readme-pic-comparison-d-axis-current-regulation-per-inductance.png?raw=true)
## [D]. Known Issues (outdated)
### GNU Make failed to create process
After adding installing CCS and MinGW, you might need to restart the PC.
```
gcc -o main pmsm_comm.c im_controller.c ... -I. -L.
process_begin: CreateProcess(NULL, gcc -o main pmsm_comm.c im_controller.c... -I. -L., ...) failed.
make (e=2): The system cannot find the file specified.
makefile:11: recipe for target 'main' failed
gmake: *** [main] Error 2
```
See this [question](https://stackoverflow.com/questions/3848357/createprocess-no-such-file-or-directory)
## [E] Other Information
_This package is published to PYPI following https://www.youtube.com/watch?v=Qs91v2Tofys_
----
## Changelog
*2.0.0*
- Streamlit now serves as the GUI.
- Support both acmsimcv5 (c based simulation) and ACMSimPy (python/numba based simulation).
*1.3.2*
- ACMSimPy: memorize user's last input
- ACMSimPy: allow user to do basic operations with the available variables and show in scope.
*1.3.1*
- Attempt to distribute <gmake.exe> with the package.
*1.3.0*
- Add button for revoking console (for Python based real-time simulation).
- New gui-v3 using Wanderson's <PyOneDark> has issues with matplotlib stylesheet (which cannot be resolved and new gui is postponed).
- Sensorless operation with ACMSimPy is tested.
*1.2.6*
- Use pycairo for faster plotting (as backend for matplotlib).
*1.2.5*
- Python based Real-time simulation now supports more waveforms.
*1.2.4*
- Python packaging issue. Update Manifest.in. See [this post](https://packaging.python.org/guides/using-manifest-in/).
*1.2.3*
- Fix bugs when calling acmsimpy from app_functions.py.
*1.2.2*
- Fix bugs when setting the path to acmsimc.
*1.2.0*
- Mordern GUI in dark theme by Wanderson.
- Top level global variable CTRL, which is a struct of pointers to other structs.
*1.1.5*
- Recover last user selected MachineName and MachineType.
*1.1.4*
- Anaconda3 (Python 3.8) comes with qtconsole now, but it will cause problems.
> My code was developed with Anaconda3 (Python 3.7). So one silly fix is to revert back to Python 3.7 for now:
> ```conda install python=3.7 anaconda=custom```
> But before you try to revert, try ```pip install --upgrade jupyterlab``` first.
*1.1.3*
- No use of LoadUi when published.
*1.1.2*
- Support parametric analysis.
*1.1.1*
- User is now able to select from different plot settings.
- Support sinusoidal flux modulus command for induction motor.
- Remember user's last selected plot setting considering machine types, i.e., IM or PMSM.
- Marino05 is tuned.
*1.1.0*
- Induction motor simulation.
- Marino05 is added.
- Harnefors06 is tuned for a different motor.
- Fix the bug "cannot file .dat file" when "Plot Here" is clicked upon start.
*1.0.9*
- (Video@Bilibili) Demonstrate the effectiveness of the current loop decoupling (PMSM).
- Allow velocity-open-loop and current-closed-loop for sweep frequency analysis.
- Automatically add path2acmsimc if the user-specified path does not exist.
- Remember last user input for C-based simulation.
*1.0.8*
- I was stupid. Version 1.0.7 did not do its job.
*1.0.7*
- Add the resource "makefile" to the package.
*1.0.6*
- Remember last user input for path2acmsimcv5 and add config.json to gui/
- Publish acmsimcv5 along with the package.
*1.0.5*
- Add sweep-frequency and bode-plot feature.
- gmake compile .c program, execute .exe, collect .dat, and ggplot.
Raw data
{
"_id": null,
"home_page": "https://github.com/horychen/emachinery",
"name": "emachinery",
"maintainer": null,
"docs_url": null,
"requires_python": null,
"maintainer_email": null,
"keywords": "electric machinery, motors, motor control, numerical simulation",
"author": "Jiahao Chen",
"author_email": "horychen@qq.com",
"download_url": "https://files.pythonhosted.org/packages/f8/71/3cfe6e7267157cc093e282b4feacf06f7a7b528b1f9c0f930eb34f764760/emachinery-2.0.1.tar.gz",
"platform": null,
"description": "# [emachinery](https://pypi.org/project/emachinery/)\r\n\r\n*<u>A package for analysis of electric machinery.</u>*\r\n\r\n# Instructions to use emy-c\r\n\r\n## [A]. Install\r\n\r\nTo run the source code, git clone the repo and create a virtual environment via conda:\r\n```shell\r\nconda create --name emy python=3.10 streamlit numpy pandas control matplotlib numba openpyxl psutil pyyaml\r\n```\r\nThe package further requires the following free softwares to compile c source codes:\r\n- gcc (comes with [Minimalist GNU for Windows](https://sourceforge.net/projects/mingw/)---See this [awesome page](https://www3.ntu.edu.sg/home/ehchua/programming/howto/Cygwin_HowTo.html) for info)\r\n- gmake.exe (I use the one from [TI's CCS](https://www.ti.com/tool/download/CCSTUDIO), it is located at somewhere like: `D:\\ti\\ccs930\\ccs\\utils\\bin\\gmake.exe`. Anyway, I decided to just copy-paste gmake.exe to `/emachinery/acmsimc/c/gmake.exe`. So no need to install CCS anymore.)\r\n - It also works with CMake with some minor modification.\r\n\r\nAlternatively, the package can be installed via pip.\r\n```shell\r\npip install emachinery\r\nemy\r\n```\r\nCommand `emy` is an entry point for starting the main program of this package, which is equivalent to `python emachinery/main.py`\r\n\r\n## [B]. Functions (outdated)\r\n\r\n### 1. Machine Quantities Calculations & Conversion\r\n\r\n### 2. PI Regulator Tuner based on Texas Instruments' InstaSPIN\r\n\r\n### 3. Run C-based Numerical Integration Simulation\r\n\r\n### 4. Sweep Frequency Analysis\r\n\r\n### 5. Run Python- and Numba-based Realtime Numerical Integration Simulation\r\n\r\n### 6. FEA based Machine Design and Multi-Objective Optimization (develop)\r\n\r\n### 7. PC User GUI for Serial Communication to DSP (develop)\r\n\r\n\r\n## [C]. Simulation Tips\r\n\r\n1. Field oriented control is an asymptotic input-output linearizing (IOL) control. This means the IOL is achieved only when flux modulus is regulated to its reference. So before motor starts, we must wait for the motor to build up its magnetic air gap field or else the starting transient would be disturbed. Refer to the figure below.![1](https://github.com/horychen/emachinery/blob/main/gallery/readme-pic-flux-to-build.png?raw=true)\r\n2. The inductance of the motor matters. For a small \"DC\" servo PM motor, the inductance is relatively designed to be low because the DC source is usually only 24 V or 48 V. However, an induction motor usually has higher inductance, which limits the bandwidth of the current loop, I think. For example, this is what happens to d-axis current regulation when I set desired velocity loop bandwidth from 50 Hz up to 100 Hz. Refer to the figure below.![2](https://github.com/horychen/emachinery/blob/main/gallery/readme-pic-comparison-d-axis-current-regulation-per-inductance.png?raw=true)\r\n\r\n\r\n\r\n## [D]. Known Issues (outdated)\r\n\r\n### GNU Make failed to create process\r\nAfter adding installing CCS and MinGW, you might need to restart the PC.\r\n\r\n```\r\ngcc -o main pmsm_comm.c im_controller.c ... -I. -L.\r\nprocess_begin: CreateProcess(NULL, gcc -o main pmsm_comm.c im_controller.c... -I. -L., ...) failed.\r\nmake (e=2): The system cannot find the file specified.\r\nmakefile:11: recipe for target 'main' failed\r\ngmake: *** [main] Error 2\r\n```\r\n\r\nSee this [question](https://stackoverflow.com/questions/3848357/createprocess-no-such-file-or-directory)\r\n\r\n## [E] Other Information\r\n\r\n_This package is published to PYPI following https://www.youtube.com/watch?v=Qs91v2Tofys_\r\n\r\n----\r\n\r\n\r\n\r\n\r\n## Changelog\r\n\r\n*2.0.0*\r\n- Streamlit now serves as the GUI.\r\n- Support both acmsimcv5 (c based simulation) and ACMSimPy (python/numba based simulation).\r\n\r\n\r\n*1.3.2*\r\n- ACMSimPy: memorize user's last input\r\n- ACMSimPy: allow user to do basic operations with the available variables and show in scope.\r\n\r\n*1.3.1*\r\n- Attempt to distribute <gmake.exe> with the package.\r\n\r\n*1.3.0*\r\n- Add button for revoking console (for Python based real-time simulation).\r\n- New gui-v3 using Wanderson's <PyOneDark> has issues with matplotlib stylesheet (which cannot be resolved and new gui is postponed).\r\n- Sensorless operation with ACMSimPy is tested.\r\n\r\n*1.2.6*\r\n- Use pycairo for faster plotting (as backend for matplotlib).\r\n\r\n*1.2.5*\r\n- Python based Real-time simulation now supports more waveforms.\r\n\r\n*1.2.4*\r\n- Python packaging issue. Update Manifest.in. See [this post](https://packaging.python.org/guides/using-manifest-in/).\r\n\r\n*1.2.3*\r\n- Fix bugs when calling acmsimpy from app_functions.py.\r\n\r\n*1.2.2*\r\n- Fix bugs when setting the path to acmsimc.\r\n\r\n*1.2.0*\r\n- Mordern GUI in dark theme by Wanderson.\r\n- Top level global variable CTRL, which is a struct of pointers to other structs.\r\n\r\n*1.1.5*\r\n- Recover last user selected MachineName and MachineType.\r\n\r\n*1.1.4*\r\n- Anaconda3 (Python 3.8) comes with qtconsole now, but it will cause problems. \r\n> My code was developed with Anaconda3 (Python 3.7). So one silly fix is to revert back to Python 3.7 for now: \r\n> ```conda install python=3.7 anaconda=custom```\r\n> But before you try to revert, try ```pip install --upgrade jupyterlab``` first.\r\n\r\n*1.1.3*\r\n- No use of LoadUi when published.\r\n\r\n*1.1.2*\r\n- Support parametric analysis.\r\n\r\n*1.1.1*\r\n- User is now able to select from different plot settings.\r\n- Support sinusoidal flux modulus command for induction motor.\r\n- Remember user's last selected plot setting considering machine types, i.e., IM or PMSM.\r\n- Marino05 is tuned.\r\n\r\n*1.1.0*\r\n- Induction motor simulation.\r\n- Marino05 is added.\r\n- Harnefors06 is tuned for a different motor.\r\n- Fix the bug \"cannot file .dat file\" when \"Plot Here\" is clicked upon start.\r\n\r\n*1.0.9*\r\n- (Video@Bilibili) Demonstrate the effectiveness of the current loop decoupling (PMSM).\r\n- Allow velocity-open-loop and current-closed-loop for sweep frequency analysis.\r\n- Automatically add path2acmsimc if the user-specified path does not exist.\r\n- Remember last user input for C-based simulation.\r\n\r\n*1.0.8*\r\n- I was stupid. Version 1.0.7 did not do its job.\r\n\r\n*1.0.7*\r\n- Add the resource \"makefile\" to the package.\r\n\r\n*1.0.6*\r\n- Remember last user input for path2acmsimcv5 and add config.json to gui/\r\n- Publish acmsimcv5 along with the package.\r\n\r\n*1.0.5*\r\n- Add sweep-frequency and bode-plot feature.\r\n- gmake compile .c program, execute .exe, collect .dat, and ggplot.\r\n",
"bugtrack_url": null,
"license": "GNU General Public License v3.0",
"summary": "A package for electric machinery analysis.",
"version": "2.0.1",
"project_urls": {
"Homepage": "https://github.com/horychen/emachinery"
},
"split_keywords": [
"electric machinery",
" motors",
" motor control",
" numerical simulation"
],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "443befc49f6d2c0d6cbf8e80a65a8870f69fb5bfb15f79cfedd074bd84fef9cb",
"md5": "eeca9058acf6e3f712494cf607397e0f",
"sha256": "e92d6862968e4da36280ad9d8c6efd8f4a52b89ac0360bb0f17fff4271bac07b"
},
"downloads": -1,
"filename": "emachinery-2.0.1-py3-none-any.whl",
"has_sig": false,
"md5_digest": "eeca9058acf6e3f712494cf607397e0f",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": null,
"size": 2113134,
"upload_time": "2024-08-10T10:04:53",
"upload_time_iso_8601": "2024-08-10T10:04:53.265993Z",
"url": "https://files.pythonhosted.org/packages/44/3b/efc49f6d2c0d6cbf8e80a65a8870f69fb5bfb15f79cfedd074bd84fef9cb/emachinery-2.0.1-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "f8713cfe6e7267157cc093e282b4feacf06f7a7b528b1f9c0f930eb34f764760",
"md5": "79e9c16893eb0a0bedb04c9492a29fb8",
"sha256": "ff5589242b967df84911f0c57450ccc7323e6d857a5c226951036fb14e37d5a3"
},
"downloads": -1,
"filename": "emachinery-2.0.1.tar.gz",
"has_sig": false,
"md5_digest": "79e9c16893eb0a0bedb04c9492a29fb8",
"packagetype": "sdist",
"python_version": "source",
"requires_python": null,
"size": 2090824,
"upload_time": "2024-08-10T10:05:22",
"upload_time_iso_8601": "2024-08-10T10:05:22.837697Z",
"url": "https://files.pythonhosted.org/packages/f8/71/3cfe6e7267157cc093e282b4feacf06f7a7b528b1f9c0f930eb34f764760/emachinery-2.0.1.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2024-08-10 10:05:22",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "horychen",
"github_project": "emachinery",
"travis_ci": false,
"coveralls": false,
"github_actions": false,
"lcname": "emachinery"
}