Averages/Mean time of day: Difference between revisions

Added Algol 68
m (syntax highlighting fixup automation)
(Added Algol 68)
 
(6 intermediate revisions by 6 users not shown)
Line 1:
{{task|Date and time}}
 
;Task
{{task heading}}
 
A particular activity of bats occurs at these times of the day:
Line 21:
=={{header|11l}}==
{{trans|Python}}
<syntaxhighlight lang="11l">F mean_angle(angles)
V x = sum(angles.map(a -> cos(radians(a)))) / angles.len
V y = sum(angles.map(a -> sin(radians(a)))) / angles.len
Line 49:
{{libheader|Action! Tool Kit}}
{{libheader|Action! Real Math}}
<syntaxhighlight lang=Action"action!">INCLUDE "H6:REALMATH.ACT"
 
DEFINE PTR="CARD"
Line 146:
 
=={{header|Ada}}==
<syntaxhighlight lang=Ada"ada">with Ada.Calendar.Formatting;
with Ada.Command_Line;
with Ada.Numerics.Elementary_Functions;
Line 228:
<pre>
% ./mean_time_of_day 23:00:17 23:40:20 00:12:45 00:17:19
23:47:43
</pre>
 
=={{header|ALGOL 68}}==
Uses code from the Averages/Mean angle task, included here for convenience.
<syntaxhighlight lang="algol68">
BEGIN # Mean time of day mapping time to angles #
 
# code from the Averages/Mean angle task - angles are in degrees #
PROC mean angle = ([]REAL angles)REAL:
(
INT size = UPB angles - LWB angles + 1;
REAL y part := 0, x part := 0;
FOR i FROM LWB angles TO UPB angles DO
x part +:= cos (angles[i] * pi / 180);
y part +:= sin (angles[i] * pi / 180)
OD;
arc tan2 (y part / size, x part / size) * 180 / pi
);
# end code from the Averages/Mean angle task #
 
MODE TIME = STRUCT( INT hh, mm, ss );
 
OP TOANGLE = ( TIME t )REAL: ( ( ( ( ( ss OF t / 60 ) + mm OF t ) / 60 ) + hh OF t ) * 360 ) / 24;
OP TOTIME = ( REAL a )TIME:
BEGIN
REAL t := ( a * 24 ) / 360;
WHILE t < 0 DO t +:= 24 OD;
WHILE t > 24 DO t -:= 24 OD;
INT hh = ENTIER t;
t -:= hh *:= 60;
INT mm = ENTIER t;
INT ss = ENTIER ( ( t - mm ) * 60 );
( hh, mm, ss )
END # TOTIME # ;
 
PROC mean time = ( []TIME times )TIME:
BEGIN
[ LWB times : UPB times ]REAL angles;
FOR i FROM LWB times TO UPB times DO angles[ i ] := TOANGLE times[ i ] OD;
TOTIME mean angle( angles )
END # mean time # ;
 
OP SHOW = ( TIME t )VOID:
BEGIN
PROC d2 = ( INT n )STRING: IF n < 10 THEN "0" ELSE "" FI + whole( n, 0 );
print( ( d2( hh OF t ), ":", d2( mm OF t ), ":", d2( ss OF t ) ) )
END # show time # ;
 
SHOW mean time( ( ( 23,00,17 ), ( 23,40,20 ), ( 00,12,45 ), ( 00,17,19 ) ) )
END
</syntaxhighlight>
{{out}}
<pre>
23:47:43
</pre>
Line 233 ⟶ 288:
=={{header|AutoHotkey}}==
{{works with|AutoHotkey 1.1}}
<syntaxhighlight lang=AutoHotkey"autohotkey">MsgBox, % "The mean time is: " MeanTime(["23:00:17", "23:40:20", "00:12:45", "00:17:19"])
 
