Web 基尼系数的计算

<!DOCTYPE html>
<html>

<head>
  <title>计算基尼系数</title>
  <script src="https://cdn.staticfile.org/Chart.js/3.9.1/chart.js"></script>
  <script>
    var myChart;
    function giniCoefficient(data) {
     
      var cum_data = Array.from({
      length: data.length + 1 }, function (_, i) {
     
        return i === data.length ? 0 : data[i];
      }).sort(function (a, b) {
      return a - b; }).reduce(function (acc, val) {
     
        acc.push((acc[acc.length - 1] || 0) + val);
        return acc;
      }, []);
      var sum_data = cum_data[cum_data.length - 1];
      var xarray = Array.from({
      length: cum_data.length }, function (_, i) {
      return i / (cum_data.length - 1); });
      var upper = xarray;
      var yarray = cum_data.map(function (val) {
      return val / sum_data; });
      console.log(xarray, yarray);
      //pl.plot(xarray, yarray)
      //pl.plot(xarray, upper)
      var B = trapz(yarray, xarray);
      console.log("B的面积:", B);
      var A = 0.5 - B;
      console.log("A的面积:", A);
      var G = A / (A + B);

      // 销毁之前的图表实例
      if (myChart) {
     
        myChart.destroy();
      }
      // 创建画布
      const canvas = document.getElementById('giniChart');
      canvas.width = 30;
      canvas.height = 20;
      var ctx = canvas.getContext('2d');

      // 绘制基尼系数曲线
      myChart = new Chart(ctx, {
     
        type: 'line',
        data: {
     
          labels: xarray,
          datasets: [
            {
     
              label: '洛伦茨曲线的面积',
              data: yarray,
              borderColor: 'blue',
              backgroundColor: 'rgba(0, 0, 255, 0.5)',
              fill: true
            },
            {
     
              label: '绝对平等线面积与洛伦茨曲线面积之差',
              data: xarray,
              borderColor: 'red',
              backgroundColor: 'rgba(255, 0, 0, 0.5)',
              fill: true,
            }
          ]
        },
        options: {
     
          scales: {
     
            x: {
     
              display: true,
              title: {
     
                display: true,
                text: '个数累计百分比'
              }
            },
            y: {
     
              display: true,
              title: {
     
                display: true,
                text: '数值累计百分比'
              }
            }
          },
          title: {
     
            display: true,
            text: 'Gini Coefficient'
          }
        }
      });

      return G;
    }

    function trapz(y, x) {
     
      if (y.length !== x.length) {
     
        throw new Error('The length of y and x must be the same');
      }
      var n = y.length;
      var s = 0;
      for (var i = 1; i < n; i++) {
     
        s += (x[i] - x[i - 1]) * (y[i] + y[i - 1]);
      }
      return s / 2;
    }


    function calculateGini() {
     
      var values = document.getElementById("inputValues").value;
      var data = values.split(",").map(Number);

      var result = giniCoefficient(data)

      document.getElementById("result").innerHTML = "基尼系数: " + result;
    }
  </script>
</head>

<body>
  <h1>计算基尼系数</h1>
  <label for="inputValues">输入数据(用逗号分隔):</label>
  <input type="text" id="inputValues"><br><br>
  <button onclick="calculateGini()">计算</button><br><br>
  <div id="result"></div>
  <dic style="width: 600px; display:block">
  <canvas id="giniChart"></canvas>
  </dic>
</body>

</html>

相关推荐

最近更新

  1. TCP协议是安全的吗?

    2024-01-12 17:42:06       19 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-01-12 17:42:06       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-01-12 17:42:06       20 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-01-12 17:42:06       20 阅读

热门阅读

  1. 获取时间进行格式化

    2024-01-12 17:42:06       33 阅读
  2. 算法训练营Day38

    2024-01-12 17:42:06       44 阅读
  3. ECMAScript 6之Map

    2024-01-12 17:42:06       27 阅读
  4. 移动端测试体系建设

    2024-01-12 17:42:06       41 阅读
  5. 面试官:实际工作中哪里用到了自定义注解?

    2024-01-12 17:42:06       39 阅读
  6. golang --gin+websocket实现指定的数据点推送

    2024-01-12 17:42:06       35 阅读
  7. yolov8模型转换

    2024-01-12 17:42:06       29 阅读
  8. GNSS数据及产品下载地址(FTP/HTTP)

    2024-01-12 17:42:06       30 阅读