ngx-khiops-histogram is an Angular TypeScript component for displaying histograms of numerical values in both linear and logarithmic forms. This component is actively maintained and integrated into the Khiops Visualization tool.
While linear representation in x and y axes is standard, and logarithmic representation in y is common, logarithmic representation in x presents challenges for values near zero and for negative intervals.
Negative logarithmic interval values cannot be represented directly since Math.log10(-x) = NaN. To display these values, their absolute values are shown on the negative x-axis: from -1 to -∞.
Values around [-1; 1] are infinite, so the representation would be infinitely large. To avoid this, an arbitrary width of 1/10 of the graph is assigned to this region.
If 0 is a boundary, the arbitrary histogram in the middle is split into two parts to represent values <0 and >0.
yarn add ngx-khiops-histogram
# or
npm install ngx-khiops-histogramAdd the package to your NgModule imports:
import { NgxKhiopsHistogramModule } from 'ngx-khiops-histogram';
@NgModule({
    ...
    imports: [NgxKhiopsHistogramModule, ...]
    ...
})Add component to your page:
<ngx-khiops-histogram
    [datas]="datas"
    [datasLabels]="datasLabels"
    [options]="options"
    [graphOptionX]="graphOptionX"
    [graphOptionY]="graphOptionY"
    (selectedItemChanged)="selectedItemChanged($event)">
</ngx-khiops-histogram>
| Property | Type | Default | Description | 
|---|---|---|---|
| graphOptionX | HistogramType | HistogramType.XLIN | X axis scale | 
| graphOptionY | HistogramType | HistogramType.YLIN | Y axis scale | 
| options | HistogramOptions | See example below | Optional style options | 
| datas | HistogramData | See example below | Data inputs | 
Example for options default:
{
    selectedBarColor: 'black',
    gridColor: '#aaa',
    xPadding: 40,
    yPadding: 50,
    minBarHeight: 4
}Example for datas default:
{
    frequency: number,
    partition: [number, number],
    value: number,
    logValue: number
}| Property | Event type | Description | 
|---|---|---|
| selectedItemChanged | EventEmitter(Number) | Emit new index value when a bar is clicked | 
This software is distributed under the BSD 3-Clause-clear License, the text of which is available at
BSD-3-Clause-Clear or see the LICENSE.md for more details.
The ngx-khiops-histogram library is currently developed at Orange Innovation by the Khiops Team: [email protected].


