当前位置: 首页 > news >正文

Dart调用JS对10000条定位数据滤波

使用Dart调用JS,还是为了练习跨语言调用;

一、编写对应的JS代码

平时在开发时不推荐将算法放在JS里,我这里是简单的做一下数据过滤;
首先生成一些随机定位数据,在实际开发中可以使用真实数据;

// 随机定位点
function getRandomCoordinate() {return {latitude: getRandomFloat(110, 115),longitude: getRandomFloat(110, 115)};
}// 随机数
function getRandomFloat(min, max) {return min+Math.random()*(max-min);
}

将数据添加到对应容器中;

// 滤波
function filterData() {console.log("开始滤波-----");var data = [];// 添加10000条随机定位点for (let index = 0; index < 10000; index++) {let coordinate = getRandomCoordinate();data.push(coordinate);}console.log(data);averageFilter(data);
}

滤波时需要计算弧面距离;

// 计算定位之间的距离
function distance(lat1, lon1, lat2, lon2) {const R = 6371; // 地球半径,我使用的是平均值,单位公里const dLat = deg2rad(lat2-lat1); // 角度转弧度const dLon = deg2rad(lon2-lon1); // 同上const dL1 = deg2rad(lat1);const dL2 = deg2rad(lat2);// 开始求弧面距离了const a = Math.sin(dLat/2)*Math.sin(dLon/2)+Math.cos(dL1)*Math.cos(dL2)*Math.sin(dLon/2)*Math.sin(dLon/2);if (a < 0) {return 0;}const c = 2*Math.atan2(Math.sqrt(a), Math.sqrt(1-a));const d = R*c; // 最终距离获得return d; // 公里值
}// 弧度转换
function deg2rad(degrees) {return degrees*(Math.PI/180);
}

开始滤波;

// 平均值滤波
function averageFilter(data) {var totalDistance = 0; // 总距离for (let index = 0; index < data.length-1; index++) {const l1 = data[index];const l2 = data[index+1];totalDistance += distance(l1.latitude, l1.longitude, l2.latitude, l2.longitude);}const averageDistance = totalDistance/(data.length-1);// 开始过滤var filters = [];const value = averageDistance*1.5; // 使用1.5倍平均值作为阀值,可调整for (let index = 0; index < data.length-1; index++) {const l1 = data[index];const l2 = data[index+1];const d = distance(l1.latitude, l1.longitude, l2.latitude, l2.longitude);if (d <= value) {filters.push(l2);}}console.log("平均值滤波结果");console.log(filters);console.log("------------");
}
Dart中调用JS代码;
import 'dart:js' as js;void main() {js.context.callMethod("filterData", []);exit(0); // 退出
}

运行结果过滤了一部分距离过远跳跃的定位数据;
滤波
JS也可以调用Dart方法,可以将对应的Dart方法当作参数传给JS,然后JS使用闭包接收,然后可以在需要时调用闭包。

http://www.lryc.cn/news/273973.html

相关文章:

  • 大模型应用实践:AIGC探索之旅
  • 【.NET Core】异步编程模式
  • macOS通过外置驱动器备份数据
  • rtsp解析视频流
  • 【物联网】手把手完整实现STM32+ESP8266+MQTT+阿里云+APP应用——第3节-云产品流转配置
  • Spring Cloud Config相关问题及答案(2024)
  • 【Azure 架构师学习笔记】- Azure Databricks (4) - 使用Azure Key Vault 管理ADB Secret
  • [每周一更]-(第50期):Go的垃圾回收GC
  • 【嵌入式学习笔记-01】什么是UC,操作系统历史介绍,计算机系统分层,环境变量(PATH),错误
  • 【动态规划】LeetCode-10. 正则表达式匹配
  • lenovo联想拯救者8.8英寸掌上游戏机Legion Go 8APU1(83E1)原装出厂Windows11预装系统
  • 经典目标检测YOLO系列(一)复现YOLOV1(4)VOC2007数据集的读取及预处理
  • Android Studio xml布局代码补全功能失效问题
  • 算法每日一题:队列中可以看到的人数 | 单调栈
  • 报表控件Stimulsoft 2023回顾:都做了哪些产品的改变?
  • Mybatis缓存实现方式
  • C#用StringBuilder高效处理字符串
  • python开发案例教程-清华大学出版社(张基温)答案(4.2)
  • 【MATLAB】【数字信号处理】线性卷积和抽样定理
  • 什么是 MVVM ?
  • Redis(一)
  • 自动驾驶预测-决策-规划-控制学习(1):自动驾驶框架、硬件、软件概述
  • SSM建材商城网站----计算机毕业设计
  • js逆向第9例:猿人学第2题-js混淆-动态cookie1
  • [论文分享]TimesURL:通用时间序列表示学习的自监督对比学习
  • 解决sublime中文符号乱码问题
  • 厚积薄发11年,鸿蒙究竟有多可怕
  • pyDAL一个python的ORM(4) pyDAL查询操作
  • 如何通过Python将各种数据写入到Excel工作表
  • 跟着cherno手搓游戏引擎【2】:日志系统spdlog和premake的使用