Create beautiful diagrams just by typing mathematical notation in plain text.

Overview

Penrose CircleCI

Penrose is an early-stage system that is still in development. Our system is not ready for contributions or public use yet, but hopefully will be soon. Send us an email if you're interested in collaborating.

  • See the site for more information and examples.
  • See the wiki for more system-specific information on building, running, testing, and debugging the system.
  • For even more documentation, see Nimo Ni's README.

Example

Here's a simple Penrose visualization in the domain of set theory.

It's specified by the following Substance and Style programs.

  • tree.sub
    Set A
    Set B
    Set C
    Set D
    Set E
    Set F
    Set G
    Subset B A
    Subset C A 
    Subset D B
    Subset E B
    Subset F C
    Subset G C
    NoIntersect E D
    NoIntersect F G
    NoIntersect B C
    
  • venn.sty
    Set x {
        shape = Circle { }
        constraint contains(x, x.label)
    }
    
    Intersect x y {
        constraint overlapping(x, y)
        constraint outsideOf(y.label, x)
        constraint outsideOf(x.label, y)
    }
    
    NoIntersect x y {
        constraint nonOverlapping(x, y)
    }
    
    Subset x y {
        constraint contains(y, x)
        constraint smallerThan(x, y)
        constraint outsideOf(y.label, x)
    }
    
    NoSubset x y {
        objective repel(x, y)
        constraint outsideOf(x, y)
        constraint outsideOf(y.label, x)
        constraint outsideOf(x.label, y)
        constraint nonOverlapping(x, y)
    }
    

Here's how the optimization looks live in the UI.

