squiggle/packages/squiggle-lang
2022-03-25 12:48:02 -04:00
..
__tests__ Better describe test cases 2022-03-23 13:12:20 +11:00
src Remove unneccesary log 2022-03-25 15:37:07 +11:00
.gitignore Add squiggle notebooks 2022-03-22 13:33:28 +11:00
.npmignore Move to webpack 2022-03-22 10:40:14 +11:00
bsconfig.json squiggle-lang/bsconfig.json: updated package name 2022-03-24 11:29:42 -04:00
jest.config.js Add typescript to squiggle-lang 2022-02-18 13:16:31 +11:00
package.json Merge pull request from QURIresearch/dependabot/npm_and_yarn/typescript-4.6.3 2022-03-25 11:26:56 -04:00
README.md (rebase): README improvements, and other such things 2022-03-25 12:48:02 -04:00
tsconfig.json Reference lang source code directly from components 2022-03-25 10:27:17 +11:00
webpack.config.js Move to webpack 2022-03-22 10:40:14 +11:00

Squiggle language

Build for development

We assume that you ran yarn at the monorepo level.

yarn build

yarn bundle is needed for a deployment.

Other:

yarn start  # listens to files and recompiles at every mutation
yarn test
yarn test:watch  # keeps an active session and runs all tests at every mutation

Information

Squiggle is a language for representing probability distributions, as well as functions that return probability distributions. Its original intended use is for improving epistemics around EA decisions.

This package, @quri/squiggle-lang, contains the core language of squiggle. The main feature revolves around evaluating squiggle expressions. Currently the package only exports a single function, named "run", which from a squiggle string returns an object representing the result of the evaluation.

If using this package for tests or as a dependency, typescript typings are available and recommended to be used.

This package is mainly written in ReScript, but has a typescript interface.

ReScript has an interesting philosophy of not providing much in the way of effective build tools. Every ReScript file is compiled into .bs.js and .gen.ts files with the same name and same location, and then you can use these files in other .js files to create your program. To generate these files to build the package, you run yarn build.

.gen.ts files are created by the @genType decorator, which creates typescript typings for needed parts of the codebase so that they can be easily used in typescript. These .gen.ts files reference the .bs.js files generated by rescript.

Errors regarding the rationale package

You may notice sometimes, that there are errors about the rationale package. If you ever get these errors, yarn build should fix this issue. These errors occur because yarn build also needs to create build files that are in node_modules. So if you replace node_modules you may need to rebuild to get those files back.

Distributing this package or using this package from other monorepo packages

As it says in the other packages/*/README.mds, building this package is an essential step of building other packages.