MeanTime(t, x=0, y=0) {
Line 258 ⟶ 313:
 
=={{header|AWK}}==
<syntaxhighlight lang=AWK"awk">#!/usr/bin/awk -f
{
c = atan2(0,-1)/(12*60*60);
Line 277 ⟶ 332:
=={{header|BBC BASIC}}==
{{works with|BBC BASIC for Windows}}
<syntaxhighlight lang="bbcbasic"> nTimes% = 4
DATA 23:00:17, 23:40:20, 00:12:45, 00:17:19
Line 322 ⟶ 377:
 
=={{header|C}}==
<syntaxhighlight lang=C"c">#include<stdlib.h>
#include<math.h>
#include<stdio.h>
Line 403 ⟶ 458:
 
=={{header|C sharp|C#}}==
<syntaxhighlight lang="csharp">using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using static System.Math;
 
namespace RosettaCode;
 
class Program
{
private const int SecondsPerDay = 60 * 60 * 24;
class Program
 
static void Main()
{
var digitimes = new List<TimeSpan>();
static void Main(string[] args)
{
Func<TimeSpan, double> TimeToDegrees = (time) =>
360 * time.Hours / 24.0 +
360 * time.Minutes / (24 * 60.0) +
360 * time.Seconds / (24 * 3600.0);
Func<List<double>, double> MeanAngle = (angles) =>
{
double y_part = 0.0d, x_part = 0.0d;
int numItems = angles.Count;
 
for Console.WriteLine(int"Enter itimes, =end 0;with ino <input: numItems"); i++)
while (true) {
string input x_part += MathConsole.CosReadLine(angles[i] * Math.PI / 180);
if (string.IsNullOrWhiteSpace(input)) break;
y_part += Math.Sin(angles[i] * Math.PI / 180);
if (TimeSpan.TryParse(input, out var digitime)) }{
digitimes.Add(digitime);
} else {
Console.WriteLine("Seems this is wrong input: ignoring time");
}
}
if(digitimes.Count() > 0)
Console.WriteLine($"The mean time is : {MeanTime(digitimes)}");
}
 
public static TimeSpan MeanTime(IEnumerable<TimeSpan> ts) => FromDegrees(MeanAngle(ts.Select(ToDegrees)));
return Math.Atan2(y_part / numItems, x_part / numItems) * 180 / Math.PI;
public static double ToDegrees(TimeSpan ts) => ts.TotalSeconds * 360d / SecondsPerDay;
};
public static TimeSpan FromDegrees(double degrees) => TimeSpan.FromSeconds((int)(degrees * SecondsPerDay / 360));
Func<double, TimeSpan> TimeFromDegrees = (angle) =>
new TimeSpan(
(int)(24 * 60 * 60 * angle / 360) / 3600,
((int)(24 * 60 * 60 * angle / 360) % 3600 - (int)(24 * 60 * 60 * angle / 360) % 60) / 60,
(int)(24 * 60 * 60 * angle / 360) % 60);
List<double> digitimes = new List<double>();
TimeSpan digitime;
string input;
 
public static double MeanAngle(IEnumerable<double> angles)
Console.WriteLine("Enter times, end with no input: ");
do{
var x = angles.Average(a {=> Cos(a * PI / 180));
var y = angles.Average(a => Sin(a * PI input/ = Console.ReadLine(180));
return (Atan2(y, x) * 180 / PI + if360) (!(string.IsNullOrWhiteSpace(input)))% 360;
{
if (TimeSpan.TryParse(input, out digitime))
digitimes.Add(TimeToDegrees(digitime));
else
Console.WriteLine("Seems this is wrong input: ignoring time");
}
} while (!string.IsNullOrWhiteSpace(input));
 
if(digitimes.Count() > 0)
Console.WriteLine("The mean time is : {0}", TimeFromDegrees(360 + MeanAngle(digitimes)));
}
}
}
Line 471 ⟶ 512:
 
=={{header|C++}}==
<syntaxhighlight lang="cpp">#include <iomanip>
#include <iostream>
#include <vector>
Line 542 ⟶ 583:
=={{header|Common Lisp}}==
{{trans|Echo Lisp}}
<syntaxhighlight lang="lisp">;; * Loading the split-sequence library
(eval-when (:compile-toplevel :load-toplevel :execute)
(ql:quickload '("split-sequence")))
Line 590 ⟶ 631:
=={{header|D}}==
{{trans|Python}}
<syntaxhighlight lang="d">import std.stdio, std.range, std.algorithm, std.complex, std.math,
std.format, std.conv;
 
Line 635 ⟶ 676:
{{libheader| System.Math}}
{{Trans|Go}}
<syntaxhighlight lang=Delphi"delphi">
program Averages_Mean_time_of_day;
 
Line 692 ⟶ 733:
readln;
end.</syntaxhighlight>
=={{header|EasyLang}}==
{{trans|C}}
<syntaxhighlight lang=easylang>
func tm2deg t$ .
t[] = number strsplit t$ ":"
return 360 * t[1] / 24.0 + 360 * t[2] / (24 * 60.0) + 360 * t[3] / (24 * 3600.0)
.
func$ deg2tm deg .
len t[] 3
h = floor (24 * 60 * 60 * deg / 360)
t[3] = h mod 60
h = h div 60
t[2] = h mod 60
t[1] = h div 60
for h in t[]
if h < 10
s$ &= 0
.
s$ &= h
s$ &= ":"
.
return substr s$ 1 8
.
func mean ang[] .
for ang in ang[]
x += cos ang
y += sin ang
.
return atan2 (y / len ang[]) (x / len ang[])
.
in$ = "23:00:17 23:40:20 00:12:45 00:17:19"
for s$ in strsplit in$ " "
ar[] &= tm2deg s$
.
print deg2tm (360 + mean ar[])
</syntaxhighlight>
 
=={{header|EchoLisp}}==
<syntaxhighlight lang="scheme">
;; string hh:mm:ss to radians
(define (time->radian time)
Line 716 ⟶ 794:
→ "23:47:43"
</syntaxhighlight>
 
 
=={{header|Erlang}}==
<syntaxhighlight lang=Erlang"erlang">
-module( mean_time_of_day ).
-export( [from_times/1, task/0] ).
Line 759 ⟶ 836:
=={{header|Euphoria}}==
{{works with|OpenEuphoria}}
<syntaxhighlight lang=Euphoria"euphoria">
include std/console.e
include std/math.e
Line 836 ⟶ 913:
 
=={{header|F_Sharp|F#}}==
<syntaxhighlight lang="fsharp">open System
open System.Numerics
 
Line 862 ⟶ 939:
 
=={{header|Factor}}==
<syntaxhighlight lang="factor">USING: arrays formatting kernel math math.combinators
math.functions math.libm math.parser math.trig qw sequences
splitting ;
Line 895 ⟶ 972:
=={{header|Fortran}}==
{{works with|gfortran 5.1.0}}
<syntaxhighlight lang="fortran">
program mean_time_of_day
implicit none
Line 973 ⟶ 1,050:
 
=={{header|FreeBASIC}}==
<syntaxhighlight lang="freebasic">' FB 1.05.0 Win64
 
Const pi As Double = 3.1415926535897932
Line 1,034 ⟶ 1,111:
 
=={{header|Go}}==
<syntaxhighlight lang="go">package main
 
import (
Line 1,091 ⟶ 1,168:
=={{header|Groovy}}==
Solution:
<syntaxhighlight lang="groovy">import static java.lang.Math.*
 
final format = 'HH:mm:ss', clock = PI / 12, millisPerHr = 3600*1000
Line 1,104 ⟶ 1,181:
 
Test:
<syntaxhighlight lang="groovy">println (meanTime("23:00:17", "23:40:20", "00:12:45", "00:17:19"))</syntaxhighlight>
 
{{out}}
Line 1,110 ⟶ 1,187:
 
=={{header|Haskell}}==
<syntaxhighlight lang="haskell">import Data.Complex (cis, phase)
import Data.List.Split (splitOn)
import Text.Printf (printf)
Line 1,143 ⟶ 1,220:
=={{header|Icon}} and {{header|Unicon}}==
 
<syntaxhighlight lang="text">procedure main(A)
every put(B := [], ct2a(!A))
write(ca2t(meanAngle(B)))
Line 1,178 ⟶ 1,255:
=={{header|J}}==
use <code>avgAngleR</code> from [[Averages/Mean angle#J]]
<syntaxhighlight lang=J"j">require 'types/datetime'
parseTimes=: ([: _&".;._2 ,&':');._2
secsFromTime=: 24 60 60 #. ] NB. convert from time to seconds
Line 1,184 ⟶ 1,261:
meanTime=: 'hh:mm:ss' fmtTime [: secsFromTime [: avgAngleR&.rft parseTimes</syntaxhighlight>
{{out|Example Use}}
<syntaxhighlight lang=J"j"> meanTime '23:00:17 23:40:20 00:12:45 00:17:19 '
23:47:43</syntaxhighlight>
 
=={{header|Java}}==
{{trans|Kotlin}}
<syntaxhighlight lang="java">public class MeanTimeOfDay {
static double meanAngle(double[] angles) {
Line 1,245 ⟶ 1,322:
=={{header|Javascript}}==
{{works with|Node.js}}
<syntaxhighlight lang=Javascript"javascript">var args = process.argv.slice(2);
 
function time_to_seconds( hms ) {
Line 1,295 ⟶ 1,372:
 
The "mean time" of two times that differ by 12 hours (e.g. ["00:00:00", "12:00:00"]) is not very well-defined, and is accordingly computed as null here.
<syntaxhighlight lang="jq"># input: array of "h:m:s"
def mean_time_of_day:
def pi: 4 * (1|atan);
Line 1,327 ⟶ 1,404:
end ;</syntaxhighlight>
'''Examples'''
<syntaxhighlight lang="jq">["0:0:0", "12:0:0" ],
["0:0:0", "24:0:0" ],
["1:0:0", "1:0:0" ],
Line 1,336 ⟶ 1,413:
| mean_time_of_day</syntaxhighlight>
{{out}}
<syntaxhighlight lang="sh">$ jq -r -n -f Mean_time_of_day.jq
null
00:00:00
Line 1,348 ⟶ 1,425:
{{works with|Julia|0.6}}
{{trans|MATLAB}}
<syntaxhighlight lang="julia">using Statistics
 
function meantime(times::Array, dlm::String=":")
Line 1,379 ⟶ 1,456:
=={{header|Kotlin}}==
{{trans|FreeBASIC}}
<syntaxhighlight lang="scala">// version 1.0.6
 
fun meanAngle(angles: DoubleArray): Double {
Line 1,422 ⟶ 1,499:
 
=={{header|Liberty BASIC}}==
<syntaxhighlight lang="lb">
global pi
pi = acs(-1)
Line 1,481 ⟶ 1,558:
 
=={{header|Lua}}==
<syntaxhighlight lang="lua">
local times = {"23:00:17","23:40:20","00:12:45","00:17:19"}
 
Line 1,524 ⟶ 1,601:
 
=={{header|Mathematica}} / {{header|Wolfram Language}}==
<syntaxhighlight lang="mathematica">meanTime[list_] :=
StringJoin@
Riffle[ToString /@
Line 1,536 ⟶ 1,613:
 
=={{header|MATLAB}} / {{header|Octave}}==
<syntaxhighlight lang=MATLAB"matlab">function t = mean_time_of_day(t)
c = pi/(12*60*60);
for k=1:length(t)
Line 1,552 ⟶ 1,629:
=={{header|Nim}}==
{{works with|Nim|0.20.0+}}
<syntaxhighlight lang="nim">import math, complex, strutils, sequtils
proc meanAngle(deg: openArray[float]): float =
Line 1,577 ⟶ 1,654:
=={{header|Oberon-2}}==
{{works with|oo2c}}
<syntaxhighlight lang="oberon2">
MODULE AvgTimeOfDay;
IMPORT
Line 1,655 ⟶ 1,732:
 
=={{header|OCaml}}==
<syntaxhighlight lang="ocaml">let pi_twice = 2.0 *. 3.14159_26535_89793_23846_2643
let day = float (24 * 60 * 60)
 
Line 1,696 ⟶ 1,773:
 
=={{header|ooRexx}}==
<syntaxhighlight lang="oorexx">/* REXX ---------------------------------------------------------------
* 25.06.2014 Walter Pachl
*--------------------------------------------------------------------*/
Line 1,736 ⟶ 1,813:
 
=={{header|PARI/GP}}==
<syntaxhighlight lang="parigp">meanAngle(v)=atan(sum(i=1,#v,sin(v[i]))/sum(i=1,#v,cos(v[i])))%(2*Pi)
meanTime(v)=my(x=meanAngle(2*Pi*apply(u->u[1]/24+u[2]/1440+u[3]/86400, v))*12/Pi); [x\1, 60*(x-=x\1)\1, round(60*(60*x-60*x\1))]
meanTime([[23,0,17], [23,40,20], [0,12,45], [0,17,19]])</syntaxhighlight>
Line 1,746 ⟶ 1,823:
Using the core module <code>Math::Complex</code> to enable use of complex numbers. The <code>POSIX</code> CPAN module provides the <code>fmod</code> routine for non-integer modulus calculations.
{{trans|Raku}}
<syntaxhighlight lang=Perl"perl">use strict;
use warnings;
use POSIX 'fmod';
Line 1,784 ⟶ 1,861:
===v5.36===
As previous, but using features from an up-to-date release of Perl, e.g. strict/warn/subroutine signatures without the <code>use</code> boilerplate.
<syntaxhighlight lang="perl">use v5.36;
use POSIX 'fmod';
use Math::Complex;
Line 1,805 ⟶ 1,882:
 
=={{header|Phix}}==
<!--<syntaxhighlight lang=Phix"phix">(phixonline)-->
<span style="color: #008080;">with</span> <span style="color: #008080;">javascript_semantics</span>
<span style="color: #008080;">function</span> <span style="color: #000000;">MeanAngle</span><span style="color: #0000FF;">(</span><span style="color: #004080;">sequence</span> <span style="color: #000000;">angles</span><span style="color: #0000FF;">)</span>
Line 1,847 ⟶ 1,924:
 
=={{header|PHP}}==
<syntaxhighlight lang=PHP"php">
<?php
function time2ang($tim) {
Line 1,893 ⟶ 1,970:
 
=={{header|PicoLisp}}==
<syntaxhighlight lang=PicoLisp"picolisp">(load "@lib/math.l")
 
(de meanTime (Lst)
Line 1,904 ⟶ 1,981:
(tim$ (% (+ Tim 86400) 86400) T) ) )</syntaxhighlight>
{{out|Test}}
<syntaxhighlight lang=PicoLisp"picolisp">: (meanTime '("23:00:17" "23:40:20" "00:12:45" "00:17:19"))
-> "23:47:43"</syntaxhighlight>
 
=={{header|PL/I}}==
<syntaxhighlight lang="pli">*process source attributes xref;
avt: Proc options(main);
/*--------------------------------------------------------------------
Line 1,958 ⟶ 2,035:
 
=={{header|PowerShell}}==
<syntaxhighlight lang=PowerShell"powershell">
function Get-MeanTimeOfDay
{
Line 2,026 ⟶ 2,103:
}
</syntaxhighlight>
<syntaxhighlight lang=PowerShell"powershell">
[timespan]$meanTimeOfDay = "23:00:17","23:40:20","00:12:45","00:17:19" | Get-MeanTimeOfDay
"Mean time is {0}" -f (Get-Date $meanTimeOfDay.ToString()).ToString("hh:mm:ss tt")
Line 2,036 ⟶ 2,113:
 
=={{header|Python}}==
<syntaxhighlight lang="python">from cmath import rect, phase
from math import radians, degrees
 
Line 2,064 ⟶ 2,141:
 
=={{header|Racket}}==
<syntaxhighlight lang="racket">
#lang racket
(define (mean-angle/radians as)
Line 2,093 ⟶ 2,170:
{{works with|Rakudo|2015.12}}
 
<syntaxhighlight lang=perl6"raku" line>sub tod2rad($_) { [+](.comb(/\d+/) Z* 3600,60,1) * tau / 86400 }
sub rad2tod ($r) {
Line 2,114 ⟶ 2,191:
 
=={{header|REXX}}==
<syntaxhighlight lang="rexx">/* REXX ---------------------------------------------------------------
* 25.06.2014 Walter Pachl
* taken from ooRexx using my very aged sin/cos/artan functions
Line 2,216 ⟶ 2,293:
{{out}}
<pre>23:47:43</pre>
 
=={{header|RPL}}==
{{works with|Halcyon Calc|4.2.7}}
≪ → angles
≪ 0 1 angles SIZE '''FOR''' j
1 angles j GET R→C P→R + '''NEXT'''
angles SIZE / ARG
≫ ≫ ''''MEANG'''' STO
 
≪ → times
≪ { } 1 times SIZE '''FOR''' j
1 times j GET HMS→ 15 * + '''NEXT'''
'''MEANG''' 15 / 24 MOD →HMS 4 FIX RND STD
≫ ≫ ''''MTIME'''' STO
 
{23.0017 23.4020 0.1245 0.1719 } '''MTIME'''
{{out}}
<pre>
1: 23.4743
</pre>
 
=={{header|Ruby}}==
Using the methods at [[http://rosettacode.org/wiki/Averages/Mean_angle#Ruby|Averages/Mean angle]]
 
<syntaxhighlight lang="ruby">def time2deg(t)
raise "invalid time" unless m = t.match(/^(\d\d):(\d\d):(\d\d)$/)
hh,mm,ss = m[1..3].map {|e| e.to_i}
Line 2,243 ⟶ 2,340:
 
=={{header|Run BASIC}}==
<syntaxhighlight lang="runbasic">global pi
pi = acs(-1)
Line 2,288 ⟶ 2,385:
End Function</syntaxhighlight>
=={{header|Rust}}==
<syntaxhighlight lang="rust">
use std::f64::consts::PI;
 
Line 2,358 ⟶ 2,455:
 
=={{header|Scala}}==
{{libheader|java.time.LocalTime}}<syntaxhighlight lang=Scala"scala">import java.time.LocalTime
import scala.compat.Platform
 
Line 2,394 ⟶ 2,491:
To be self-contained, this starts with the functions from [[Averages/Mean angle]]
 
<syntaxhighlight lang="scheme">
(import (scheme base)
(scheme inexact)
Line 2,457 ⟶ 2,554:
{{trans|Ruby}}
Using the '''mean_angle()''' function from: [http://rosettacode.org/wiki/Averages/Mean_angle#Sidef "Averages/Mean angle"]
<syntaxhighlight lang="ruby">func time2deg(t) {
(var m = t.match(/^(\d\d):(\d\d):(\d\d)$/)) || die "invalid time"
var (hh,mm,ss) = m.cap.map{.to_i}...
Line 2,479 ⟶ 2,576:
=={{header|SQL}}/{{header|PostgreSQL}}==
{{trans|Python}}
<syntaxhighlight lang=SQL"sql">
--Setup table for testing
CREATE TABLE time_table(times time);
Line 2,501 ⟶ 2,598:
=={{header|Swift}}==
 
<syntaxhighlight lang="swift">import Foundation
 
@inlinable public func d2r<T: FloatingPoint>(_ f: T) -> T { f * .pi / 180 }
Line 2,564 ⟶ 2,661:
 
=={{header|Tcl}}==
<syntaxhighlight lang="tcl">proc meanTime {times} {
set secsPerRad [expr {60 * 60 * 12 / atan2(0,-1)}]
set sumSin [set sumCos 0.0]
Line 2,587 ⟶ 2,684:
=={{header|VBA}}==
Uses Excel and [[Averages/Mean_angle#VBA|mean angle]].
<syntaxhighlight lang="vb">Public Sub mean_time()
Dim angles() As Double
s = [{"23:00:17","23:40:20","00:12:45","00:17:19"}]
Line 2,599 ⟶ 2,696:
=={{header|Visual Basic .NET}}==
{{trans|C#}}
<syntaxhighlight lang="vbnet">Module Module1
 
Function TimeToDegrees(time As TimeSpan) As Double
Line 2,654 ⟶ 2,751:
The mean time is : 23:47:43</pre>
 
=={{header|V (Vlang)}}==
{{trans|Wren}}
<syntaxhighlight lang="v (vlang)">import math
 
const inputs = ["23:00:17", "23:40:20", "00:12:45", "00:17:19"]
Line 2,703 ⟶ 2,800:
=={{header|Wren}}==
{{libheader|Wren-fmt}}
<syntaxhighlight lang=ecmascript"wren">import "./fmt" for Fmt
 
var timeToDegs = Fn.new { |time|
Line 2,720 ⟶ 2,817:
s = m % 60
m = (m / 60).floor
return "%(Fmt.dswrite(2"$2d:$2d:$2d", h)):%(Fmt.d(2, m)):%(Fmt.d(2, s))"
}
 
Line 2,744 ⟶ 2,841:
 
=={{header|XPL0}}==
<syntaxhighlight lang=XPL0"xpl0">include c:\cxpl\codes;
 
proc NumOut(N); \Display 2-digit N with leading zero
Line 2,788 ⟶ 2,885:
=={{header|Yabasic}}==
{{trans|Phix}}
<syntaxhighlight lang=Yabasic"yabasic">sub atan2(y, x)
return 2 * atan((sqrt(x **2 + y ** 2) - x) / y)
end sub
Line 2,839 ⟶ 2,936:
to task "Averages/Mean angle" and some on-the-fly
time-to-angle and back conversions.
<syntaxhighlight lang="zkl">var D=Time.Date;
fcn meanT(t1,t2,etc){
ts:=vm.arglist.apply(fcn(hms){
3,043

edits