當前位置: 首頁>>代碼示例>>TypeScript>>正文


TypeScript IMeasureTask.getSampleValueAtIndex方法代碼示例

本文整理匯總了TypeScript中eez-studio-shared/extensions/extension.IMeasureTask.getSampleValueAtIndex方法的典型用法代碼示例。如果您正苦於以下問題:TypeScript IMeasureTask.getSampleValueAtIndex方法的具體用法?TypeScript IMeasureTask.getSampleValueAtIndex怎麽用?TypeScript IMeasureTask.getSampleValueAtIndex使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在eez-studio-shared/extensions/extension.IMeasureTask的用法示例。


在下文中一共展示了IMeasureTask.getSampleValueAtIndex方法的5個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的TypeScript代碼示例。

示例1: function

export default function(task: IMeasureTask) {
    let numSamples = Math.min(
        Math.pow(2, Math.floor(Math.log(task.xNumSamples) / Math.log(2))),
        1024 * 1024
    );

    var real = new Float64Array(numSamples);
    var imag = new Float64Array(numSamples).fill(0);

    for (let i = 0; i < numSamples; ++i) {
        real[i] = task.getSampleValueAtIndex(
            task.xStartIndex + Math.floor((i * task.xNumSamples) / numSamples)
        );
    }

    transform(real, imag);

    // Ignore 0 frequency part when trying to get frequency. Offset can be bigger than wave amplitude and cause issues.
    var maxMag = real[1] * real[1] + imag[1] * imag[1];
    var indexMax = 1;
    for (var i = 2; i < real.length / 2; i++) {
        var magnitude = real[i] * real[i] + imag[i] * imag[i];
        if (magnitude > maxMag) {
            maxMag = magnitude;
            indexMax = i;
        }
    }
    var step = task.samplingRate / task.xNumSamples;
    var frequency = indexMax * step;

    task.result = frequency;
    task.resultUnit = "frequency";
}
開發者ID:eez-open,項目名稱:studio,代碼行數:33,代碼來源:frequency.ts

示例2: function

export default function(task: IMeasureTask) {
    let result = Number.MAX_VALUE;

    const xEndIndex = task.xStartIndex + task.xNumSamples;
    for (let i = task.xStartIndex; i < xEndIndex; ++i) {
        const y = task.getSampleValueAtIndex(i);
        if (y < result) {
            result = y;
        }
    }

    task.result = result;
}
開發者ID:eez-open,項目名稱:studio,代碼行數:13,代碼來源:min.ts

示例3: function

export default function(task: IMeasureTask) {
    let sum = 0;

    const xEndIndex = task.xStartIndex + task.xNumSamples;
    for (let i = task.xStartIndex; i < xEndIndex; ++i) {
        const sample = task.getSampleValueAtIndex(i);
        if (!isNaN(sample)) {
            sum += sample;
        }
    }

    task.result = sum / task.xNumSamples;
}
開發者ID:eez-open,項目名稱:studio,代碼行數:13,代碼來源:average.ts

示例4: function

export default function(task: IMeasureTask) {
    let min = Number.MAX_VALUE;
    let max = Number.MIN_VALUE;

    const xEndIndex = task.xStartIndex + task.xNumSamples;
    for (let i = task.xStartIndex; i < xEndIndex; ++i) {
        const y = task.getSampleValueAtIndex(i);
        if (y < min) {
            min = y;
        }
        if (y > max) {
            max = y;
        }
    }

    task.result = max - min;
}
開發者ID:eez-open,項目名稱:studio,代碼行數:17,代碼來源:peak-to-peak.ts

示例5: function

export default function(task: IMeasureTask) {
    //
    let numSamples = Math.pow(2, Math.floor(Math.log2(task.xNumSamples)));

    let F = task.xNumSamples / numSamples;

    let halfNumSamples = Math.floor(numSamples / 2);

    //
    const real = new Float64Array(numSamples);

    real[0] = task.getSampleValueAtIndex(task.xStartIndex + 0);
    for (let i = 1; i < numSamples; ++i) {
        real[i] = task.getSampleValueAtIndex(task.xStartIndex + Math.round(i * F));
    }

    const imag = new Float64Array(numSamples).fill(0);

    //
    transform(real, imag);

    //
    const yAxisInDecibels =
        !task.parameters || !task.parameters.yAxis || task.parameters.yAxis !== "linear";

    function toDecibels(i: number) {
        const re = real[i];
        const im = imag[i];
        const pow_dB = 10 * Math.log10((re * re + im * im) / (numSamples * numSamples));
        return Math.max(pow_dB, -110);
    }

    function getLinearYValue(i: number) {
        const re = real[i];
        const im = imag[i];
        return Math.sqrt(re * re + im * im) / numSamples;
    }

    const getYValue = yAxisInDecibels ? toDecibels : getLinearYValue;

    const data = new Array(halfNumSamples);
    let minValue, maxValue;
    minValue = maxValue = data[0] = getYValue(0);
    for (let i = 1; i < halfNumSamples; ++i) {
        data[i] = getYValue(i);
        if (data[i] < minValue) {
            minValue = data[i];
        } else if (data[i] > maxValue) {
            maxValue = data[i];
        }
    }

    //
    task.result = {
        data,
        samplingRate: numSamples / (task.samplingRate / F),
        xAxes: {
            unit: "frequency",
            logarithmic:
                !task.parameters || !task.parameters.xAxis || task.parameters.xAxis !== "linear"
        },
        yAxes: {
            unit: yAxisInDecibels ? "decibel" : task.valueUnit,
            minValue,
            maxValue
        }
    };
}
開發者ID:eez-open,項目名稱:studio,代碼行數:68,代碼來源:fft.ts


注:本文中的eez-studio-shared/extensions/extension.IMeasureTask.getSampleValueAtIndex方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。