From 1e48ede4fec3066c8a76d0314992a5f5f2f37961 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?St=C3=A9phane=20Laurent?= Date: Thu, 16 Feb 2023 18:57:24 +0100 Subject: [PATCH] theta_c --- CHANGELOG.md | 11 ++++++ LICENSE | 30 +++++++++++++++ README.md | 1 + Setup.hs | 2 + jacobi-elliptic.cabal | 35 +++++++++++++++++ jacobi-elliptic.code-workspace | 18 +++++++++ src/Math/NevilleTheta.hs | 17 +++++++++ stack.yaml | 69 ++++++++++++++++++++++++++++++++++ stack.yaml.lock | 12 ++++++ 9 files changed, 195 insertions(+) create mode 100644 CHANGELOG.md create mode 100644 LICENSE create mode 100644 README.md create mode 100644 Setup.hs create mode 100644 jacobi-elliptic.cabal create mode 100644 jacobi-elliptic.code-workspace create mode 100644 src/Math/NevilleTheta.hs create mode 100644 stack.yaml create mode 100644 stack.yaml.lock diff --git a/CHANGELOG.md b/CHANGELOG.md new file mode 100644 index 0000000..154a8be --- /dev/null +++ b/CHANGELOG.md @@ -0,0 +1,11 @@ +# Changelog for `jacobi-elliptic` + +All notable changes to this project will be documented in this file. + +The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/), +and this project adheres to the +[Haskell Package Versioning Policy](https://pvp.haskell.org/). + +## Unreleased + +## 0.1.0.0 - YYYY-MM-DD diff --git a/LICENSE b/LICENSE new file mode 100644 index 0000000..9783b89 --- /dev/null +++ b/LICENSE @@ -0,0 +1,30 @@ +Copyright Stéphane Laurent (c) 2023 + +All rights reserved. + +Redistribution and use in source and binary forms, with or without +modification, are permitted provided that the following conditions are met: + + * Redistributions of source code must retain the above copyright + notice, this list of conditions and the following disclaimer. + + * Redistributions in binary form must reproduce the above + copyright notice, this list of conditions and the following + disclaimer in the documentation and/or other materials provided + with the distribution. + + * Neither the name of Stéphane Laurent nor the names of other + contributors may be used to endorse or promote products derived + from this software without specific prior written permission. + +THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS +"AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT +LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR +A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT +OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, +SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT +LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, +DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY +THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT +(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE +OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. diff --git a/README.md b/README.md new file mode 100644 index 0000000..980accb --- /dev/null +++ b/README.md @@ -0,0 +1 @@ +# jacobi-elliptic diff --git a/Setup.hs b/Setup.hs new file mode 100644 index 0000000..9a994af --- /dev/null +++ b/Setup.hs @@ -0,0 +1,2 @@ +import Distribution.Simple +main = defaultMain diff --git a/jacobi-elliptic.cabal b/jacobi-elliptic.cabal new file mode 100644 index 0000000..030d547 --- /dev/null +++ b/jacobi-elliptic.cabal @@ -0,0 +1,35 @@ +name: jacobi-elliptic +version: 0.1.0.0 +synopsis: Neville Theta Functions and Jacobi Elliptic Functions +description: Evaluation of the Neville theta functions and the Jacobi elliptic functions. +homepage: https://github.com/stla/jacobi-elliptic#readme +license: BSD3 +license-file: LICENSE +author: Stéphane Laurent +maintainer: laurent_step@outlook.fr +copyright: 2023 Stéphane Laurent +category: Math, Numeric +build-type: Simple +extra-source-files: README.md + CHANGELOG.md +cabal-version: >=1.10 + +library + hs-source-dirs: src + exposed-modules: Math.NevilleTheta + build-depends: base >= 4.7 && < 5 + , jacobi-theta + default-language: Haskell2010 + ghc-options: -Wall + -Wcompat + -Widentities + -Wincomplete-record-updates + -Wincomplete-uni-patterns + -Wmissing-export-lists + -Wmissing-home-modules + -Wpartial-fields + -Wredundant-constraints + +source-repository head + type: git + location: https://github.com/stla/jacobi-elliptic diff --git a/jacobi-elliptic.code-workspace b/jacobi-elliptic.code-workspace new file mode 100644 index 0000000..374af43 --- /dev/null +++ b/jacobi-elliptic.code-workspace @@ -0,0 +1,18 @@ +{ + "folders": [ + { + "path": "." + } + ], + "settings": { + "haskell.serverEnvironment": { + "PATH": "/home/stla/.ghcup/bin:/usr/bin:$PATH" + }, + "haskell.toolchain": { + "ghc": "9.0.2", + "hls": "1.7.0.0", + "cabal": "3.6.2.0", + "stack": "2.9.3" + } + } +} \ No newline at end of file diff --git a/src/Math/NevilleTheta.hs b/src/Math/NevilleTheta.hs new file mode 100644 index 0000000..2b25f74 --- /dev/null +++ b/src/Math/NevilleTheta.hs @@ -0,0 +1,17 @@ +module Math.NevilleTheta + ( theta_c + ) where +import Data.Complex +import Math.JacobiTheta + +type Cplx = Complex Double + +theta_c :: + Cplx + -> Cplx + -> Cplx +theta_c z q = + jtheta2 z' q / jtheta2 0 q + where + j3 = jtheta3 0 q + z' = z / (j3 * j3) \ No newline at end of file diff --git a/stack.yaml b/stack.yaml new file mode 100644 index 0000000..108d5f9 --- /dev/null +++ b/stack.yaml @@ -0,0 +1,69 @@ +# This file was automatically generated by 'stack init' +# +# Some commonly used options have been documented as comments in this file. +# For advanced use and comprehensive documentation of the format, please see: +# https://docs.haskellstack.org/en/stable/yaml_configuration/ + +# Resolver to choose a 'specific' stackage snapshot or a compiler version. +# A snapshot resolver dictates the compiler version and the set of packages +# to be used for project dependencies. For example: +# +# resolver: lts-3.5 +# resolver: nightly-2015-09-21 +# resolver: ghc-7.10.2 +# +# The location of a snapshot can be provided as a file or url. Stack assumes +# a snapshot provided as a file might change, whereas a url resource does not. +# +# resolver: ./custom-snapshot.yaml +# resolver: https://example.com/snapshots/2018-01-01.yaml +resolver: lts-20.11 + +# User packages to be built. +# Various formats can be used as shown in the example below. +# +# packages: +# - some-directory +# - https://example.com/foo/bar/baz-0.0.2.tar.gz +# subdirs: +# - auto-update +# - wai +packages: +- . +- ../jacobi-theta + +# Dependency packages to be pulled from upstream that are not in the resolver. +# These entries can reference officially published versions as well as +# forks / in-progress versions pinned to a git hash. For example: +# +# extra-deps: +# - acme-missiles-0.3 +# - git: https://github.com/commercialhaskell/stack.git +# commit: e7b331f14bcffb8367cd58fbfc8b40ec7642100a +# +#extra-deps: +#- jacobi-theta-0.1.0.0 + +# Override default flag values for local packages and extra-deps +# flags: {} + +# Extra package databases containing global packages +# extra-package-dbs: [] + +# Control whether we use the GHC we find on the path +# system-ghc: true +# +# Require a specific version of Stack, using version ranges +# require-stack-version: -any # Default +# require-stack-version: ">=2.9" +# +# Override the architecture used by Stack, especially useful on Windows +# arch: i386 +# arch: x86_64 +# +# Extra directories used by Stack for building +# extra-include-dirs: [/path/to/dir] +# extra-lib-dirs: [/path/to/dir] +# +# Allow a newer minor version of GHC than the snapshot specifies +# compiler-check: newer-minor diff --git a/stack.yaml.lock b/stack.yaml.lock new file mode 100644 index 0000000..90e049c --- /dev/null +++ b/stack.yaml.lock @@ -0,0 +1,12 @@ +# This file was autogenerated by Stack. +# You should not edit this file by hand. +# For more information, please see the documentation at: +# https://docs.haskellstack.org/en/stable/lock_files + +packages: [] +snapshots: +- completed: + sha256: adbc602422dde10cc330175da7de8609e70afc41449a7e2d6e8b1827aa0e5008 + size: 649342 + url: https://raw.githubusercontent.com/commercialhaskell/stackage-snapshots/master/lts/20/11.yaml + original: lts-20.11