plugin-timing

Published as @freesewing/plugin-timing, this plugin measures detailed timing information while drafting a design and adds it to the pattern store.

It is intended to be used by developers trying to determine which parts of their code are slow, or in general to provide insights into the speed at which a design can be drafted.

Installation

Shell prompt
npm install @freesewing/plugin-timing

Usage

Either add it as a part plugins in your design, or add it to a pattern instance with Pattern.use().

To import the plugin for use:

Javascript
import { timingPlugin } from '@freesewing/plugin-timing'
// or
import { pluginTiming } from '@freesewing/plugin-timing'

Information in store

The plugin adds the following key/value pairs to the store before and after the pattern and parts drafting process.

KeyDescription
timing.draft.startTimestamp for the start of the pattern drafting process
timing.draft.tookTime it took to draft the pattern
timing.parts.[part name].startTimestamp for the start of the part drafting process
timing.parts.[part name].tookTime it took to draft the part
NOTE

Units and types depend on whether the pattern is generated in a browser or via Node.js.

  • If the pattern is generated in a browser, both start timestamps and draft times are in milliseconds, and the values are Numbers.

  • If the pattern is generated via Node.js, start timestamps are in nanoseconds, draft times are in microseconds, and the values are BigInts.

Examples

Via Node.js

Javascript
import { Aaron } from '@freesewing/aaron'
import { pluginTiming } from '@freesewing/plugin-timing'

// Load some public test measurements from the FreeSewing backend
const measurements = (
  await (
    await fetch("https://backend3.freesewing.org/curated-sets/1.json")
  ).json()
).measurements

const pattern = new Aaron({ measurements }).use(pluginTiming)

const svg = pattern.draft().render()

const patternTook = pattern.setStores[0].get(['timing', 'draft', 'took'])
console.log('The Aaron pattern took ' + patternTook + ' µs to draft.')

const frontTook = pattern.setStores[0].get(['timing', 'parts', 'aaron.front', 'took'])
console.log('The aaron.front part took ' + frontTook + ' µs to draft.')

console.log(JSON.stringify(pattern.setStores[0].timing,
  (key, value
) => typeof value === 'bigint' ? value.toString() : value))

In a browser

For example, in designs/aaron/src/back.mjs:

Javascript
import { pluginTiming } from '@freesewing/plugin-timing'
import { front } from '@freesewing/aaron'

export const back = {
  from: front,
  plugins: [ pluginTiming ],
  draft: ({
    store,
    log,
    part,
...
  }
) => {
...

  const frontTook = store.get(['timing', 'parts', 'aaron.front', 'took'])
  log.info('The aaron.front part took ' + frontTook + ' ms to draft.')

  log.info(JSON.stringify(store.timing))

  return part
  },
}