Comments
  • Porting runtime to the web

    Porting runtime to the web

    Description

    Related issues: none

    This PR will eventually contain a web runtime for Penrose. Short-term goals include:

    • [x] TypeScript types for various data structures for easier pattern-matching in the evaluator
    • [x] Evaluator: given a serialized State, decode it into some data structure with type, and evaluate the translation in the state. Top level function evalTranslation(s : State) : Shapes
    • [x] A subset of computations as arbitrary TS functions

    Longer-term goals:

    • [x] Optimizer: progress below. Close to done
    • [x] A subset of constraints in TensorFlow.js compatible format
    • [x] If needed, port the computations to the TensorFlow format as well

    See additional documentation on this wiki page.

    Implementation strategy and design decisions

    • This branch has more npm dependencies, so you'll have to run npm install.
    • If you run into fsevents related errors, try brew install watchman, which did the trick for me on Mac OS X Catalina

    Examples with steps to reproduce them

    • TS definitions from Haskell: stack install && tsdef > types.d.ts
    • Tests for evaluator: npm test in react-renderer

    Checklist

    • [ ] I have commented my code, particularly in hard-to-understand areas
    • [ ] I ran Haddock and there were no errors when generating the HTML site
    • [ ] My changes generate no new warnings
    • [ ] New and existing tests pass locally using stack test
    • [ ] My code follows the style guidelines of this project (e.g.: no HLint warnings)

    Open questions

    Questions that require more discussion or to be addressed in future development:

    Backend runtime related

    • While the design of ArgVal seems convenient for differentiating between GPI and Val, I think it's cleaner if we just treat it as an expression since the GPI values can just be treated as yet another data structure similar to lists. Obviously a few things to consider:
    -- Synonyms of GPIs: can a GPI be reused? Is it copied as reference or value?
    global { defaultRect = Rectangle { ... } }
    Set A { A.shape = global.defaultRect }
    Set B { B.shape = global.defaultRect }
    
    -- As discussed a long time before, GPIs as outputs of computation functions
    Set A { 
      A.shape = computeRect(...) -- returns Rectangle. Does `computeRect` have to compute all properties?
      A.shape.x = 3.0 -- Does this take precedance over the previous computation?
    
    kind:extensibility kind:engineering 
    opened by wodeni 33
  • Style 1.01

    Style 1.01

    Description

    This PR extends Style and the shape definitions to handle local vars and vector/matrix types, and ports existing Style programs to use these features. The motivation is to address the dealbreakers that @keenancrane pointed out when writing graphics code in Style.

    Related issues: #375 #372

    Implementation strategy and design decisions

    • Parsing:

      • [x] optional type annotation and import parsing (not used for now)
      • [x] vector & matrix as first class objects in Style
      • [x] new syntax for lists and tuples
      • [x] separate definition of Style identifiers
    • Compilation:

      • Local variables (e.g. x) are handled by replacing them, and all references to them, by a field path with a Substance object named uniquely according to the block number and substitution number.
      • Anonymous statements (e.g. encourage near(x.shape, y.shape)) are handled by turning them into local variable-named statements with a unique anonymous keyword, using a counter
      • Vector-valued properties are sampled like other properties; to refer to anonymous elements (e.g. x[0]) in the list of varying paths, AccessPath is used in findNestedVarying

    Examples with steps to reproduce them

    These include all the currently working Style programs for penrose-web. (These are mostly taken from the first sample, though some may not look exactly like the image since they are from old version of the system.)

    • Orthogonal vector example from paper: runpenrose linear-algebra-domain/twoVectorsPerp.sub linear-algebra-domain/linear-algebra-paper-simple.sty linear-algebra-domain/linear-algebra.dsl

    image

    • Two sets with labels: runpenrose set-theory-domain/twosets-simple.sub set-theory-domain/venn-small.sty set-theory-domain/setTheory.dsl

    image

    • Big set example with circles: runpenrose set-theory-domain/tree.sub set-theory-domain/venn-opt-test.sty set-theory-domain/setTheory.dsl

    image

    • Big set example with tree:runpenrose set-theory-domain/tree.sub set-theory-domain/tree.sty set-theory-domain/setTheory.dsl

    image

    • Continuous map: runpenrose set-theory-domain/continuousmap.sub set-theory-domain/continuousmap.sty set-theory-domain/setTheory.dsl

    image

    • Hyperbolic: runpenrose hyperbolic-domain/hyperbolic-example.sub hyperbolic-domain/PoincareDisk.sty hyperbolic-domain/hyperbolic.dsl

    image

    • Geometry (partial): runpenrose geometry-domain/pythagorean-theorem-sugared.sub geometry-domain/euclidean-simple.sty geometry-domain/geometry.dsl

    image

    • Sets (optimizing thru computation): runpenrose set-theory-domain/multisets.sub set-theory-domain/venn-comp-test.sty set-theory-domain/setTheory.dsl

    image

    • Cross-domain mesh-set example: runpenrose mesh-set-domain/DomainInterop.sub mesh-set-domain/DomainInterop.sty mesh-set-domain/DomainInterop.dsl

    image

    Checklist

    • [ ] I have commented my code, particularly in hard-to-understand areas
    • [ ] I ran Haddock and there were no errors when generating the HTML site
    • [ ] My changes generate no new warnings
    • [ ] New and existing tests pass locally using stack test
    • [ ] My code follows the style guidelines of this project (e.g.: no HLint warnings)

    Open questions

    Questions that require more discussion or to be addressed in future development:

    • Ints are not auto-cast to float. (Right now if say side refers to a path that's an int, it won't get converted, and won't be VarAD in the autodiff, causing a runtime crash)
    • Fully implement AccessPath in Evaluator.ts (see TODOs)
    • Look for varying vals in other composite types like matrix, list, tuple in findNestedVarying (right now if a matrix contains varying vals, the path won't be found; AccessPath needs to include it)
    • Dimensionality of vectors/matrices is hardcoded to 2 in some places
    • Parametric types in general are handled poorly, with special cases to handle e.g. lists containing floats or vectors
    opened by wodeni 27
  • Port Style compiler to typescript

    Port Style compiler to typescript

    Description

    Related issue/PR: #419 #441

    This PR ports the Style compiler to typescript. All past examples work, with the exception of very minor issues listed below.

    Implementation strategy and design decisions

    This is basically a 1:1 port of the Style compiler from Haskell, with some minor changes made to accommodate the fact that we did the Evaluator in ts first (e.g. use of insertExpr in Style compiler) and minor changes in the grammar, as well as minor changes in the functionality of the Domain/Substance toolchain. Errors are dealt with idiosyncratically, usually marked with TODO(errors).

    Done

    • [x] Port previous/new compiler features
      • [x] Selector typechecking (relies on Substance typechecking, @wodeni)
      • [x] Subtypes
      • [x] Path aliasing
      • [x] Disambiguating SEFuncOrValsCons
      • [x] Adding labels and names to translation
    • [x] Add some tests
    • [x] Integrate with system
      • [x] Repro all existing examples with new toolchain (with test suite)
      • [x] Requires Evaluator to work with new grammar
      • [x] Address important TODOs/COMBAKs
    • [x] Integrate with new Domain/Substance parsers (w/ @wodeni)
    • [x] Document compiler (moving comments from Haskell functions)
    • [x] Integrate with App + CLI

    Changes to be made in the near future

    • [x] Layering (@wodeni)
    • [ ] Fix minor label/feature problems, documented in #459 #460 #461 (@hypotext)
    • [ ] Ad-hoc unit testing of negative examples (e.g. testing that invalid programs have the correct errors reported) and specific features in isolation (e.g. path aliasing)
    • [ ] Deprecating StyleTestData? (@hypotext)
    • [ ] Break up Style into modules?
    • [ ] Move comments into docstring format?
    • [ ] Overhaul error and warning handling (w/ @wodeni)

    Examples with steps to reproduce them

    All examples from the previous compiler, on this page, work.

    For more documentation, see compiler/README.md.

    Checklist

    • [x] I have commented my code, particularly in hard-to-understand areas
    • [x] My changes generate no new warnings
    • [x] New and existing tests pass locally using npm test
    • [x] I ran npm run docs and there were no errors when generating the HTML site
    • [x] My code follows the style guidelines of this project (e.g.: no ESLint warnings)

    Open questions

    Questions that require more discussion or to be addressed in future development:

    • [ ] Pseudorandomness
    • [ ] Int/Float disambiguation
    • [ ] Syntactic sugar
    • [ ] Plugins??
    system:style system:port 
    opened by k-qy 22
  • feat: mathtransform with jscodeshift

    feat: mathtransform with jscodeshift

    Description

    The code in this branch is meant to allow users to write constraints/objs in basic math, and translate them afterward to the specific optimization framework. See the README in react-renderer/src/mathtransform for more details.

    Ideally it would run each time a file is changed (or at least a file from a specific list of files we want to transform), so hot-reloading functionality. It’s currently built to run on the command line (sample line: jscodeshift bugtest.ts -t toCustomAD.ts -p -d) , but I think it could also be modified to use the API functions (more detail is here). Another thing to note (also mentioned in the README) is that jscodeshift modifies in place the file you call it on (unless you call a dry run). So if we wanted to keep an unmodified version of that file we would need to make a copy. The CLI for jscodeshift apparently does not support redirecting the output (though the API does) But the program doesn’t change much code, and which code it changes is well-defined and easily reversible so maybe storing the old version is not necessary.

    Sample Input/Output

    Sample Input

        export const objDict = {
            // mathtrans
            equal: (x: number, y: number) => squared(x - y),
    
            // mathtrans
            above: ([t1, top]: [string, any], [t2, bottom]: [string, any], offset = 100) =>
                // (getY top - getY bottom - offset) ^ 2
                squared(top.y.contents - bottom.y.contents - varOf(offset))
        }
    

    Sample Output

        export const objDict = {
            // mathtrans
            equal: (x: VarAD, y: VarAD) => squared(sub(x, y)),
    
            // mathtrans
            above: ([t1, top]: [string, any], [t2, bottom]: [string, any], offset = 100) =>
                // (getY top - getY bottom - offset) ^ 2
                squared(sub(sub(top.y.contents, bottom.y.contents), varOf(offset)))
        }
    

    Remaining issues

    Dependencies

    I’m not sure what to do with the new dependencies. I was just originally working on this project outside of the Penrose directory, so I had to download the jscodeshift package and make my own tsconfig file to get it to work. I assume it should be merged into the main dependency list and node_modules folder but I'm not sure how to do that.

    opened by strout18 18
  • Label point sizes appear visually different despite being set to the same size in Style

    Label point sizes appear visually different despite being set to the same size in Style

    I made some simple examples that Keenan requested for the Penrose blog post / Twitter thread, but am running into a weird font size issue.

    @maxkrieger @wodeni can you take a quick look and let me know how to address this ASAP, or if there's a (reasonably principled) workaround? It's blocking us from posting examples :)

    Repro with minimal example: on branch set-example, do runpenrose set-theory-domain/intersection-venn-diagram.sub set-theory-domain/venn-simple.sty set-theory-domain/setTheory.dsl

    Expected result: all labels have the same size, 15 pt

    Actual result: "Circle" label looks smaller than the other two

    image

    Tried:

    • changing the label size in Style (seems to actually set the label size)
    • running examples with other Styles ("Circle" seems to be consistently mis-sized across Style programs)
    • looking at DOM (svg indeed has fontSize set to the style size, but changing it in chrome does not change the font size live, as noted in https://github.com/penrose/penrose/issues/301#issue-529443958)
    • changing the label text (I can't consistently repro the mis-sizing, e.g. if I change the labels to strings of different sizes, like "Z", "ZZZZ", and "ZZZ ZZZ ZZZZ", the "Z"s all appear the same size, so I'm not sure if it's an aspect ratio problem)

    I also don't know if all three labels are actually mis-sized, but only "Circle" is the visually noticeable one.

    Related issues: https://github.com/penrose/penrose/issues/301#issue-529443958

    kind:bug system:labels 
    opened by k-qy 18
  • Image path exporting hotfix

    Image path exporting hotfix

    BEFORE MERGING: please try importing the SVG in illustration (12).zip into Illustrator. Make sure the brackets/parens show up, it should look like this:

    image

    Description

    A quick hack to substitute inline SVG <image>s with their contents to allow for export portability. Puts all xlinks in the external images into their own unique namespaces.

    Related issues: penrose/penrose-ide#6

    Inline image before:

    <image href="left-bracket.svg" x="490.5946350097656" y="340" width="10" height="20"></image>
    

    Inline image after:

    <g xmlns="http://www.w3.org/2000/svg" transform="translate(150.78616333007812,340)"><svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="10" height="20" viewBox="0 0 6 37" version="1.1"><!--latexit:AAAE9HjabVNrbFRFFD4zU0rpUnrb8igt0IvdKj6AbRW3iGBbyqLiLo/dbrfdLnX2
    7uz20rv3bu6di2w3TSaK/MEYQ4gBFbXbPxQfiBpjGmOMxhglJto2mhCjP4wx/DAx
    Jv4wMdHZh4iGmdzcM2fmnPnOd75J5gzd4T7fEsKkZlntEydi3uPMdnTLjHmt5DGm
    cWfES21tQpfuiJdbuWZAp169rGxeXrf5tk5v1+13bLnzrru7e3fu7t//cOjgcGxs
    XEtNGJbDh7ymaxiLK+o9K9eqw6HwtkmWd0blv5o36tUM6jhzDasalabmltVrBBZE
    1IhlolYsF3VihaifW9e6vq19w8ZNHcIjVopVolE0iTbRLjaKTUKNJanDDN1kQ5pl
    WHYka6XYENe5wWI5m9Fs0mCJLM2YelrXKJclRVKUs3GlMUm1yYxtuWZqbylw1LFc
    W2MRdoJ3QnUs3rPVs227bygUPrJ/YCwULh8M56jGAj5VTlCQaFjoufe+HaOVMkya
    ZbGKyZzhakDxfv8/ZiwUPliuW6lZ8Dyw68ERSYTDbd3MCOWQTLTnIQksFA66nErc
    4fLO7J4+v4yrLBYHPHsH9wVurCWofi6tpMuZI5rFetEyriyMpSzNzTKTl5HEu305
    nihQm+uawabrx1yHyRomaYbFpVnC7CQKZfam1S7pSalpy5afydWy9+aIAs06Tj6b
    lCezlE84/98rOW+1F3d5ujdR0M2cRGpqlYvSrqFyS+X5HFNTui15MfLSoJqtS6yq
    NkFtqnGpxPqSgB45EJx5VKyeeUysEa3RUDggAS4dOnzEE44MReU6rE8xSUw6YNCM
    I9chWVhn35ZKKxVFrBXrokHLpJolmR4ZrWYoxv1VS3oTRyWhg7pW0gm188WEXzof
    p+NK8008pyrUF5P+W/o7+wYqVy4wTzpTkjzXJZD+j65dPz/9x4jYIFPqx+Sdg1KH
    xUl/1SppLbvdF+hW5QTRUOp0bl9AdJR6ejgug9zj40rLDXH8i3LWTfjLsjnA8izV
    X32mX+enIrZlcYGgDpqgDTphK/SAH+JAYQJyUIAn4Rl4Fp6DM3AWnodz8AK8BC/D
    RbgEr8Ob8Ba8De/Ce/A+zMMH8Clcha/gG/gBfoHfUA1qRK2oA3WhHrQT7UK70QAK
    oig6iijSkY04yqOn0NPoFDqNLqAZdAldQfPoM/Q5uoq+xEU8h1/Db+DL+Ap+B8/j
    T/AXeBFfwz/in/DP+Dr+Ff+O/8R/kVriIa2knahkB+klQRIlcaIRg5jEIVNkmpwk
    p8kZcpa8SC6QV8gMmSUXyYfkY7JEviXfVXqAUfUpF+A/g3z/N2H8mSU=
    -->
    <defs>
    <g>
    <symbol overflow="visible" id="glyph0-0">
    <path style="stroke:none;" d=""/>
    </symbol>
    <symbol overflow="visible" id="2-ns-glyph0-1">
    <path style="stroke:none;" d="M 9.140625 8.96875 L 9.140625 7.53125 L 5.671875 7.53125 L 5.671875 -25.453125 L 9.140625 -25.453125 L 9.140625 -26.890625 L 4.234375 -26.890625 L 4.234375 8.96875 Z M 9.140625 8.96875 "/>
    </symbol>
    </g>
    </defs>
    <g id="surface1">
    <g style="fill:rgb(0%,0%,0%);fill-opacity:1;">
      <use xlink:href="#2-ns-glyph0-1" x="-3.788" y="27.6482"/>
    </g>
    </g>
    </svg></g>
    

    Yes, you may notice that id="glyph0-0" is not unique, and neither is <g id="surface1">. However, it has minimal side effects right now, and would need a lot of extra hacks to prevent.

    .

    opened by maxkrieger 18
  • fix: Unify BBox Computation in `Constraints.ts` and Make `Square` Rect-Like

    fix: Unify BBox Computation in `Constraints.ts` and Make `Square` Rect-Like

    Description

    Though Square is a rect-like shape, it does not expose the same interface of w and h like other rect-likes, which causes many constraint implementations to fail on squares.

    This PR enhances the bbox function to compute w, h, and center.

    Additionally, this PR moves the implementation of line-like bboxes into bbox. This also consolidates disjointRectLineAAVert and disjointRectLineAAHoriz into one constraint disjointRectLineAA.

    Implementation strategy and design decisions

    Include a high-level summary of the implementation strategy and list important design decisions made, if any.

    Checklist

    • [x] I have commented my code, particularly in hard-to-understand areas
    • [x] My changes generate no new warnings
    • [x] New and existing tests pass locally using yarn test
    • [x] I ran yarn docs and there were no errors when generating the HTML site
    • [x] My code follows the style guidelines of this project (e.g.: no ESLint warnings)
    opened by joshpoll 17
  • build: improve build time and add `clean` scripts

    build: improve build time and add `clean` scripts

    Description

    Some our packages use create-react-app for the production build, and they slow the CI build workflow down significantly. The reason is CRA uses Webpack for bundling, which is very slow. To work around this, we have been using ESBuild as the bundler in live-reload mode, but not the build. This uses ESBuild for all packages in both live-reload and build modes.

    Also, this PR adds clean scripts to all packages, so that when we run yarn clean at the top level, all build artifacts will be removed.

    Implementation strategy and design decisions

    • The clean scripts use rimraf to remove files
    • In the top-level package.json, we also remove the global node_modules because lerna clean does not remove it.
    • Except for core (which uses both ESBuild for ESM and CJS builds and webpack for UMD build), all packages' build scripts are renamed to build.js for consistency.
    • For easier deployment, browser-ui and synthesizer-ui build their app.js/css under public, instead of build, just like what @penrose/panels does.

    Checklist

    • [x] I have commented my code, particularly in hard-to-understand areas
    • [x] My changes generate no new ESLint warnings

    Open questions

    N/A

    Questions that require more discussion or to be addressed in future development:

    opened by wodeni 15
  • Add list types and values to Element, Substance, and Style

    Add list types and values to Element, Substance, and Style

    We are very soon going to need to support polymorphic lists in Element, Substance, and Style (both selector and block). This is necessary for the raytracing domain and for several subsequent ones (e.g. graph theory, neural networks). Here is an example usage in raytracing from the design paper:

    image image

    Specifically:

    • Element needs to be able to parse, specify, typecheck, etc. lists (as a builtin polymorphic type that can be used to define further types)--with syntactic sugar
    • Substance needs to be able to parse, specify, typecheck lists (as values of list types)--with syntactic sugar
    • Style selectors need to be able to parse and match on those list types and lists of values from Substance
    • Style blocks need to be able to specify lists of expressions and operate generically over them (this may be a task for a separate issue)
    system:parser system:language kind:semantics 
    opened by k-qy 15
  • Fix increasing optimization slowness after system overhaul

    Fix increasing optimization slowness after system overhaul

    The new Style rewrite (#99) reduced the performance of the system. Based on the profiling results (#13), we suspect the optimizer becomes slower due to the increased number of transformations we do. We would like to explore other optimization methods that are of lower computational costs.

    Some early ideas:

    • eliminate the automatic differentiation
    • use a zeroth order optimization method
      • it may converge slower overall but maybe each step will be faster
    • numerically estimate gradients
    system:optimization kind:performance 
    opened by wodeni 15
  • feat: Make Penrose deterministic

    feat: Make Penrose deterministic

    Description

    Resolves #731.

    This PR makes Penrose deterministic. At a surface level, that roughly means the following:

    • registry
      • each of the trios in any Registry now has an an additional field variation, which represents a seed
      • rendered versions of all diagrams in the registry are tracked in diagrams/, kept up to date by a CI check
      • diagrams using bold text seem to render differently on macOS vs in CI, so they have been removed from the registry
    • @penrose/core
      • compileTrio, diagram, and interactiveDiagram now use keyword params; now variation is required
      • the end-to-end diagram tests now write to the diagrams/ folder in this repo instead of to /tmp/diagrams/
      • to get a consistent diagram, you now must always call resample after calling prepareState
      • the resample function no longer takes a number, since previously it didn't do anything
      • resample just resets the state; it doesn't actually change the variation
      • to change the variation, use the new variationSeeds function, then call resample
      • State now has a field seeds which is used to seed PRNGs when calling certain functions on it
    • @penrose/browser-ui
      • new setting for the variation
      • resample button changes the variation and also resets the diagram
      • new reset button which resets the diagram but keeps the variation the same
      • hitting enter on the variation text box also resets the diagram using the entered variation string
    • @penrose/docs-site
      • always uses the same two seeds for _ShapeProps
    • @penrose/synthesizer-ui
      • the variation used is always progNumber.toString()

    Implementation strategy and design decisions

    • removed top-level call to seedrandom with { global: true }
    • many functions throughout @penrose/core now take a seedrandom.prng as their first parameter
    • every function in compDict takes a Context as its first parameter; currently just a PRNG
    • using the variation, we (first, so resampling doesn't need to recompile) generate some Seeds into the State

    Examples with steps to reproduce them

    Standard Penrose workflow. From the repo root:

    yarn start
    

    Then in a separate terminal:

    cd examples/set-theory-domain
    npx roger watch setTheory.dsl venn.sty twosets-simple.sub
    
    Open up http://localhost:3000/; it should look exactly like this (if it doesn't, copy in the variation and hit enter):

    tfJ7rRKHjH

    However many times you click "reset", you should still get the same diagram.

    Now click "resample"; the variation will change to something random (probably not this particular one):

    RbbjyprfHy

    Again, click "reset" however many times and you'll still get the same diagram.

    Type "Hello, world!" into the "variation" text box and hit enter; you should see exactly this:

    Hello, world!

    Checklist

    • [x] I have commented my code, particularly in hard-to-understand areas
    • [x] My changes generate no new ESLint warnings
    opened by samestep 14
  • refactor: use top-level `await` for Wasm

    refactor: use top-level `await` for Wasm

    Description

    As a followup to #1092 and #1172, this PR simplifies @penrose/optimizer by using top-level await. This requires us to add build: { target: "esnext" } to all our Vite configs.

    Checklist

    • [x] I have commented my code, particularly in hard-to-understand areas
    • [x] My changes generate no new ESLint warnings
    • [x] I have reviewed any generated registry diagram changes
    opened by samestep 3
  • build(deps): bump json5 from 1.0.1 to 1.0.2

    build(deps): bump json5 from 1.0.1 to 1.0.2

    Bumps json5 from 1.0.1 to 1.0.2.

    Release notes

    Sourced from json5's releases.

    v1.0.2

    • Fix: Properties with the name __proto__ are added to objects and arrays. (#199) This also fixes a prototype pollution vulnerability reported by Jonathan Gregson! (#295). This has been backported to v1. (#298)
    Changelog

    Sourced from json5's changelog.

    Unreleased [code, diff]

    v2.2.3 [code, diff]

    v2.2.2 [code, diff]

    • Fix: Properties with the name __proto__ are added to objects and arrays. (#199) This also fixes a prototype pollution vulnerability reported by Jonathan Gregson! (#295).

    v2.2.1 [code, diff]

    • Fix: Removed dependence on minimist to patch CVE-2021-44906. (#266)

    v2.2.0 [code, diff]

    • New: Accurate and documented TypeScript declarations are now included. There is no need to install @types/json5. (#236, #244)

    v2.1.3 [code, diff]

    • Fix: An out of memory bug when parsing numbers has been fixed. (#228, #229)

    v2.1.2 [code, diff]

    ... (truncated)

    Commits

    Dependabot compatibility score

    Dependabot will resolve any conflicts with this PR as long as you don't alter it yourself. You can also trigger a rebase manually by commenting @dependabot rebase.


    Dependabot commands and options

    You can trigger Dependabot actions by commenting on this PR:

    • @dependabot rebase will rebase this PR
    • @dependabot recreate will recreate this PR, overwriting any edits that have been made to it
    • @dependabot merge will merge this PR after your CI passes on it
    • @dependabot squash and merge will squash and merge this PR after your CI passes on it
    • @dependabot cancel merge will cancel a previously requested merge and block automerging
    • @dependabot reopen will reopen this PR if it is closed
    • @dependabot close will close this PR and stop Dependabot recreating it. You can achieve the same result by closing it manually
    • @dependabot ignore this major version will close this PR and stop Dependabot creating any more for this major version (unless you reopen the PR or upgrade to it yourself)
    • @dependabot ignore this minor version will close this PR and stop Dependabot creating any more for this minor version (unless you reopen the PR or upgrade to it yourself)
    • @dependabot ignore this dependency will close this PR and stop Dependabot creating any more for this dependency (unless you reopen the PR or upgrade to it yourself)
    • @dependabot use these labels will set the current labels as the default for future PRs for this repo and language
    • @dependabot use these reviewers will set the current reviewers as the default for future PRs for this repo and language
    • @dependabot use these assignees will set the current assignees as the default for future PRs for this repo and language
    • @dependabot use this milestone will set the current milestone as the default for future PRs for this repo and language

    You can disable automated security fix PRs for this repo from the Security Alerts page.

    kind:dependencies 
    opened by dependabot[bot] 2
  • Some scripts aren't colored when run by Nx

    Some scripts aren't colored when run by Nx

    As mentioned in #1092, Nx sets a FORCE_COLOR environment variable when calling scripts. However, some tools don't follow this convention, and instead take CLI args to enable color. In shell it's easy to pass a CLI arg conditionally on the setting of an environment variable; for instance:

    • esbuild ${FORCE_COLOR+--color=true}
    • cargo ${FORCE_COLOR+--color=always}

    I didn't actually implement this, though, because I don't think it works on Windows. It would be nice to get colors for all these tools on all platforms.

    opened by samestep 0
  • build: Don't bundle core

    build: Don't bundle core

    Description

    We don't need to, as far as I can tell; anything using @penrose/core that wants to bundle it should be able to just bundle it directly, so there's no reason to put all our dependencies into the bundle when they're already dependencies of the package itself. This is a followup to #1160, #1165, and #1170. See also #423.

    Implementation strategy and design decisions

    To increase consistency with our other packages, I changed the core build directory from build/dist/ to just dist/. Previously packages/synthesizer-ui/README.md also erroneously said it used build/ instead of dist/, so I corrected that here too.

    Checklist

    • [x] I have commented my code, particularly in hard-to-understand areas
    • [x] My changes generate no new ESLint warnings
    • [x] I have reviewed any generated changes to the diagrams/ folder

    Open questions

    • This PR removes core's start and watch scripts, because I wasn't sure how to deal with them when we have both tsc and tsc-alias to run.
    opened by samestep 4
  • refactor: unify default strokeColor for outline shapes

    refactor: unify default strokeColor for outline shapes

    Description

    Related issue/PR: #430

    This PR makes #fff the default strokeColor for "outline" shapes such as Line, Path, and Text. Path is consider an outline shape out of uncertainty that the path might not be closed.

    Implementation strategy and design decisions

    • Change default props in respective shape files

    Examples with steps to reproduce them

    See deployment allShapes-allShapes example.

    Checklist

    • [x] I have commented my code, particularly in hard-to-understand areas
    • [x] My changes generate no new ESLint warnings
    • [x] I have reviewed any generated changes to the diagrams/ folder

    Open questions

    Looks like this impacted variations of many diagrams. Why? (cc: @samestep) Looks like even when the Style props remain the same, as long as there's a change to the defaults, the resulting diagrams will change.

    opened by wodeni 4
  • Inline comparison operators for constraints and objectives

    Inline comparison operators for constraints and objectives

    Is your feature request related to a problem? Please describe.

    Currently, only calls to the constraint library is allowed in ensure and encourage statements. The syntax can be a bit restrictive and counter-intuitive. For instance, to express norm(c.vec) > 200, one can only write ensure lessThan(200, norm(c.vec)).

    Describe the solution you'd like

    Support boolean expressions such as ==, >, <, <=, >= in constraint/objective statements as a starter. To improve the expressiveness, we may also support chained expressions such as 10 <= norm(c.vec) < 200.

    system:style system:language 
    opened by wodeni 1
Releases(v1.3.0)
  • v1.3.0(Jun 24, 2021)

    Change log

    Changes for users

    • BREAKING: Style programs now support configurable canvas dimensions, and require that the canvas be configured. More information here.
    • New callout shapes (text bubbles) available in Style. API here.
    • Path shape now supports Arc commands. API here.
    • Arrowheads incorporated in the path length
    • Better computation of disjoint constraint on boxes
    • New existential graph domain (#600)

    Changes for devs

    • Various synthesizer updates
    • See more detailed changelog here.
    Source code(tar.gz)
    Source code(zip)
  • v1.2.0(May 24, 2021)

  • v1.1.0(Apr 21, 2021)

    Change log

    Changes for users

    • Interface: Easier optimization debugging. The new opt tab in inspector displays the objectives and constraints that apply to your diagram, as well as information about how well the optimizer was able to satisfy them.
    • Interface: autostep is no longer on by default. By default, you will see the initial state of a diagram, and should hit autostep to turn it on, so it optimizes.
    • Style: Support for dashed shape strokes. You can now set the strokeDashArray property of any shape to a string value, following the SVG spec for stroke-dasharray. For example: strokeDashArray: "4 1 2 3"
    • Library: Experimental support for shapes Polygon and Polyline. Example program triple in examples/shape-spec: shape-spec.dsl,shapes.sub, shape-spec.sty
    • Library: Support for sqrt, max, min, abs, norm, normsq, vdist, vdistsq, rot90 to be called from Style; better support for disjoint functions (example program: roger watch graph-domain/small-graph.sub graph-domain/disjoint-rect-line-horiz.sty graph-domain/graph-theory.dsl)
    • Optimization: Better support for optimizing functions that contain conditionals (ifCond, max, min, etc.)
    • Style: Experimental support for initializing varying variables by a custom value, VARYING_INIT(i) (where i is your custom value). This is helpful for testing the optimization with custom initial states. See the Style language page for more information.

    Changes for devs

    • API: Expose evalFns for individual opt fns, and compile each opt fn
    • Domain: Add experimental graph domain
    • System: Add mathtransform (not yet used)
    • Language: Process prelude values in Substance only
    • Various bugfixes
    Source code(tar.gz)
    Source code(zip)
Owner
Penrose
Create beautiful diagrams just by typing mathematical notation in plain text.
Penrose
Very simple encoding scheme that will encode data as a series of OwOs or UwUs.

OwO Encoder Very simple encoding scheme that will encode data as a series of OwOs or UwUs. The encoder is a simple state machine. Still needs a decode

1 Nov 15, 2021
Lightweight library for accessing data and configuration

accsr This lightweight library contains utilities for managing, loading, uploading, opening and generally wrangling data and configurations. It was ba

appliedAI Initiative 7 Mar 09, 2022
Performance monitoring and testing of OpenStack

Browbeat Browbeat is a performance tuning and analysis tool for OpenStack. Browbeat is free, Open Source software. Analyze and tune your Cloud for opt

cloud-bulldozer 83 Dec 14, 2022
XHacks 2021 Startup Track Winner: Be Heard. Educate, Enact, Empower. No voice left behind. (backend)

Be Heard: X Hacks 2021 Submission Educate, Enact, Empower. No voice left behind. Inspiration To say 2020 was an eventful year would be an understateme

3 Jul 14, 2022
Tools for dos (denial-of-service) website / web server

DoS Attack Tools Tools for dos (denial-of-service) website / web server di buat olah NurvySec How to install on debian / ubuntu $ apt update $ apt ins

nurvy 1 Feb 10, 2022
A program that makes all 47 textures of Optifine CTM only using 2 textures

A program that makes all 47 textures of Optifine CTM only using 2 textures

1 Jan 22, 2022
Программа для практической работы №12 по дисциплине

Информатика: программа для практической работы №12 Код и блок-схема программы для практической работы №12 по дисциплине "Информатика" (I семестр). Сут

Vladislav 1 Dec 07, 2021
The Playwright Workshop for TAU: The Homecoming

tau-playwright-workshop This repository contains the instructions and example code for the Playwright workshop for TAU: The Homecoming on December 1,

Pandy Knight 134 Dec 30, 2022
Sheet2export - FreeCAD macro to export spreadsheet

Description This is FreeCAD macro to export spreadsheet to file.

Darek L 3 Jul 09, 2022
Gitlab py scripts

Gitlab py scripts The code can be used to gather the list of GitHub groups/projects and the permissions of the users in those groups/projects. group/p

Roghuchi 1 Aug 29, 2022
A telegram bot which programed to countdown.

countdown-vi this is a telegram bot which programed to countdown. usage well, first you should specify a exact interval. there is 5 column, very first

Arya Shabane 3 Feb 15, 2022
Roblox Limited Sniper For Python

Info this is version 2.1 version 3 will support more options (install python: https://www.python.org) the program will buy any limited item with a pri

1 Dec 09, 2021
MinimalGearDisplay, Assetto Corsa app

MinimalGearDisplay MinimalGearDisplay, Assetto Corsa app. Just displays the current gear you are on. Download and Install To use this app, clone or do

1 Jan 10, 2022
Kubernetes-native workflow automation platform for complex, mission-critical data and ML processes at scale. It has been battle-tested at Lyft, Spotify, Freenome, and others and is truly open-source.

Flyte Flyte is a workflow automation platform for complex, mission-critical data, and ML processes at scale Home Page · Quick Start · Documentation ·

Flyte 3k Jan 01, 2023
Zotero references script (and app)

A little script (and PyInstaller build) for a very specific, somewhat hack-ish purpose: managing and exporting project references with Zotero and its API.

Marius Rödder 0 Dec 05, 2021
MySQL Connectivity based project. Contains various functions of a Store-Management-System

An Intermediate Level Python - MySQL Connectivity based project. Contains various functions of a Store-Management-System.

Yash Wadhvani 2 Nov 21, 2022
Hera is a Python framework for constructing and submitting Argo Workflows.

Hera is an Argo Workflows Python SDK. Hera aims to make workflow construction and submission easy and accessible to everyone! Hera abstracts away workflow setup details while still maintaining a cons

argoproj-labs 241 Jan 02, 2023
2021华为软件精英挑战赛 程序输出分析器

AutoGrader 0.2.0更新:加入资源分配溢出检测,如果发生资源溢出会输出溢出发生的位置。 如果通过检测,会显示通过符号 如果没有通过检测,会显示警告,并输出溢出发生的位置和操作

54 Aug 14, 2022
Some shitty programs just to brush up on my understanding of binary conversions.

Binary Converters Some shitty programs just to brush up on my understanding of binary conversions. Supported conversions formats = "unsigned-binary" |

Tim 2 Jan 09, 2022
Library for managing git hooks

Autohooks Library for managing and writing git hooks in Python. Looking for automatic formatting or linting, e.g., with black and pylint, while creati

Greenbone 165 Dec 16, 2022