summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorCoprDistGit <infra@openeuler.org>2023-06-20 07:48:53 +0000
committerCoprDistGit <infra@openeuler.org>2023-06-20 07:48:53 +0000
commit22988bb61d26e5a69b902fd5eb0cc7d7894cd735 (patch)
tree1ba08d4053bc643271132ff19635fd3cab0403f2
parent994e03422495e3b32f10e40c2bd53d536579c776 (diff)
automatic import of python-inkstoneopeneuler20.03
-rw-r--r--.gitignore1
-rw-r--r--python-inkstone.spec305
-rw-r--r--sources1
3 files changed, 307 insertions, 0 deletions
diff --git a/.gitignore b/.gitignore
index e69de29..04ad911 100644
--- a/.gitignore
+++ b/.gitignore
@@ -0,0 +1 @@
+/inkstone-0.2.11.tar.gz
diff --git a/python-inkstone.spec b/python-inkstone.spec
new file mode 100644
index 0000000..444da71
--- /dev/null
+++ b/python-inkstone.spec
@@ -0,0 +1,305 @@
+%global _empty_manifest_terminate_build 0
+Name: python-inkstone
+Version: 0.2.11
+Release: 1
+Summary: 3D efficient solver for multi-stacked in-plane periodic structures using rcwa.
+License: GNU Affero General Public License v3 or later (AGPLv3+)
+URL: https://github.com/alexysong/inkstone
+Source0: https://mirrors.aliyun.com/pypi/web/packages/4c/c3/4d3484e74f99d39c250ff1433f318053478de206a4d9e72f5351294e324b/inkstone-0.2.11.tar.gz
+BuildArch: noarch
+
+Requires: python3-numpy
+Requires: python3-scipy
+
+%description
+<img src="https://github.com/alexysong/inkstone/blob/main/figs/logo.png" align="middle" alt="logo" width="250">
+
+**Inkstone** simulates the electromagnetic properties of 3D and 2D multi-layered structures with in-plane periodicity, such as gratings, photonic-crystal slabs, metasurfaces, vertical-cavity or photonic-crystal surface-emitting lasers (VCSEL, PCSEL), (patterned) solar cells, nano-antennas, and more.
+
+Internally, Inkstone implements rigorous coupled-wave analysis (RCWA), a. k. a. Fourier Modal Method (FMM).
+
+### Inkstone can calculate:
+* the reflection, transmission, and absorption of the structure
+* the total and by-order power fluxes of the propagating and the evanescent waves in each layer
+* electric and magnetic field amplitudes at any locations in the structure,
+* band-structures based on the determinant of the scattering matrix of the structure.
+
+### Features of Inkstone:
+* It supports efficient and flexible parameter-scanning. You can change part of your structure such as the shapes and sizes of some patterns, or some material parameters. Inkstone only recalculates the modified parts and produces the final results efficiently.
+* It allows both tensorial permittivities and tensorial permeabilities, such as in anisotropic, magneto-optical, or gyromagnetic materials.
+* It can calculate the determinant of the scattering matrix on the complex frequency plane.
+* Pre-defined shapes of patterns can be used, including rectangular, parallelogram, disk, ellipse, 1D, and polygons. Closed-form Fourier transforms and corrections for Gibbs phenomena are implemented.
+* It is fully 3D.
+* It is written in pure python, with heavy-lifting done in numpy and scipy.
+
+
+## Quick Start
+### Installation:
+
+ $ pip install inkstone
+Or,
+
+ $ git clone git://github.com/alexysong/inkstone
+ $ pip install .
+
+### Usage
+
+The [examples](examples/) folder contains various self-explaining examples to get you started.
+
+## Dependencies
+
+* python 3.6+
+* numpy
+* scipy
+
+## Units, conventions, and definitions
+
+### Unit system
+We adopt a natural unit system, where vacuum permittivity, permeability, and light speed are $\varepsilon_0=\mu_0=c_0=1$.
+
+### Sign convention
+Sign conventions in electromagnetic waves:
+
+$$e^{i(kx-\omega t)}$$
+
+where $k$ is the wavevector, $x$ is spatial location, $\omega$ is frequency, $t$ is time.
+
+By this convention, a permittivity of $\varepsilon_r + i\varepsilon_i$ with $\varepsilon_i>0$ means material loss, and $\varepsilon_i<0$ means material gain.
+
+### Coordinates and incident angles
+
+<img src="https://github.com/alexysong/inkstone/blob/main/figs/PhC_slab_vector_incident.svg" alt="drawing" width="300">
+
+(Inkstone, **In**cident $\bm{k}$ on **st**acked peri**o**dic **n**ano **e**lectromagnetic structures.)
+
+## Citing
+If you find Inkstone useful for your research, we would apprecite you citing our [paper](https://doi.org/10.1103/PhysRevLett.120.193903). For your convenience, you can use the following BibTex entry:
+
+ @article{song2018broadband,
+ title={Broadband Control of Topological Nodes in Electromagnetic Fields},
+ author={Song, Alex Y and Catrysse, Peter B and Fan, Shanhui},
+ journal={Physical review letters},
+ volume={120},
+ number={19},
+ pages={193903},
+ year={2018},
+ publisher={American Physical Society}
+ }
+
+
+
+
+
+
+%package -n python3-inkstone
+Summary: 3D efficient solver for multi-stacked in-plane periodic structures using rcwa.
+Provides: python-inkstone
+BuildRequires: python3-devel
+BuildRequires: python3-setuptools
+BuildRequires: python3-pip
+%description -n python3-inkstone
+<img src="https://github.com/alexysong/inkstone/blob/main/figs/logo.png" align="middle" alt="logo" width="250">
+
+**Inkstone** simulates the electromagnetic properties of 3D and 2D multi-layered structures with in-plane periodicity, such as gratings, photonic-crystal slabs, metasurfaces, vertical-cavity or photonic-crystal surface-emitting lasers (VCSEL, PCSEL), (patterned) solar cells, nano-antennas, and more.
+
+Internally, Inkstone implements rigorous coupled-wave analysis (RCWA), a. k. a. Fourier Modal Method (FMM).
+
+### Inkstone can calculate:
+* the reflection, transmission, and absorption of the structure
+* the total and by-order power fluxes of the propagating and the evanescent waves in each layer
+* electric and magnetic field amplitudes at any locations in the structure,
+* band-structures based on the determinant of the scattering matrix of the structure.
+
+### Features of Inkstone:
+* It supports efficient and flexible parameter-scanning. You can change part of your structure such as the shapes and sizes of some patterns, or some material parameters. Inkstone only recalculates the modified parts and produces the final results efficiently.
+* It allows both tensorial permittivities and tensorial permeabilities, such as in anisotropic, magneto-optical, or gyromagnetic materials.
+* It can calculate the determinant of the scattering matrix on the complex frequency plane.
+* Pre-defined shapes of patterns can be used, including rectangular, parallelogram, disk, ellipse, 1D, and polygons. Closed-form Fourier transforms and corrections for Gibbs phenomena are implemented.
+* It is fully 3D.
+* It is written in pure python, with heavy-lifting done in numpy and scipy.
+
+
+## Quick Start
+### Installation:
+
+ $ pip install inkstone
+Or,
+
+ $ git clone git://github.com/alexysong/inkstone
+ $ pip install .
+
+### Usage
+
+The [examples](examples/) folder contains various self-explaining examples to get you started.
+
+## Dependencies
+
+* python 3.6+
+* numpy
+* scipy
+
+## Units, conventions, and definitions
+
+### Unit system
+We adopt a natural unit system, where vacuum permittivity, permeability, and light speed are $\varepsilon_0=\mu_0=c_0=1$.
+
+### Sign convention
+Sign conventions in electromagnetic waves:
+
+$$e^{i(kx-\omega t)}$$
+
+where $k$ is the wavevector, $x$ is spatial location, $\omega$ is frequency, $t$ is time.
+
+By this convention, a permittivity of $\varepsilon_r + i\varepsilon_i$ with $\varepsilon_i>0$ means material loss, and $\varepsilon_i<0$ means material gain.
+
+### Coordinates and incident angles
+
+<img src="https://github.com/alexysong/inkstone/blob/main/figs/PhC_slab_vector_incident.svg" alt="drawing" width="300">
+
+(Inkstone, **In**cident $\bm{k}$ on **st**acked peri**o**dic **n**ano **e**lectromagnetic structures.)
+
+## Citing
+If you find Inkstone useful for your research, we would apprecite you citing our [paper](https://doi.org/10.1103/PhysRevLett.120.193903). For your convenience, you can use the following BibTex entry:
+
+ @article{song2018broadband,
+ title={Broadband Control of Topological Nodes in Electromagnetic Fields},
+ author={Song, Alex Y and Catrysse, Peter B and Fan, Shanhui},
+ journal={Physical review letters},
+ volume={120},
+ number={19},
+ pages={193903},
+ year={2018},
+ publisher={American Physical Society}
+ }
+
+
+
+
+
+
+%package help
+Summary: Development documents and examples for inkstone
+Provides: python3-inkstone-doc
+%description help
+<img src="https://github.com/alexysong/inkstone/blob/main/figs/logo.png" align="middle" alt="logo" width="250">
+
+**Inkstone** simulates the electromagnetic properties of 3D and 2D multi-layered structures with in-plane periodicity, such as gratings, photonic-crystal slabs, metasurfaces, vertical-cavity or photonic-crystal surface-emitting lasers (VCSEL, PCSEL), (patterned) solar cells, nano-antennas, and more.
+
+Internally, Inkstone implements rigorous coupled-wave analysis (RCWA), a. k. a. Fourier Modal Method (FMM).
+
+### Inkstone can calculate:
+* the reflection, transmission, and absorption of the structure
+* the total and by-order power fluxes of the propagating and the evanescent waves in each layer
+* electric and magnetic field amplitudes at any locations in the structure,
+* band-structures based on the determinant of the scattering matrix of the structure.
+
+### Features of Inkstone:
+* It supports efficient and flexible parameter-scanning. You can change part of your structure such as the shapes and sizes of some patterns, or some material parameters. Inkstone only recalculates the modified parts and produces the final results efficiently.
+* It allows both tensorial permittivities and tensorial permeabilities, such as in anisotropic, magneto-optical, or gyromagnetic materials.
+* It can calculate the determinant of the scattering matrix on the complex frequency plane.
+* Pre-defined shapes of patterns can be used, including rectangular, parallelogram, disk, ellipse, 1D, and polygons. Closed-form Fourier transforms and corrections for Gibbs phenomena are implemented.
+* It is fully 3D.
+* It is written in pure python, with heavy-lifting done in numpy and scipy.
+
+
+## Quick Start
+### Installation:
+
+ $ pip install inkstone
+Or,
+
+ $ git clone git://github.com/alexysong/inkstone
+ $ pip install .
+
+### Usage
+
+The [examples](examples/) folder contains various self-explaining examples to get you started.
+
+## Dependencies
+
+* python 3.6+
+* numpy
+* scipy
+
+## Units, conventions, and definitions
+
+### Unit system
+We adopt a natural unit system, where vacuum permittivity, permeability, and light speed are $\varepsilon_0=\mu_0=c_0=1$.
+
+### Sign convention
+Sign conventions in electromagnetic waves:
+
+$$e^{i(kx-\omega t)}$$
+
+where $k$ is the wavevector, $x$ is spatial location, $\omega$ is frequency, $t$ is time.
+
+By this convention, a permittivity of $\varepsilon_r + i\varepsilon_i$ with $\varepsilon_i>0$ means material loss, and $\varepsilon_i<0$ means material gain.
+
+### Coordinates and incident angles
+
+<img src="https://github.com/alexysong/inkstone/blob/main/figs/PhC_slab_vector_incident.svg" alt="drawing" width="300">
+
+(Inkstone, **In**cident $\bm{k}$ on **st**acked peri**o**dic **n**ano **e**lectromagnetic structures.)
+
+## Citing
+If you find Inkstone useful for your research, we would apprecite you citing our [paper](https://doi.org/10.1103/PhysRevLett.120.193903). For your convenience, you can use the following BibTex entry:
+
+ @article{song2018broadband,
+ title={Broadband Control of Topological Nodes in Electromagnetic Fields},
+ author={Song, Alex Y and Catrysse, Peter B and Fan, Shanhui},
+ journal={Physical review letters},
+ volume={120},
+ number={19},
+ pages={193903},
+ year={2018},
+ publisher={American Physical Society}
+ }
+
+
+
+
+
+
+%prep
+%autosetup -n inkstone-0.2.11
+
+%build
+%py3_build
+
+%install
+%py3_install
+install -d -m755 %{buildroot}/%{_pkgdocdir}
+if [ -d doc ]; then cp -arf doc %{buildroot}/%{_pkgdocdir}; fi
+if [ -d docs ]; then cp -arf docs %{buildroot}/%{_pkgdocdir}; fi
+if [ -d example ]; then cp -arf example %{buildroot}/%{_pkgdocdir}; fi
+if [ -d examples ]; then cp -arf examples %{buildroot}/%{_pkgdocdir}; fi
+pushd %{buildroot}
+if [ -d usr/lib ]; then
+ find usr/lib -type f -printf "\"/%h/%f\"\n" >> filelist.lst
+fi
+if [ -d usr/lib64 ]; then
+ find usr/lib64 -type f -printf "\"/%h/%f\"\n" >> filelist.lst
+fi
+if [ -d usr/bin ]; then
+ find usr/bin -type f -printf "\"/%h/%f\"\n" >> filelist.lst
+fi
+if [ -d usr/sbin ]; then
+ find usr/sbin -type f -printf "\"/%h/%f\"\n" >> filelist.lst
+fi
+touch doclist.lst
+if [ -d usr/share/man ]; then
+ find usr/share/man -type f -printf "\"/%h/%f.gz\"\n" >> doclist.lst
+fi
+popd
+mv %{buildroot}/filelist.lst .
+mv %{buildroot}/doclist.lst .
+
+%files -n python3-inkstone -f filelist.lst
+%dir %{python3_sitelib}/*
+
+%files help -f doclist.lst
+%{_docdir}/*
+
+%changelog
+* Tue Jun 20 2023 Python_Bot <Python_Bot@openeuler.org> - 0.2.11-1
+- Package Spec generated
diff --git a/sources b/sources
new file mode 100644
index 0000000..308555b
--- /dev/null
+++ b/sources
@@ -0,0 +1 @@
+911aa520a13742430b7462a9c10d11ee inkstone-0.2.11.tar.gz