1.0.2 • Published 5 years ago

node-seasonal v1.0.2

Weekly downloads
4
License
MIT
Repository
github
Last release
5 years ago

node-seasonal

A simple Node.js wrapper for X-13-ARIMA-SEATS, the seasonal adjustment software by the U.S. Census Bureau

Installation and usage

Install:

npm install --save node-seasonal

Use:

const seasonal = require('node-seasonal');

// Your input data must be an array of objects with the requred fields
const input_data = [
  {
    month: "1998-01",
    shoe_sales: 100343,
    shirt_sales: 35991
  },
  // { ... } etc etc
];

const options = {
  date_field: "month", // Dates must be formatted YYYY-MM
  value_fields: ["shoe_sales", "shirt_sales"], // All values in data to adjust
  table_ids: ["d11"], // d11 is standard seasonal adjustment
  output_dir: `${__dirname}/output`, // x13 files deleted if left empty
  log: true // Whether to log output of x13 command
};

const adjusted_data = seasonal.adjust(input_data, options);

The above will auto-adjust the input data and append the adjusted numbers to it. The output will include the original data, with new fields for the adjusted numbers which include the requested table IDs. That is, in the example above, adjusted_data would look like this:

[
  {
    month: "1998-01",
    shoe_sales: 100343,
    shirt_sales: 35991,
    shoe_sales_d11: 90443,
    shirt_sales_d11: 38002
  },
  // { ... } etc etc
]

Each valid table ID specified in the options will append a new field for each value field specified.

Options

Required properties:

date_field (String) Date format must be YYYY-MM; (seasonal.adjust() only supports monthly adjustments)

value_fields (Array of strings) Should include all fields in input data that should be seasonally adjusted

table_ids (Array of strings) Refer to the x13ashtml reference manual for a listing of codes (d11 is final seasonally adjusted numbers)

Optional properties:

output_dir (String) Where to output x13ashtml files. If empty or null, output files are deleted.

log (Boolean) Whether to log output of x13ashtml command, which is useful for debugging. (Default is false.)

Use a custom .spc file

seasonal.custom({
  input_file_path: `${__dirname}/input_filename`, // Required
  log: true // Optional (default is false)
});

This simply runs a .spc file you create on your own and saves the x13ashtml output files. The files will be saved to the same directory where the input spec file is. Refer to the x13ashtml reference manual for the specifications of the input files.