diff --git a/src/App.vue b/src/App.vue
index e4e35a8..523c89d 100644
--- a/src/App.vue
+++ b/src/App.vue
@@ -14,7 +14,7 @@
font-family: Avenir, Helvetica, Arial, sans-serif;
-webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale;
- text-align: center;
+ /* text-align: center; */
color: #2c3e50;
}
diff --git a/src/plugin/xml-digital-teaching/lib/catalog.js b/src/plugin/xml-digital-teaching/lib/catalog.js
index 6cb3bc3..6a751d1 100644
--- a/src/plugin/xml-digital-teaching/lib/catalog.js
+++ b/src/plugin/xml-digital-teaching/lib/catalog.js
@@ -1,6 +1,6 @@
/*
* XmlDigitalTeaching v0.0.1
-* Copyright ©Wed Jun 19 2024 19:48:48 GMT+0800 (中国标准时间) smile
+* Copyright ©Fri Jun 21 2024 13:16:29 GMT+0800 (中国标准时间) smile
* Released under the ISC License.
*/
//
diff --git a/src/plugin/xml-digital-teaching/lib/ebook.js b/src/plugin/xml-digital-teaching/lib/ebook.js
index cc1fc94..05c430a 100644
--- a/src/plugin/xml-digital-teaching/lib/ebook.js
+++ b/src/plugin/xml-digital-teaching/lib/ebook.js
@@ -1,6 +1,6 @@
/*
* XmlDigitalTeaching v0.0.1
-* Copyright ©Wed Jun 19 2024 19:48:48 GMT+0800 (中国标准时间) smile
+* Copyright ©Fri Jun 21 2024 13:16:29 GMT+0800 (中国标准时间) smile
* Released under the ISC License.
*/
//
diff --git a/src/plugin/xml-digital-teaching/lib/group.js b/src/plugin/xml-digital-teaching/lib/group.js
index bdb747c..0251996 100644
--- a/src/plugin/xml-digital-teaching/lib/group.js
+++ b/src/plugin/xml-digital-teaching/lib/group.js
@@ -1,6 +1,6 @@
/*
* XmlDigitalTeaching v0.0.1
-* Copyright ©Wed Jun 19 2024 19:48:48 GMT+0800 (中国标准时间) smile
+* Copyright ©Fri Jun 21 2024 13:16:29 GMT+0800 (中国标准时间) smile
* Released under the ISC License.
*/
//
diff --git a/src/plugin/xml-digital-teaching/lib/html.js b/src/plugin/xml-digital-teaching/lib/html.js
index 8305907..6b9e7bd 100644
--- a/src/plugin/xml-digital-teaching/lib/html.js
+++ b/src/plugin/xml-digital-teaching/lib/html.js
@@ -1,6 +1,6 @@
/*
* XmlDigitalTeaching v0.0.1
-* Copyright ©Wed Jun 19 2024 19:48:48 GMT+0800 (中国标准时间) smile
+* Copyright ©Fri Jun 21 2024 13:16:29 GMT+0800 (中国标准时间) smile
* Released under the ISC License.
*/
//
diff --git a/src/plugin/xml-digital-teaching/lib/image.css b/src/plugin/xml-digital-teaching/lib/image.css
index 198afdc..c7b0ba6 100644
--- a/src/plugin/xml-digital-teaching/lib/image.css
+++ b/src/plugin/xml-digital-teaching/lib/image.css
@@ -4,15 +4,15 @@
}
-.el-image__inner[data-v-755c322e] {
+.el-image__inner[data-v-fb4f6862] {
width: 100% !important;
}
-.xml-image-ping-pu-h5[data-v-755c322e] {
+.xml-image-ping-pu-h5[data-v-fb4f6862] {
display: flex;
flex-direction: column;
align-items: center;
}
-.xml-image-hua-lang[data-v-755c322e] {
+.xml-image-hua-lang[data-v-fb4f6862] {
display: flex;
flex-direction: column;
align-items: center;
diff --git a/src/plugin/xml-digital-teaching/lib/image.js b/src/plugin/xml-digital-teaching/lib/image.js
index 2e400cd..6684fa3 100644
--- a/src/plugin/xml-digital-teaching/lib/image.js
+++ b/src/plugin/xml-digital-teaching/lib/image.js
@@ -1,6 +1,6 @@
/*
* XmlDigitalTeaching v0.0.1
-* Copyright ©Wed Jun 19 2024 19:48:48 GMT+0800 (中国标准时间) smile
+* Copyright ©Fri Jun 21 2024 13:16:29 GMT+0800 (中国标准时间) smile
* Released under the ISC License.
*/
import Vue from 'vue';
@@ -893,13 +893,17 @@ var script$1 = {
return;
}
if (this.clickEffect === 'dian-ji-fang-da') {
+ let imgList = [];
+ this.previewSrcList.map((item, index) => {
+ imgList.push({
+ url: item,
+ title: this.title[index]
+ });
+ });
this.$xmlImgPreview({
multiple: true,
- nowImgIndex: 0,
- imgList: [{
- url: this.previewSrcList[0],
- title: this.self.title
- }]
+ nowImgIndex: this.current,
+ imgList
});
}
if (isByTitle) {
@@ -1000,7 +1004,7 @@ var __vue_render__$2 = function () {
? _c(
"div",
{
- staticClass: "image-title--lay image-title--on",
+ staticClass: "xml-image-title image-title--lay image-title--on",
style: { textAlign: _vm.titleAlign || "left" },
},
[_vm._v("\n " + _vm._s(_vm.self.title) + "\n ")]
@@ -1061,7 +1065,8 @@ var __vue_render__$2 = function () {
? _c(
"div",
{
- staticClass: "image-title--fixed image-title--bottom",
+ staticClass:
+ "xml-image-title image-title--fixed image-title--bottom",
style: { textAlign: _vm.titleAlign || "left" },
on: {
click: function ($event) {
@@ -1077,7 +1082,8 @@ var __vue_render__$2 = function () {
? _c(
"div",
{
- staticClass: "image-title--fixed image-title--top",
+ staticClass:
+ "xml-image-title image-title--fixed image-title--top",
style: { textAlign: _vm.titleAlign || "left" },
on: {
click: function ($event) {
@@ -1096,7 +1102,8 @@ var __vue_render__$2 = function () {
? _c(
"div",
{
- staticClass: "image-title--lay image-title--under",
+ staticClass:
+ "xml-image-title image-title--lay image-title--under",
style: { textAlign: _vm.titleAlign || "left" },
},
[_vm._v("\n " + _vm._s(_vm.self.title) + "\n ")]
@@ -1112,7 +1119,7 @@ __vue_render__$2._withStripped = true;
/* style */
const __vue_inject_styles__$1 = undefined;
/* scoped */
- const __vue_scope_id__$1 = "data-v-755c322e";
+ const __vue_scope_id__$1 = "data-v-fb4f6862";
/* module identifier */
const __vue_module_identifier__$1 = undefined;
/* functional template */
diff --git a/src/plugin/xml-digital-teaching/lib/image.min.css b/src/plugin/xml-digital-teaching/lib/image.min.css
index 5499fbb..4771ff0 100644
--- a/src/plugin/xml-digital-teaching/lib/image.min.css
+++ b/src/plugin/xml-digital-teaching/lib/image.min.css
@@ -1 +1 @@
-.xml-image-lun-bo .el-carousel__item{text-align:center}.el-image__inner[data-v-755c322e]{width:100%!important}.xml-image-ping-pu-h5[data-v-755c322e]{display:flex;flex-direction:column;align-items:center}.xml-image-hua-lang[data-v-755c322e]{display:flex;flex-direction:column;align-items:center}
\ No newline at end of file
+.xml-image-lun-bo .el-carousel__item{text-align:center}.el-image__inner[data-v-fb4f6862]{width:100%!important}.xml-image-ping-pu-h5[data-v-fb4f6862]{display:flex;flex-direction:column;align-items:center}.xml-image-hua-lang[data-v-fb4f6862]{display:flex;flex-direction:column;align-items:center}
\ No newline at end of file
diff --git a/src/plugin/xml-digital-teaching/lib/imageText.css b/src/plugin/xml-digital-teaching/lib/imageText.css
index bc84a37..344a610 100644
--- a/src/plugin/xml-digital-teaching/lib/imageText.css
+++ b/src/plugin/xml-digital-teaching/lib/imageText.css
@@ -3,33 +3,25 @@
/*# sourceMappingURL=fifth.vue.map */
-/*# sourceMappingURL=third.vue.map */
+/*# sourceMappingURL=sixth.vue.map */
/*# sourceMappingURL=fourth.vue.map */
-/*# sourceMappingURL=seventh.vue.map */
+/*# sourceMappingURL=first.vue.map */
-/*# sourceMappingURL=sixth.vue.map */
+/*# sourceMappingURL=third.vue.map */
/*# sourceMappingURL=eighth.vue.map */
-/*# sourceMappingURL=first.vue.map */
+/*# sourceMappingURL=seventh.vue.map */
/*# sourceMappingURL=second.vue.map */
-
-.xml-text-h5[data-v-5d93942a] {
-}
-.xml-text-pc[data-v-5d93942a] {
-}
-.xml-text-h5[data-v-5d93942a] {
-}
-
.xml-text-h5 .inline-audio-wrap,
.xml-text-h5 .inline-link-wrap {
align-items: center;
@@ -101,6 +93,14 @@
/*# sourceMappingURL=XmlText.vue.map */
+.xml-text-h5[data-v-5d93942a] {
+}
+.xml-text-pc[data-v-5d93942a] {
+}
+.xml-text-h5[data-v-5d93942a] {
+}
+
+
.xml-image-lun-bo .el-carousel__item {
text-align: center;
}
@@ -692,15 +692,15 @@
-.el-image__inner[data-v-755c322e] {
+.el-image__inner[data-v-fb4f6862] {
width: 100% !important;
}
-.xml-image-ping-pu-h5[data-v-755c322e] {
+.xml-image-ping-pu-h5[data-v-fb4f6862] {
display: flex;
flex-direction: column;
align-items: center;
}
-.xml-image-hua-lang[data-v-755c322e] {
+.xml-image-hua-lang[data-v-fb4f6862] {
display: flex;
flex-direction: column;
align-items: center;
diff --git a/src/plugin/xml-digital-teaching/lib/imageText.js b/src/plugin/xml-digital-teaching/lib/imageText.js
index 5d59927..76c8b4e 100644
--- a/src/plugin/xml-digital-teaching/lib/imageText.js
+++ b/src/plugin/xml-digital-teaching/lib/imageText.js
@@ -1,6 +1,6 @@
/*
* XmlDigitalTeaching v0.0.1
-* Copyright ©Wed Jun 19 2024 19:48:48 GMT+0800 (中国标准时间) smile
+* Copyright ©Fri Jun 21 2024 13:16:29 GMT+0800 (中国标准时间) smile
* Released under the ISC License.
*/
import Vue from 'vue';
@@ -893,13 +893,17 @@ var script$d = {
return;
}
if (this.clickEffect === 'dian-ji-fang-da') {
+ let imgList = [];
+ this.previewSrcList.map((item, index) => {
+ imgList.push({
+ url: item,
+ title: this.title[index]
+ });
+ });
this.$xmlImgPreview({
multiple: true,
- nowImgIndex: 0,
- imgList: [{
- url: this.previewSrcList[0],
- title: this.self.title
- }]
+ nowImgIndex: this.current,
+ imgList
});
}
if (isByTitle) {
@@ -1000,7 +1004,7 @@ var __vue_render__$e = function () {
? _c(
"div",
{
- staticClass: "image-title--lay image-title--on",
+ staticClass: "xml-image-title image-title--lay image-title--on",
style: { textAlign: _vm.titleAlign || "left" },
},
[_vm._v("\n " + _vm._s(_vm.self.title) + "\n ")]
@@ -1061,7 +1065,8 @@ var __vue_render__$e = function () {
? _c(
"div",
{
- staticClass: "image-title--fixed image-title--bottom",
+ staticClass:
+ "xml-image-title image-title--fixed image-title--bottom",
style: { textAlign: _vm.titleAlign || "left" },
on: {
click: function ($event) {
@@ -1077,7 +1082,8 @@ var __vue_render__$e = function () {
? _c(
"div",
{
- staticClass: "image-title--fixed image-title--top",
+ staticClass:
+ "xml-image-title image-title--fixed image-title--top",
style: { textAlign: _vm.titleAlign || "left" },
on: {
click: function ($event) {
@@ -1096,7 +1102,8 @@ var __vue_render__$e = function () {
? _c(
"div",
{
- staticClass: "image-title--lay image-title--under",
+ staticClass:
+ "xml-image-title image-title--lay image-title--under",
style: { textAlign: _vm.titleAlign || "left" },
},
[_vm._v("\n " + _vm._s(_vm.self.title) + "\n ")]
@@ -1112,7 +1119,7 @@ __vue_render__$e._withStripped = true;
/* style */
const __vue_inject_styles__$d = undefined;
/* scoped */
- const __vue_scope_id__$d = "data-v-755c322e";
+ const __vue_scope_id__$d = "data-v-fb4f6862";
/* module identifier */
const __vue_module_identifier__$d = undefined;
/* functional template */
@@ -12010,1441 +12017,1083 @@ var recorder_mp3_min = createCommonjsModule(function (module) {
https://github.com/xiangyuecn/Recorder
src: recorder-core.js,engine/mp3.js,engine/mp3-engine.js
*/
-!function (e) {
- var t = "object" == typeof window && !!window.document,
- a = t ? window : Object;
- !function (e, w) {
+!function (y) {
- var S = function () {},
- f = function (e) {
- return "number" == typeof e;
- },
- N = function (e) {
- return new l(e);
- },
- M = N.LM = "2024-04-09 19:15",
- y = "https://github.com/xiangyuecn/Recorder",
- R = "Recorder",
- A = "getUserMedia",
- V = "srcSampleRate",
- D = "sampleRate",
- i = "bitRate",
- x = "catch",
- t = e[R];
- if (t && t.LM == M) return t.CLog(t.i18n.$T("K8zP::重复导入{1}", 0, R), 3);
- N.IsOpen = function () {
- var e = N.Stream;
- if (e) {
- var t = e.getTracks && e.getTracks() || e.audioTracks || [],
- a = t[0];
- if (a) {
- var n = a.readyState;
- return "live" == n || n == a.LIVE;
- }
- }
- return !1;
- }, N.BufferSize = 4096, N.Destroy = function () {
- for (var e in O(R + " Destroy"), L(), a) a[e]();
+ var v = function () {},
+ V = function (e) {
+ return new t(e);
};
- var a = {};
- N.BindDestroy = function (e, t) {
- a[e] = t;
- }, N.Support = function () {
- if (!w) return !1;
- var e = navigator.mediaDevices || {};
- return e[A] || (e = navigator)[A] || (e[A] = e.webkitGetUserMedia || e.mozGetUserMedia || e.msGetUserMedia), !!e[A] && (N.Scope = e, !!N.GetContext());
- }, N.GetContext = function (e) {
- if (!w) return null;
- var t = window.AudioContext;
- if (t || (t = window.webkitAudioContext), !t) return null;
- var a = N.Ctx;
- if (a && "closed" != a.state || (a = N.Ctx = new t(), N.NewCtxs = N.NewCtxs || [], N.BindDestroy("Ctx", function () {
- var e = N.Ctx;
- e && e.close && (s(e), N.Ctx = 0);
- var t = N.NewCtxs;
- N.NewCtxs = [];
- for (var a = 0; a < t.length; a++) s(t[a]);
- })), e && a.close) try {
- a = new t(), N.NewCtxs.push(a);
- } catch (e) {
- O("GetContext tryNew Error", 1, e);
+ V.LM = "2023-02-01 18:05";
+ var T = "Recorder",
+ d = "getUserMedia",
+ O = "srcSampleRate",
+ N = "sampleRate",
+ x = "catch";
+ V.IsOpen = function () {
+ var e = V.Stream;
+ if (e) {
+ var t = e.getTracks && e.getTracks() || e.audioTracks || [],
+ a = t[0];
+ if (a) {
+ var s = a.readyState;
+ return "live" == s || s == a.LIVE;
}
- return a;
- }, N.CloseNewCtx = function (e) {
- if (e && e != N.Ctx) {
- s(e);
- for (var t = N.NewCtxs || [], a = t.length, n = 0; n < t.length; n++) if (t[n] == e) {
- t.splice(n, 1);
- break;
- }
- O(z("mSxV::剩{1}个GetContext未close", 0, a + "-1=" + t.length), t.length ? 3 : 0);
- }
- };
- var s = function (e) {
- if (e && e.close) {
- e._isC = 1;
- try {
- e.close();
- } catch (e) {
- O("ctx close err", 1, e);
- }
- }
- },
- B = N.ResumeCtx = function (a, n, s, r) {
- var i = 0,
- o = 0,
- _ = 0,
- l = 0,
- f = "EventListener",
- c = "ResumeCtx ",
- u = function (e, t) {
- o && h(), i || (i = 1, e && r(e, l), t && s(l)), t && (!a._LsSC && a["add" + f] && a["add" + f]("statechange", b), a._LsSC = 1, _ = 1);
- },
- h = function (e) {
- if (!e || !o) {
- o = e ? 1 : 0;
- for (var t = ["focus", "mousedown", "mouseup", "touchstart", "touchend"], a = 0; a < t.length; a++) window[(e ? "add" : "remove") + f](t[a], b, !0);
- }
- },
- b = function () {
- var e = a.state,
- t = p(e);
- if (!i && !n(t ? ++l : l)) return u();
- t ? (_ && O(c + "sc " + e, 3), h(1), a.resume().then(function () {
- _ && O(c + "sc " + a.state), u(0, 1);
- })[x](function (e) {
- O(c + "error", 1, e), p(a.state) || u(e.message || "error");
- })) : "closed" == e ? (_ && !a._isC && O(c + "sc " + e, 1), u("ctx closed")) : u(0, 1);
- };
- b();
- },
- p = N.CtxSpEnd = function (e) {
- return "suspended" == e || "interrupted" == e;
- },
- k = function (e) {
- var t = e.state,
- a = "ctx.state=" + t;
- return p(t) && (a += z("nMIy::(注意:ctx不是running状态,rec.open和start至少要有一个在用户操作(触摸、点击等)时进行调用,否则将在rec.start时尝试进行ctx.resume,可能会产生兼容性问题(仅iOS),请参阅文档中runningContext配置)")), a;
- },
- T = "ConnectEnableWebM";
- N[T] = !0;
- var E = "ConnectEnableWorklet";
- N[E] = !1;
- var C = function (e, _) {
- var l = e.BufferSize || N.BufferSize,
- f = e.Stream,
- c = f._RC || f._c || N.GetContext(!0);
- f._c = c;
- var u,
- a,
- h,
- i = function (e) {
- var t = f._m = c.createMediaStreamSource(f),
- a = c.destination,
- n = "createMediaStreamDestination";
- c[n] && (a = f._d = c[n]()), t.connect(e), e.connect(a);
- },
- b = "",
- p = f._call,
- m = function (e) {
- for (var t in p) {
- for (var a = e.length, n = new Int16Array(a), s = 0, r = 0; r < a; r++) {
- var i = Math.max(-1, Math.min(1, e[r]));
- i = i < 0 ? 32768 * i : 32767 * i, n[r] = i, s += Math.abs(i);
- }
- for (var o in p) p[o](n, s);
- return;
- }
- },
- v = "ScriptProcessor",
- d = "audioWorklet",
- o = R + " " + d,
- g = "RecProc",
- w = "MediaRecorder",
- S = w + ".WebM.PCM",
- M = c.createScriptProcessor || c.createJavaScriptNode,
- y = z("ZGlf::。由于{1}内部1秒375次回调,在移动端可能会有性能问题导致回调丢失录音变短,PC端无影响,暂不建议开启{1}。", 0, d),
- A = function () {
- a = f.isWorklet = !1, n(f), O(z("7TU0::Connect采用老的{1},", 0, v) + Y.get(z(N[E] ? "JwCL::但已设置{1}尝试启用{2}" : "VGjB::可设置{1}尝试启用{2}", 2), [R + "." + E + "=true", d]) + b + y, 3);
- var e = f._p = M.call(c, l, 1, 1);
- i(e), e.onaudioprocess = function (e) {
- var t = e.inputBuffer.getChannelData(0);
- m(t);
- };
- },
- k = function () {
- u = f.isWebM = !1, I(f), a = f.isWorklet = !M || N[E];
- var t = window.AudioWorkletNode;
- if (a && c[d] && t) {
- var n = function () {
- return a && f._na;
- },
- s = f._na = function () {
- "" !== h && (clearTimeout(h), h = setTimeout(function () {
- h = 0, n() && (O(z("MxX1::{1}未返回任何音频,恢复使用{2}", 0, d, v), 3), M && A());
- }, 500));
- },
- r = function () {
- if (n()) {
- var e = f._n = new t(c, g, {
- processorOptions: {
- bufferSize: l
- }
- });
- i(e), e.port.onmessage = function (e) {
- h && (clearTimeout(h), h = ""), n() ? m(e.data.val) : a || O(z("XUap::{1}多余回调", 0, d), 3);
- }, O(z("yOta::Connect采用{1},设置{2}可恢复老式{3}", 0, d, R + "." + E + "=false", v) + b + y, 3);
- }
- },
- e = function () {
- if (n()) if (c[g]) r();else {
- var e,
- t,
- a = (t = "class " + g + " extends AudioWorkletProcessor{", t += "constructor " + (e = function (e) {
- return e.toString().replace(/^function|DEL_/g, "").replace(/\$RA/g, o);
- })(function (e) {
- DEL_super(e);
- var t = this,
- a = e.processorOptions.bufferSize;
- t.bufferSize = a, t.buffer = new Float32Array(2 * a), t.pos = 0, t.port.onmessage = function (e) {
- e.data.kill && (t.kill = !0, $C.log("$RA kill call"));
- }, $C.log("$RA .ctor call", e);
- }), t += "process " + e(function (e, t, a) {
- var n = this,
- s = n.bufferSize,
- r = n.buffer,
- i = n.pos;
- if ((e = (e[0] || [])[0] || []).length) {
- r.set(e, i);
- var o = ~~((i += e.length) / s) * s;
- if (o) {
- this.port.postMessage({
- val: r.slice(0, o)
- });
- var _ = r.subarray(o, i);
- (r = new Float32Array(2 * s)).set(_), i = _.length, n.buffer = r;
- }
- n.pos = i;
- }
- return !n.kill;
- }), t = (t += '}try{registerProcessor("' + g + '", ' + g + ')}catch(e){$C.error("' + o + ' Reg Error",e)}').replace(/\$C\./g, "console."), "data:text/javascript;base64," + btoa(unescape(encodeURIComponent(t))));
- c[d].addModule(a).then(function (e) {
- n() && (c[g] = 1, r(), h && s());
- })[x](function (e) {
- O(d + ".addModule Error", 1, e), n() && A();
- });
- }
- };
- B(c, function () {
- return n();
- }, e, e);
- } else A();
- };
- !function () {
- var e = window[w],
- t = "ondataavailable",
- a = "audio/webm; codecs=pcm";
- u = f.isWebM = N[T];
- var n = e && t in e.prototype && e.isTypeSupported(a);
- if (b = n ? "" : z("VwPd::(此浏览器不支持{1})", 0, S), !_ || !u || !n) return k();
- var s = function () {
- return u && f._ra;
- },
- r = (f._ra = function () {
- "" !== h && (clearTimeout(h), h = setTimeout(function () {
- s() && (O(z("vHnb::{1}未返回任何音频,降级使用{2}", 0, w, d), 3), k());
- }, 500));
- }, Object.assign({
- mimeType: a
- }, N.ConnectWebMOptions)),
- i = f._r = new e(f, r),
- o = f._rd = {
- sampleRate: c[D]
- };
- i[t] = function (e) {
- var t = new FileReader();
- t.onloadend = function () {
- if (s()) {
- var e = P(new Uint8Array(t.result), o);
- if (!e) return;
- if (-1 == e) return void k();
- h && (clearTimeout(h), h = ""), m(e);
- } else u || O(z("O9P7::{1}多余回调", 0, w), 3);
- }, t.readAsArrayBuffer(e.data);
- }, i.start(~~(l / 48)), O(z("LMEm::Connect采用{1},设置{2}可恢复使用{3}或老式{4}", 0, S, R + "." + T + "=false", d, v));
- }();
- },
- r = function (e) {
- e._na && e._na(), e._ra && e._ra();
- },
- n = function (e) {
- e._na = null, e._n && (e._n.port.postMessage({
- kill: !0
- }), e._n.disconnect(), e._n = null);
- },
- I = function (e) {
- if (e._ra = null, e._r) {
- try {
- e._r.stop();
- } catch (e) {
- O("mr stop err", 1, e);
- }
- e._r = null;
- }
- },
- L = function (e) {
- var t = (e = e || N) == N,
- a = e.Stream;
- a && (a._m && (a._m.disconnect(), a._m = null), !a._RC && a._c && N.CloseNewCtx(a._c), a._RC = null, a._c = null, a._d && (o(a._d.stream), a._d = null), a._p && (a._p.disconnect(), a._p.onaudioprocess = a._p = null), n(a), I(a), t && o(a)), e.Stream = 0;
- },
- o = N.StopS_ = function (e) {
- for (var t = e.getTracks && e.getTracks() || e.audioTracks || [], a = 0; a < t.length; a++) {
- var n = t[a];
- n.stop && n.stop();
- }
- e.stop && e.stop();
- };
- N.SampleData = function (e, t, a, n, s) {
- var r = "SampleData";
- n || (n = {});
- var i = n.index || 0,
- o = n.offset || 0,
- _ = n.filter;
- if (_ && _.fn && _.sr != t && (_ = null, O(z("d48C::{1}的filter采样率变了,重设滤波", 0, r), 3)), !_) {
- var l = 3 * t / 4 < a ? 0 : a / 2 * 3 / 4;
- _ = {
- fn: l ? N.IIRFilter(!0, t, l) : 0
- };
- }
- _.sr = t;
- var f = _.fn,
- c = n.frameNext || [];
- s || (s = {});
- var u = s.frameSize || 1;
- s.frameType && (u = "mp3" == s.frameType ? 1152 : 1);
- var h = e.length;
- h + 1 < i && O(z("tlbC::{1}似乎传入了未重置chunk {2}", 0, r, i + ">" + h), 3);
- for (var b = 0, p = i; p < h; p++) b += e[p].length;
- b = Math.max(0, b - Math.floor(o));
- var m = t / a;
- 1 < m ? b = Math.floor(b / m) : (m = 1, a = t), b += c.length;
- for (var v = new Int16Array(b), d = 0, p = 0; p < c.length; p++) v[d] = c[p], d++;
- for (; i < h; i++) {
- for (var g = e[i], p = o, w = g.length, S = f && f.Embed, M = 0, y = 0, A = 0, k = 0, R = 0, x = 0; R < w; R++, x++) if (x < w && (S ? (A = g[x], k = S.b0 * A + S.b1 * S.x1 + S.b0 * S.x2 - S.a1 * S.y1 - S.a2 * S.y2, S.x2 = S.x1, S.x1 = A, S.y2 = S.y1, S.y1 = k) : k = f ? f(g[x]) : g[x]), M = y, y = k, 0 != x) {
- var B = Math.floor(p);
- if (R == B) {
- var T = Math.ceil(p),
- E = p - B,
- C = M,
- I = T < w ? y : C,
- L = C + (I - C) * E;
- 32767 < L ? L = 32767 : L < -32768 && (L = -32768), v[d] = L, d++, p += m;
- }
- } else R--;
- o = Math.max(0, p - w);
- }
- c = null;
- var P = v.length % u;
- if (0 < P) {
- var H = 2 * (v.length - P);
- c = new Int16Array(v.buffer.slice(H)), v = new Int16Array(v.buffer.slice(0, H));
- }
- return {
- index: i,
- offset: o,
- filter: _,
- frameNext: c,
- sampleRate: a,
- data: v
- };
- }, N.IIRFilter = function (e, t, a) {
- var n = 2 * Math.PI * a / t,
- s = Math.sin(n),
- r = Math.cos(n),
- i = s / 2,
- o = 1 + i,
- _ = -2 * r / o,
- l = (1 - i) / o;
- if (e) var f = (1 - r) / 2 / o,
- c = (1 - r) / o;else var f = (1 + r) / 2 / o,
- c = -(1 + r) / o;
- var u = 0,
- h = 0,
- b = 0,
- p = 0,
- m = 0,
- v = function (e) {
- return b = f * e + c * u + f * h - _ * p - l * m, h = u, u = e, m = p, p = b;
- };
- return v.Embed = {
- x1: 0,
- x2: 0,
- y1: 0,
- y2: 0,
- b0: f,
- b1: c,
- a1: _,
- a2: l
- }, v;
- }, N.PowerLevel = function (e, t) {
- var a = e / t || 0;
- return a < 1251 ? Math.round(a / 1250 * 10) : Math.round(Math.min(100, Math.max(0, 100 * (1 + Math.log(a / 1e4) / Math.log(10)))));
- }, N.PowerDBFS = function (e) {
- var t = Math.max(.1, e || 0);
- return t = Math.min(t, 32767), t = 20 * Math.log(t / 32767) / Math.log(10), Math.max(-100, Math.round(t));
- }, N.CLog = function (e, t) {
- if ("object" == typeof console) {
- var a = new Date(),
- n = ("0" + a.getMinutes()).substr(-2) + ":" + ("0" + a.getSeconds()).substr(-2) + "." + ("00" + a.getMilliseconds()).substr(-3),
- s = this && this.envIn && this.envCheck && this.id,
- r = ["[" + n + " " + R + (s ? ":" + s : "") + "]" + e],
- i = arguments,
- o = N.CLog,
- _ = 2,
- l = o.log || console.log;
- for (f(t) ? l = 1 == t ? o.error || console.error : 3 == t ? o.warn || console.warn : l : _ = 1; _ < i.length; _++) r.push(i[_]);
- c ? l && l("[IsLoser]" + r[0], 1 < r.length ? r : "") : l.apply(console, r);
- }
- };
- var O = function () {
- N.CLog.apply(this, arguments);
- },
- c = !0;
- try {
- c = !console.log.apply;
- } catch (e) {}
- var _ = 0;
- function l(e) {
- var t = this;
- t.id = ++_, u();
- var a = {
- type: "mp3",
- onProcess: S
- };
- for (var n in e) a[n] = e[n];
- var s = (t.set = a)[i],
- r = a[D];
- (s && !f(s) || r && !f(r)) && t.CLog(z.G("IllegalArgs-1", [z("VtS4::{1}和{2}必须是数值", 0, D, i)]), 1, e), a[i] = +s || 16, a[D] = +r || 16e3, t.state = 0, t._S = 9, t.Sync = {
- O: 9,
- C: 9
- };
}
- N.Sync = {
+ return !1;
+ }, V.BufferSize = 4096, V.Destroy = function () {
+ for (var e in H(T + " Destroy"), S(), a) a[e]();
+ };
+ var a = {};
+ V.BindDestroy = function (e, t) {
+ a[e] = t;
+ }, V.Support = function () {
+ var e = navigator.mediaDevices || {};
+ return e[d] || (e = navigator)[d] || (e[d] = e.webkitGetUserMedia || e.mozGetUserMedia || e.msGetUserMedia), !!e[d] && (V.Scope = e, !!V.GetContext());
+ }, V.GetContext = function () {
+ var e = y.AudioContext;
+ return e || (e = y.webkitAudioContext), e ? (V.Ctx && "closed" != V.Ctx.state || (V.Ctx = new e(), V.BindDestroy("Ctx", function () {
+ var e = V.Ctx;
+ e && e.close && (e.close(), V.Ctx = 0);
+ })), V.Ctx) : null;
+ };
+ var E = "ConnectEnableWebM";
+ V[E] = !0;
+ var P = "ConnectEnableWorklet";
+ V[P] = !1;
+ var g = function (e, _) {
+ var l,
+ i,
+ f,
+ c = e.BufferSize || V.BufferSize,
+ h = V.Ctx,
+ u = e.Stream,
+ o = function (e) {
+ var t = u._m = h.createMediaStreamSource(u),
+ a = h.destination,
+ s = "createMediaStreamDestination";
+ h[s] && (a = h[s]()), t.connect(e), e.connect(a);
+ },
+ m = "",
+ p = u._call,
+ b = function (e) {
+ for (var t in p) {
+ for (var a = e.length, s = new Int16Array(a), n = 0, r = 0; r < a; r++) {
+ var i = Math.max(-1, Math.min(1, e[r]));
+ i = i < 0 ? 32768 * i : 32767 * i, s[r] = i, n += Math.abs(i);
+ }
+ for (var o in p) p[o](s, n);
+ return;
+ }
+ },
+ v = "ScriptProcessor",
+ d = "audioWorklet",
+ g = T + " " + d,
+ S = "RecProc",
+ M = "MediaRecorder",
+ w = M + ".WebM.PCM",
+ R = h.createScriptProcessor || h.createJavaScriptNode,
+ A = "。由于" + d + "内部1秒375次回调,在移动端可能会有性能问题导致回调丢失录音变短,PC端无影响,暂不建议开启" + d + "。",
+ B = function () {
+ i = u.isWorklet = !1, L(u), H("Connect采用老的" + v + "," + (V[P] ? "但已" : "可") + "设置" + T + "." + P + "=true尝试启用" + d + m + A, 3);
+ var e = u._p = R.call(h, c, 1, 1);
+ o(e);
+ var t = "_D220626",
+ a = V[t];
+ a && H("Use " + T + "." + t, 3), e.onaudioprocess = function (e) {
+ var t = e.inputBuffer.getChannelData(0);
+ a ? (t = new Float32Array(t), setTimeout(function () {
+ b(t);
+ })) : b(t);
+ };
+ },
+ k = function () {
+ l = u.isWebM = !1, I(u), i = u.isWorklet = !R || V[P];
+ var t = y.AudioWorkletNode;
+ if (i && h[d] && t) {
+ var s = function () {
+ return i && u._na;
+ },
+ n = u._na = function () {
+ "" !== f && (clearTimeout(f), f = setTimeout(function () {
+ f = 0, s() && (H(d + "未返回任何音频,恢复使用" + v, 3), R && B());
+ }, 500));
+ },
+ r = function () {
+ if (s()) {
+ var e = u._n = new t(h, S, {
+ processorOptions: {
+ bufferSize: c
+ }
+ });
+ o(e), e.port.onmessage = function (e) {
+ f && (clearTimeout(f), f = ""), s() ? b(e.data.val) : i || H(d + "多余回调", 3);
+ }, H("Connect采用" + d + ",设置" + T + "." + P + "=false可恢复老式" + v + m + A, 3);
+ }
+ };
+ h.resume()[p && "finally"](function () {
+ if (s()) if (h[S]) r();else {
+ var e,
+ t,
+ a = (t = "class " + S + " extends AudioWorkletProcessor{", t += "constructor " + (e = function (e) {
+ return e.toString().replace(/^function|DEL_/g, "").replace(/\$RA/g, g);
+ })(function (e) {
+ DEL_super(e);
+ var t = this,
+ a = e.processorOptions.bufferSize;
+ t.bufferSize = a, t.buffer = new Float32Array(2 * a), t.pos = 0, t.port.onmessage = function (e) {
+ e.data.kill && (t.kill = !0, console.log("$RA kill call"));
+ }, console.log("$RA .ctor call", e);
+ }), t += "process " + e(function (e, t, a) {
+ var s = this,
+ n = s.bufferSize,
+ r = s.buffer,
+ i = s.pos;
+ if ((e = (e[0] || [])[0] || []).length) {
+ r.set(e, i);
+ var o = ~~((i += e.length) / n) * n;
+ if (o) {
+ this.port.postMessage({
+ val: r.slice(0, o)
+ });
+ var _ = r.subarray(o, i);
+ (r = new Float32Array(2 * n)).set(_), i = _.length, s.buffer = r;
+ }
+ s.pos = i;
+ }
+ return !s.kill;
+ }), t += '}try{registerProcessor("' + S + '", ' + S + ')}catch(e){console.error("' + g + '注册失败",e)}', "data:text/javascript;base64," + btoa(unescape(encodeURIComponent(t))));
+ h[d].addModule(a).then(function (e) {
+ s() && (h[S] = 1, r(), f && n());
+ })[x](function (e) {
+ H(d + ".addModule失败", 1, e), s() && B();
+ });
+ }
+ });
+ } else B();
+ };
+ !function () {
+ var e = y[M],
+ t = "ondataavailable",
+ a = "audio/webm; codecs=pcm";
+ l = u.isWebM = V[E];
+ var s = e && t in e.prototype && e.isTypeSupported(a);
+ if (m = s ? "" : "(此浏览器不支持" + w + ")", !_ || !l || !s) return k();
+ var n = function () {
+ return l && u._ra;
+ },
+ r = (u._ra = function () {
+ "" !== f && (clearTimeout(f), f = setTimeout(function () {
+ n() && (H(M + "未返回任何音频,降级使用" + d, 3), k());
+ }, 500));
+ }, Object.assign({
+ mimeType: a
+ }, V.ConnectWebMOptions)),
+ i = u._r = new e(u, r),
+ o = u._rd = {
+ sampleRate: h[N]
+ };
+ i[t] = function (e) {
+ var t = new FileReader();
+ t.onloadend = function () {
+ if (n()) {
+ var e = C(new Uint8Array(t.result), o);
+ if (!e) return;
+ if (-1 == e) return void k();
+ f && (clearTimeout(f), f = ""), b(e);
+ } else l || H(M + "多余回调", 3);
+ }, t.readAsArrayBuffer(e.data);
+ }, i.start(~~(c / 48)), H("Connect采用" + w + ",设置" + T + "." + E + "=false可恢复使用" + d + "或老式" + v);
+ }();
+ },
+ L = function (e) {
+ e._na = null, e._n && (e._n.port.postMessage({
+ kill: !0
+ }), e._n.disconnect(), e._n = null);
+ },
+ I = function (e) {
+ e._ra = null, e._r && (e._r.stop(), e._r = null);
+ },
+ S = function (e) {
+ var t = (e = e || V) == V,
+ a = e.Stream;
+ if (a && (a._m && (a._m.disconnect(), a._m = null), a._p && (a._p.disconnect(), a._p.onaudioprocess = a._p = null), L(a), I(a), t)) {
+ for (var s = a.getTracks && a.getTracks() || a.audioTracks || [], n = 0; n < s.length; n++) {
+ var r = s[n];
+ r.stop && r.stop();
+ }
+ a.stop && a.stop();
+ }
+ e.Stream = 0;
+ };
+ V.SampleData = function (e, t, a, s, n) {
+ s || (s = {});
+ var r = s.index || 0,
+ i = s.offset || 0,
+ o = s.frameNext || [];
+ n || (n = {});
+ var _ = n.frameSize || 1;
+ n.frameType && (_ = "mp3" == n.frameType ? 1152 : 1);
+ var l = e.length;
+ l + 1 < r && H("SampleData似乎传入了未重置chunk " + r + ">" + l, 3);
+ for (var f = 0, c = r; c < l; c++) f += e[c].length;
+ f = Math.max(0, f - Math.floor(i));
+ var h = t / a;
+ 1 < h ? f = Math.floor(f / h) : (h = 1, a = t), f += o.length;
+ for (var u = new Int16Array(f), m = 0, c = 0; c < o.length; c++) u[m] = o[c], m++;
+ for (; r < l; r++) {
+ for (var p = e[r], c = i, b = p.length; c < b;) {
+ var v = Math.floor(c),
+ d = Math.ceil(c),
+ g = c - v,
+ S = p[v],
+ M = d < b ? p[d] : (e[r + 1] || [S])[0] || 0;
+ u[m] = S + (M - S) * g, m++, c += h;
+ }
+ i = c - b;
+ }
+ o = null;
+ var w = u.length % _;
+ if (0 < w) {
+ var R = 2 * (u.length - w);
+ o = new Int16Array(u.buffer.slice(R)), u = new Int16Array(u.buffer.slice(0, R));
+ }
+ return {
+ index: r,
+ offset: i,
+ frameNext: o,
+ sampleRate: a,
+ data: u
+ };
+ }, V.PowerLevel = function (e, t) {
+ var a = e / t || 0;
+ return a < 1251 ? Math.round(a / 1250 * 10) : Math.round(Math.min(100, Math.max(0, 100 * (1 + Math.log(a / 1e4) / Math.log(10)))));
+ }, V.PowerDBFS = function (e) {
+ var t = Math.max(.1, e || 0);
+ return t = Math.min(t, 32767), t = 20 * Math.log(t / 32767) / Math.log(10), Math.max(-100, Math.round(t));
+ }, V.CLog = function (e, t) {
+ var a = new Date(),
+ s = ("0" + a.getMinutes()).substr(-2) + ":" + ("0" + a.getSeconds()).substr(-2) + "." + ("00" + a.getMilliseconds()).substr(-3),
+ n = this && this.envIn && this.envCheck && this.id,
+ r = ["[" + s + " " + T + (n ? ":" + n : "") + "]" + e],
+ i = arguments,
+ o = y.console || {},
+ _ = 2,
+ l = o.log;
+ for ("number" == typeof t ? l = 1 == t ? o.error : 3 == t ? o.warn : l : _ = 1; _ < i.length; _++) r.push(i[_]);
+ f ? l && l("[IsLoser]" + r[0], 1 < r.length ? r : "") : l.apply(o, r);
+ };
+ var H = function () {
+ V.CLog.apply(this, arguments);
+ },
+ f = !0;
+ try {
+ f = !console.log.apply;
+ } catch (e) {}
+ var s = 0;
+ function t(e) {
+ this.id = ++s, r();
+ var t = {
+ type: "mp3",
+ bitRate: 16,
+ sampleRate: 16e3,
+ onProcess: v
+ };
+ for (var a in e) t[a] = e[a];
+ this.set = t, this._S = 9, this.Sync = {
O: 9,
C: 9
- }, N.prototype = l.prototype = {
- CLog: O,
- _streamStore: function () {
- return this.set.sourceStream ? this : N;
- },
- _streamCtx: function () {
- var e = this._streamStore().Stream;
- return e && e._c;
- },
- open: function (e, a) {
- var n = this,
- s = n.set,
- r = n._streamStore(),
- i = 0;
- e = e || S;
- var o = function (e, t) {
- t = !!t, n.CLog(z("5tWi::录音open失败:") + e + ",isUserNotAllow:" + t, 1), i && N.CloseNewCtx(i), a && a(e, t);
- };
- n._streamTag = A;
- var _ = function () {
- n.CLog("open ok, id:" + n.id + " stream:" + n._streamTag), e(), n._SO = 0;
- },
- l = r.Sync,
- f = ++l.O,
- c = l.C;
- n._O = n._O_ = f, n._SO = n._S;
- if (w) {
- var t = n.envCheck({
- envName: "H5",
- canProcess: !0
- });
- if (t) o(z("A5bm::不能录音:") + t);else if (s.sourceStream) {
- if (n._streamTag = "set.sourceStream", !N.GetContext()) return void o(z("1iU7::不支持此浏览器从流中获取录音"));
- L(r);
- var u = n.Stream = s.sourceStream;
- u._RC = s.runningContext, u._call = {};
- try {
- C(r);
- } catch (e) {
- return L(r), void o(z("BTW2::从流中打开录音失败:") + e.message);
- }
- _();
- } else {
- var h = function (e, t) {
- try {
- window.top.a;
- } catch (e) {
- return void o(z("Nclz::无权录音(跨域,请尝试给iframe添加麦克风访问策略,如{1})", 0, 'allow="camera;microphone"'));
- }
- /Permission|Allow/i.test(e) ? o(z("gyO5::用户拒绝了录音权限"), !0) : !1 === window.isSecureContext ? o(z("oWNo::浏览器禁止不安全页面录音,可开启https解决")) : /Found/i.test(e) ? o(t + z("jBa9::,无可用麦克风")) : o(t);
- };
- if (N.IsOpen()) _();else if (N.Support()) {
- var b = s.runningContext;
- b || (b = i = N.GetContext(!0));
- var p = function (t) {
- setTimeout(function () {
- t._call = {};
- var e = N.Stream;
- e && (L(), t._call = e._call), (N.Stream = t)._c = b, t._RC = s.runningContext, function () {
- if (c != l.C || !n._O) {
- var e = z("dFm8::open被取消");
- return f == l.O ? n.close() : e = z("VtJO::open被中断"), o(e), !0;
- }
- }() || (N.IsOpen() ? (e && n.CLog(z("upb8::发现同时多次调用open"), 1), C(r, 1), _()) : o(z("Q1GA::录音功能无效:无音频流")));
- }, 100);
- },
- m = function (e) {
- var t = e.name || e.message || e.code + ":" + e;
- n.CLog(z("xEQR::请求录音权限错误"), 1, e), h(t, z("bDOG::无法录音:") + t);
- },
- v = s.audioTrackSet || {};
- v[D] = b[D];
- var d = {
- audio: v
- };
- try {
- var g = N.Scope[A](d, p, m);
- } catch (e) {
- n.CLog(A, 3, e), d = {
- audio: !0
- }, g = N.Scope[A](d, p, m);
- }
- n.CLog(A + "(" + JSON.stringify(d) + ") " + k(b) + z("RiWe::,未配置noiseSuppression和echoCancellation时浏览器可能会自动打开降噪和回声消除,移动端可能会降低系统播放音量(关闭录音后可恢复),请参阅文档中audioTrackSet配置") + "(" + y + ") LM:" + M + " UA:" + navigator.userAgent), g && g.then && g.then(p)[x](m);
- } else h("", z("COxc::此浏览器不支持录音"));
- }
- } else o(z.G("NonBrowser-1", ["open"]) + z("EMJq::,可尝试使用RecordApp解决方案") + "(" + y + "/tree/master/app-support-sample)");
- },
- close: function (e) {
- e = e || S;
- var t = this,
- a = t._streamStore();
- t._stop();
- var n = " stream:" + t._streamTag,
- s = a.Sync;
- if (t._O = 0, t._O_ != s.O) return t.CLog(z("hWVz::close被忽略(因为同时open了多个rec,只有最后一个会真正close)") + n, 3), void e();
- s.C++, L(a), t.CLog("close," + n), e();
- },
- mock: function (e, t) {
- var a = this;
- return a._stop(), a.isMock = 1, a.mockEnvInfo = null, a.buffers = [e], a.recSize = e.length, a._setSrcSR(t), a._streamTag = "mock", a;
- },
- _setSrcSR: function (e) {
- var t = this.set,
- a = t[D];
- e < a ? t[D] = e : a = 0, this[V] = e, this.CLog(V + ": " + e + " set." + D + ": " + t[D] + (a ? " " + z("UHvm::忽略") + ": " + a : ""), a ? 3 : 0);
- },
- envCheck: function (e) {
- var t,
- a = this.set,
- n = "CPU_BE";
- if (t || N[n] || "function" != typeof Int8Array || new Int8Array(new Int32Array([1]).buffer)[0] || (u(n), t = z("Essp::不支持{1}架构", 0, n)), !t) {
- var s = a.type,
- r = this[s + "_envCheck"];
- a.takeoffEncodeChunk && (r ? e.canProcess || (t = z("7uMV::{1}环境不支持实时处理", 0, e.envName)) : t = z("2XBl::{1}类型不支持设置takeoffEncodeChunk", 0, s) + (this[s] ? "" : z("LG7e::(未加载编码器)"))), !t && r && (t = this[s + "_envCheck"](e, a));
+ };
+ }
+ V.Sync = {
+ O: 9,
+ C: 9
+ }, V.prototype = t.prototype = {
+ CLog: H,
+ _streamStore: function () {
+ return this.set.sourceStream ? this : V;
+ },
+ open: function (e, a) {
+ var s = this,
+ n = s._streamStore();
+ e = e || v;
+ var r = function (e, t) {
+ t = !!t, s.CLog("录音open失败:" + e + ",isUserNotAllow:" + t, 1), a && a(e, t);
+ },
+ i = function () {
+ s.CLog("open ok id:" + s.id), e(), s._SO = 0;
+ },
+ o = n.Sync,
+ _ = ++o.O,
+ l = o.C;
+ s._O = s._O_ = _, s._SO = s._S;
+ var t = s.envCheck({
+ envName: "H5",
+ canProcess: !0
+ });
+ if (t) r("不能录音:" + t);else if (s.set.sourceStream) {
+ if (!V.GetContext()) return void r("不支持此浏览器从流中获取录音");
+ S(n), s.Stream = s.set.sourceStream, s.Stream._call = {};
+ try {
+ g(n);
+ } catch (e) {
+ return void r("从流中打开录音失败:" + e.message);
}
- return t || "";
- },
- envStart: function (e, t) {
- var a = this,
- n = a.set;
- if (a.isMock = e ? 1 : 0, a.mockEnvInfo = e, a.buffers = [], a.recSize = 0, e && (a._streamTag = "env$" + e.envName), a.state = 1, a.envInLast = 0, a.envInFirst = 0, a.envInFix = 0, a.envInFixTs = [], a._setSrcSR(t), a.engineCtx = 0, a[n.type + "_start"]) {
- var s = a.engineCtx = a[n.type + "_start"](n);
- s && (s.pcmDatas = [], s.pcmSize = 0);
- }
- },
- envResume: function () {
- this.envInFixTs = [];
- },
- envIn: function (e, t) {
- var s = this,
- r = s.set,
- i = s.engineCtx;
- if (1 == s.state) {
- var a = s[V],
- n = e.length,
- o = N.PowerLevel(t, n),
- _ = s.buffers,
- l = _.length;
- _.push(e);
- var f = _,
- c = l,
- u = Date.now(),
- h = Math.round(n / a * 1e3);
- s.envInLast = u, 1 == s.buffers.length && (s.envInFirst = u - h);
- var b = s.envInFixTs;
- b.splice(0, 0, {
- t: u,
- d: h
- });
- for (var p = u, m = 0, v = 0; v < b.length; v++) {
- var d = b[v];
- if (3e3 < u - d.t) {
- b.length = v;
- break;
- }
- p = d.t, m += d.d;
- }
- var g = b[1],
- w = u - p,
- S = w - m;
- if (w / 3 < S && (g && 1e3 < w || 6 <= b.length)) {
- var M = u - g.t - h;
- if (h / 5 < M) {
- var y = !r.disableEnvInFix;
- if (s.CLog("[" + u + "]" + Y.get(z(y ? "4Kfd::补偿{1}ms" : "bM5i::未补偿{1}ms", 1), [M]), 3), s.envInFix += M, y) {
- var A = new Int16Array(M * a / 1e3);
- n += A.length, _.push(A);
- }
- }
- }
- var k = s.recSize,
- R = n,
- x = k + R;
- if (s.recSize = x, i) {
- var B = N.SampleData(_, a, r[D], i.chunkInfo);
- i.chunkInfo = B, k = i.pcmSize, R = B.data.length, x = k + R, i.pcmSize = x, _ = i.pcmDatas, l = _.length, _.push(B.data), a = B[D];
- }
- var T = Math.round(x / a * 1e3),
- E = _.length,
- C = f.length,
- I = function () {
- for (var e = L ? 0 : -R, t = null == _[0], a = l; a < E; a++) {
- var n = _[a];
- null == n ? t = 1 : (e += n.length, i && n.length && s[r.type + "_encode"](i, n));
- }
- if (t && i) {
- var a = c;
- for (f[0] && (a = 0); a < C; a++) f[a] = null;
- }
- t && (e = L ? R : 0, _[0] = null), i ? i.pcmSize += e : s.recSize += e;
- },
- L = 0,
- P = "rec.set.onProcess";
+ i();
+ } else {
+ var f = function (e, t) {
try {
- L = r.onProcess(_, o, T, a, l, I);
+ y.top.a;
} catch (e) {
- console.error(P + z("gFUF::回调出错是不允许的,需保证不会抛异常"), e);
+ return void r('无权录音(跨域,请尝试给iframe添加麦克风访问策略,如allow="camera;microphone")');
}
- var H = Date.now() - u;
- if (10 < H && 1e3 < s.envInFirst - u && s.CLog(P + z("2ghS::低性能,耗时{1}ms", 0, H), 3), !0 === L) {
- for (var O = 0, v = l; v < E; v++) null == _[v] ? O = 1 : _[v] = new Int16Array(0);
- O ? s.CLog(z("ufqH::未进入异步前不能清除buffers"), 3) : i ? i.pcmSize -= R : s.recSize -= R;
- } else I();
- } else s.state || s.CLog("envIn at state=0", 3);
- },
- start: function () {
- var t = this,
- e = 1;
- if (t.set.sourceStream ? t.Stream || (e = 0) : N.IsOpen() || (e = 0), e) {
- var a = t._streamCtx();
- if (t.CLog(z("kLDN::start 开始录音,") + k(a) + " stream:" + t._streamTag), t._stop(), t.envStart(null, a[D]), t.state = 3, t._SO && t._SO + 1 != t._S) t.CLog(z("Bp2y::start被中断"), 3);else {
- t._SO = 0;
- var n = function () {
- 3 == t.state && (t.state = 1, t.resume());
- },
- s = "AudioContext resume: ";
- B(a, function (e) {
- return e && t.CLog(s + "wait..."), 3 == t.state;
- }, function (e) {
- e && t.CLog(s + a.state), n();
- }, function (e) {
- t.CLog(s + a.state + z("upkE::,可能无法录音:") + e, 1), n();
- });
+ /Permission|Allow/i.test(e) ? r("用户拒绝了录音权限", !0) : !1 === y.isSecureContext ? r("浏览器禁止不安全页面录音,可开启https解决") : /Found/i.test(e) ? r(t + ",无可用麦克风") : r(t);
+ };
+ if (V.IsOpen()) i();else if (V.Support()) {
+ var c = function (t) {
+ setTimeout(function () {
+ t._call = {};
+ var e = V.Stream;
+ e && (S(), t._call = e._call), V.Stream = t, function () {
+ if (l != o.C || !s._O) {
+ var e = "open被取消";
+ return _ == o.O ? s.close() : e = "open被中断", r(e), !0;
+ }
+ }() || (V.IsOpen() ? (e && s.CLog("发现同时多次调用open", 1), g(n, 1), i()) : r("录音功能无效:无音频流"));
+ }, 100);
+ },
+ h = function (e) {
+ var t = e.name || e.message || e.code + ":" + e;
+ s.CLog("请求录音权限错误", 1, e), f(t, "无法录音:" + t);
+ },
+ u = {
+ noiseSuppression: !1,
+ echoCancellation: !1
+ },
+ m = s.set.audioTrackSet;
+ for (var p in m) u[p] = m[p];
+ u.sampleRate = V.Ctx.sampleRate;
+ try {
+ var b = V.Scope[d]({
+ audio: u
+ }, c, h);
+ } catch (e) {
+ s.CLog(d, 3, e), b = V.Scope[d]({
+ audio: !0
+ }, c, h);
}
- } else t.CLog(z("6WmN::start失败:未open"), 1);
- },
- pause: function () {
- var e = this,
- t = e._streamStore().Stream;
- e.state && (e.state = 2, e.CLog("pause"), t && delete t._call[e.id]);
- },
- resume: function () {
- var a = this,
- t = a._streamStore().Stream,
- n = "resume(wait ctx)";
- if (3 == a.state) a.CLog(n);else if (a.state) {
- a.state = 1, a.CLog("resume"), a.envResume(), t && (t._call[a.id] = function (e, t) {
- 1 == a.state && a.envIn(e, t);
- }, r(t));
- var s = a._streamCtx();
- s && B(s, function (e) {
- return e && a.CLog(n + "..."), 1 == a.state;
- }, function (e) {
- e && a.CLog(n + s.state), r(t);
- }, function (e) {
- a.CLog(n + s.state + "[err]" + e, 1);
- });
+ b && b.then && b.then(c)[x](h);
+ } else f("", "此浏览器不支持录音");
+ }
+ },
+ close: function (e) {
+ e = e || v;
+ var t = this,
+ a = t._streamStore();
+ t._stop();
+ var s = a.Sync;
+ if (t._O = 0, t._O_ != s.O) return t.CLog("close被忽略(因为同时open了多个rec,只有最后一个会真正close)", 3), void e();
+ s.C++, S(a), t.CLog("close"), e();
+ },
+ mock: function (e, t) {
+ var a = this;
+ return a._stop(), a.isMock = 1, a.mockEnvInfo = null, a.buffers = [e], a.recSize = e.length, a[O] = t, a;
+ },
+ envCheck: function (e) {
+ var t,
+ a = this.set,
+ s = "CPU_BE";
+ if (t || V[s] || !y.Int8Array || new Int8Array(new Int32Array([1]).buffer)[0] || (r(s), t = "不支持CPU_BE架构"), !t) {
+ var n = a.type;
+ this[n + "_envCheck"] ? t = this[n + "_envCheck"](e, a) : a.takeoffEncodeChunk && (t = n + "类型" + (this[n] ? "" : "(未加载编码器)") + "不支持设置takeoffEncodeChunk");
+ }
+ return t || "";
+ },
+ envStart: function (e, t) {
+ var a = this,
+ s = a.set;
+ a.isMock = e ? 1 : 0, a.mockEnvInfo = e, a.buffers = [], a.recSize = 0, a.envInLast = 0, a.envInFirst = 0, a.envInFix = 0, a.envInFixTs = [];
+ var n = s[N];
+ if (t < n ? s[N] = t : n = 0, a[O] = t, a.CLog(O + ": " + t + " set." + N + ": " + s[N] + (n ? " 忽略" + n : ""), n ? 3 : 0), a.engineCtx = 0, a[s.type + "_start"]) {
+ var r = a.engineCtx = a[s.type + "_start"](s);
+ r && (r.pcmDatas = [], r.pcmSize = 0);
+ }
+ },
+ envResume: function () {
+ this.envInFixTs = [];
+ },
+ envIn: function (e, t) {
+ var n = this,
+ r = n.set,
+ i = n.engineCtx,
+ a = n[O],
+ s = e.length,
+ o = V.PowerLevel(t, s),
+ _ = n.buffers,
+ l = _.length;
+ _.push(e);
+ var f = _,
+ c = l,
+ h = Date.now(),
+ u = Math.round(s / a * 1e3);
+ n.envInLast = h, 1 == n.buffers.length && (n.envInFirst = h - u);
+ var m = n.envInFixTs;
+ m.splice(0, 0, {
+ t: h,
+ d: u
+ });
+ for (var p = h, b = 0, v = 0; v < m.length; v++) {
+ var d = m[v];
+ if (3e3 < h - d.t) {
+ m.length = v;
+ break;
}
- },
- _stop: function (e) {
- var t = this,
- a = t.set;
- t.isMock || t._S++, t.state && (t.pause(), t.state = 0), !e && t[a.type + "_stop"] && (t[a.type + "_stop"](t.engineCtx), t.engineCtx = 0);
- },
- stop: function (c, t, e) {
- var u,
- h = this,
- b = h.set,
- a = h.envInLast - h.envInFirst,
- n = a && h.buffers.length;
- h.CLog(z("Xq4s::stop 和start时差:") + (a ? a + "ms " + z("3CQP::补偿:") + h.envInFix + "ms envIn:" + n + " fps:" + (n / a * 1e3).toFixed(1) : "-") + " stream:" + h._streamTag + " (" + y + ") LM:" + M);
- var p = function () {
- h._stop(), e && h.close();
- },
- m = function (e) {
- h.CLog(z("u8JG::结束录音失败:") + e, 1), t && t(e), p();
- },
- s = function (e, t, a) {
- var n = "arraybuffer",
- s = "dataType",
- r = "DefaultDataType",
- i = h[s] || N[r] || "blob",
- o = s + "=" + i,
- _ = e instanceof ArrayBuffer,
- l = 0,
- f = _ ? e.byteLength : e.size;
- if (i == n ? _ || (l = 1) : "blob" == i ? "function" != typeof Blob ? l = z.G("NonBrowser-1", [o]) + z("1skY::,请设置{1}", 0, R + "." + r + '="' + n + '"') : (_ && (e = new Blob([e], {
- type: t
- })), e instanceof Blob || (l = 1), t = e.type || t) : l = z.G("NotSupport-1", [o]), h.CLog(z("Wv7l::结束录音 编码花{1}ms 音频时长{2}ms 文件大小{3}b", 0, Date.now() - u, a, f) + " " + o + "," + t), l) m(1 != l ? l : z("Vkbd::{1}编码器返回的不是{2}", 0, b.type, i) + ", " + o);else {
- if (b.takeoffEncodeChunk) h.CLog(z("QWnr::启用takeoffEncodeChunk后stop返回的blob长度为0不提供音频数据"), 3);else if (f < Math.max(50, a / 5)) return void m(z("Sz2H::生成的{1}无效", 0, b.type));
- c && c(e, a, t), p();
- }
+ p = d.t, b += d.d;
+ }
+ var g = m[1],
+ S = h - p;
+ if (S / 3 < S - b && (g && 1e3 < S || 6 <= m.length)) {
+ var M = h - g.t - u;
+ if (u / 5 < M) {
+ var w = !r.disableEnvInFix;
+ if (n.CLog("[" + h + "]" + (w ? "" : "未") + "补偿" + M + "ms", 3), n.envInFix += M, w) {
+ var R = new Int16Array(M * a / 1e3);
+ s += R.length, _.push(R);
+ }
+ }
+ }
+ var A = n.recSize,
+ B = s,
+ k = A + B;
+ if (n.recSize = k, i) {
+ var y = V.SampleData(_, a, r[N], i.chunkInfo);
+ i.chunkInfo = y, k = (A = i.pcmSize) + (B = y.data.length), i.pcmSize = k, _ = i.pcmDatas, l = _.length, _.push(y.data), a = y[N];
+ }
+ var T = Math.round(k / a * 1e3),
+ x = _.length,
+ E = f.length,
+ P = function () {
+ for (var e = L ? 0 : -B, t = null == _[0], a = l; a < x; a++) {
+ var s = _[a];
+ null == s ? t = 1 : (e += s.length, i && s.length && n[r.type + "_encode"](i, s));
+ }
+ if (t && i) for (a = c, f[0] && (a = 0); a < E; a++) f[a] = null;
+ t && (e = L ? B : 0, _[0] = null), i ? i.pcmSize += e : n.recSize += e;
+ },
+ L = 0,
+ I = "rec.set.onProcess";
+ try {
+ L = r.onProcess(_, o, T, a, l, P);
+ } catch (e) {
+ console.error(I + "回调出错是不允许的,需保证不会抛异常", e);
+ }
+ var H = Date.now() - h;
+ if (10 < H && 1e3 < n.envInFirst - h && n.CLog(I + "低性能,耗时" + H + "ms", 3), !0 === L) {
+ var C = 0;
+ for (v = l; v < x; v++) null == _[v] ? C = 1 : _[v] = new Int16Array(0);
+ C ? n.CLog("未进入异步前不能清除buffers", 3) : i ? i.pcmSize -= B : n.recSize -= B;
+ } else P();
+ },
+ start: function () {
+ var t = this,
+ a = V.Ctx,
+ e = 1;
+ if (t.set.sourceStream ? t.Stream || (e = 0) : V.IsOpen() || (e = 0), e) {
+ if (t.CLog("开始录音"), t._stop(), t.state = 3, t.envStart(null, a[N]), t._SO && t._SO + 1 != t._S) t.CLog("start被中断", 3);else {
+ t._SO = 0;
+ var s = function () {
+ 3 == t.state && (t.state = 1, t.resume());
};
- if (!h.isMock) {
- var r = 3 == h.state;
- if (!h.state || r) return void m(z("wf9t::未开始录音") + (r ? z("Dl2c::,开始录音前无用户交互导致AudioContext未运行") : ""));
+ if ("suspended" == a.state) {
+ var n = "AudioContext resume: ";
+ t.CLog(n + "wait..."), a.resume().then(function () {
+ t.CLog(n + a.state), s();
+ })[x](function (e) {
+ t.CLog(n + a.state + " 可能无法录音:" + e.message, 1, e), s();
+ });
+ } else s();
}
- h._stop(!0);
- var i = h.recSize;
- if (i) {
- if (h[b.type]) {
- if (h.isMock) {
- var o = h.envCheck(h.mockEnvInfo || {
+ } else t.CLog("未open", 1);
+ },
+ pause: function () {
+ var e = this;
+ e.state && (e.state = 2, e.CLog("pause"), delete e._streamStore().Stream._call[e.id]);
+ },
+ resume: function () {
+ var e,
+ a = this;
+ if (a.state) {
+ a.state = 1, a.CLog("resume"), a.envResume();
+ var t = a._streamStore().Stream;
+ t._call[a.id] = function (e, t) {
+ 1 == a.state && a.envIn(e, t);
+ }, (e = t)._na && e._na(), e._ra && e._ra();
+ }
+ },
+ _stop: function (e) {
+ var t = this,
+ a = t.set;
+ t.isMock || t._S++, t.state && (t.pause(), t.state = 0), !e && t[a.type + "_stop"] && (t[a.type + "_stop"](t.engineCtx), t.engineCtx = 0);
+ },
+ stop: function (a, t, e) {
+ var s,
+ n = this,
+ r = n.set,
+ i = n.envInLast - n.envInFirst,
+ o = i && n.buffers.length;
+ n.CLog("stop 和start时差" + (i ? i + "ms 补偿" + n.envInFix + "ms envIn:" + o + " fps:" + (o / i * 1e3).toFixed(1) : "-"));
+ var _ = function () {
+ n._stop(), e && n.close();
+ },
+ l = function (e) {
+ n.CLog("结束录音失败:" + e, 1), t && t(e), _();
+ },
+ f = function (e, t) {
+ if (n.CLog("结束录音 编码花" + (Date.now() - s) + "ms 音频时长" + t + "ms 文件大小" + e.size + "b"), r.takeoffEncodeChunk) n.CLog("启用takeoffEncodeChunk后stop返回的blob长度为0不提供音频数据", 3);else if (e.size < Math.max(100, t / 2)) return void l("生成的" + r.type + "无效");
+ a && a(e, t), _();
+ };
+ if (!n.isMock) {
+ var c = 3 == n.state;
+ if (!n.state || c) return void l("未开始录音" + (c ? ",开始录音前无用户交互导致AudioContext未运行" : ""));
+ n._stop(!0);
+ }
+ var h = n.recSize;
+ if (h) {
+ if (n.buffers[0]) {
+ if (n[r.type]) {
+ if (n.isMock) {
+ var u = n.envCheck(n.mockEnvInfo || {
envName: "mock",
canProcess: !1
});
- if (o) return void m(z("AxOH::录音错误:") + o);
+ if (u) return void l("录音错误:" + u);
}
- var _ = h.engineCtx;
- if (h[b.type + "_complete"] && _) {
- var l = Math.round(_.pcmSize / b[D] * 1e3);
- return u = Date.now(), void h[b.type + "_complete"](_, function (e, t) {
- s(e, t, l);
- }, m);
+ var m = n.engineCtx;
+ if (n[r.type + "_complete"] && m) {
+ var p = Math.round(m.pcmSize / r[N] * 1e3);
+ return s = Date.now(), void n[r.type + "_complete"](m, function (e) {
+ f(e, p);
+ }, l);
}
- if (u = Date.now(), h.buffers[0]) {
- var f = N.SampleData(h.buffers, h[V], b[D]);
- b[D] = f[D];
- var v = f.data,
- l = Math.round(v.length / b[D] * 1e3);
- h.CLog(z("CxeT::采样:{1} 花:{2}ms", 0, i + "->" + v.length, Date.now() - u)), setTimeout(function () {
- u = Date.now(), h[b.type](v, function (e, t) {
- s(e, t, l);
- }, function (e) {
- m(e);
- });
+ s = Date.now();
+ var b = V.SampleData(n.buffers, n[O], r[N]);
+ r[N] = b[N];
+ var v = b.data;
+ p = Math.round(v.length / r[N] * 1e3), n.CLog("采样" + h + "->" + v.length + " 花:" + (Date.now() - s) + "ms"), setTimeout(function () {
+ s = Date.now(), n[r.type](v, function (e) {
+ f(e, p);
+ }, function (e) {
+ l(e);
});
- } else m(z("xkKd::音频buffers被释放"));
- } else m(z("xGuI::未加载{1}编码器,请尝试到{2}的src/engine内找到{1}的编码器并加载", 0, b.type, R));
- } else m(z("Ltz3::未采集到录音"));
- }
- };
- var P = function (e, t) {
- t.pos || (t.pos = [0], t.tracks = {}, t.bytes = []);
- var a = t.tracks,
- n = [t.pos[0]],
- s = function () {
- t.pos[0] = n[0];
- },
- r = t.bytes.length,
- i = new Uint8Array(r + e.length);
- if (i.set(t.bytes), i.set(e, r), t.bytes = i, !t._ht) {
- if (j(i, n), X(i, n), !H(j(i, n), [24, 83, 128, 103])) return;
- for (j(i, n); n[0] < i.length;) {
- var o = j(i, n),
- _ = X(i, n),
- l = [0],
- f = 0;
- if (!_) return;
- if (H(o, [22, 84, 174, 107])) {
- for (; l[0] < _.length;) {
- var c = j(_, l),
- u = X(_, l),
- h = [0],
- b = {
- channels: 0,
- sampleRate: 0
- };
- if (H(c, [174])) for (; h[0] < u.length;) {
- var p = j(u, h),
- m = X(u, h),
- v = [0];
- if (H(p, [215])) {
- var d = F(m);
- b.number = d, a[d] = b;
- } else if (H(p, [131])) {
- var d = F(m);
- 1 == d ? b.type = "video" : 2 == d ? (b.type = "audio", f || (t.track0 = b), b.idx = f++) : b.type = "Type-" + d;
- } else if (H(p, [134])) {
- for (var g = "", w = 0; w < m.length; w++) g += String.fromCharCode(m[w]);
- b.codec = g;
- } else if (H(p, [225])) for (; v[0] < m.length;) {
- var S = j(m, v),
- M = X(m, v);
- if (H(S, [181])) {
- var d = 0,
- y = new Uint8Array(M.reverse()).buffer;
- 4 == M.length ? d = new Float32Array(y)[0] : 8 == M.length ? d = new Float64Array(y)[0] : O("WebM Track !Float", 1, M), b[D] = Math.round(d);
- } else H(S, [98, 100]) ? b.bitDepth = F(M) : H(S, [159]) && (b.channels = F(M));
- }
+ });
+ } else l("未加载" + r.type + "编码器");
+ } else l("音频buffers被释放");
+ } else l("未采集到录音");
+ }
+ }, y[T] && (H("重复引入" + T, 3), y[T].Destroy()), y[T] = V;
+ var C = function (e, t) {
+ t.pos || (t.pos = [0], t.tracks = {}, t.bytes = []);
+ var a = t.tracks,
+ s = [t.pos[0]],
+ n = function () {
+ t.pos[0] = s[0];
+ },
+ r = t.bytes.length,
+ i = new Uint8Array(r + e.length);
+ if (i.set(t.bytes), i.set(e, r), t.bytes = i, !t._ht) {
+ if (X(i, s), q(i, s), !D(X(i, s), [24, 83, 128, 103])) return;
+ for (X(i, s); s[0] < i.length;) {
+ var o = X(i, s),
+ _ = q(i, s),
+ l = [0],
+ f = 0;
+ if (!_) return;
+ if (D(o, [22, 84, 174, 107])) {
+ for (; l[0] < _.length;) {
+ var c = X(_, l),
+ h = q(_, l),
+ u = [0],
+ m = {
+ channels: 0,
+ sampleRate: 0
+ };
+ if (D(c, [174])) for (; u[0] < h.length;) {
+ var p = X(h, u),
+ b = q(h, u),
+ v = [0];
+ if (D(p, [215])) {
+ var d = Y(b);
+ m.number = d, a[d] = m;
+ } else if (D(p, [131])) {
+ var d = Y(b);
+ 1 == d ? m.type = "video" : 2 == d ? (m.type = "audio", f || (t.track0 = m), m.idx = f++) : m.type = "Type-" + d;
+ } else if (D(p, [134])) {
+ for (var g = "", S = 0; S < b.length; S++) g += String.fromCharCode(b[S]);
+ m.codec = g;
+ } else if (D(p, [225])) for (; v[0] < b.length;) {
+ var M = X(b, v),
+ w = q(b, v);
+ if (D(M, [181])) {
+ var d = 0,
+ R = new Uint8Array(w.reverse()).buffer;
+ 4 == w.length ? d = new Float32Array(R)[0] : 8 == w.length ? d = new Float64Array(R)[0] : H("WebM Track !Float", 1, w), m[N] = Math.round(d);
+ } else D(M, [98, 100]) ? m.bitDepth = Y(w) : D(M, [159]) && (m.channels = Y(w));
}
}
- t._ht = 1, O("WebM Tracks", a), s();
- break;
}
- }
- }
- var A = t.track0;
- if (A) {
- if (16 == A.bitDepth && /FLOAT/i.test(A.codec) && (A.bitDepth = 32, O("WebM 16->32 bit", 3)), A[D] != t[D] || 32 != A.bitDepth || A.channels < 1 || !/(\b|_)PCM\b/i.test(A.codec)) return t.bytes = [], t.bad || O("WebM Track Unexpected", 3, t), -(t.bad = 1);
- for (var k = [], R = 0; n[0] < i.length;) {
- var c = j(i, n),
- u = X(i, n);
- if (!u) break;
- if (H(c, [163])) {
- var x = 15 & u[0],
- b = a[x];
- if (b) {
- if (0 === b.idx) {
- for (var B = new Uint8Array(u.length - 4), w = 4; w < u.length; w++) B[w - 4] = u[w];
- k.push(B), R += B.length;
- }
- } else O("WebM !Track" + x, 1, a);
- }
- s();
- }
- if (R) {
- var T = new Uint8Array(i.length - t.pos[0]);
- T.set(i.subarray(t.pos[0])), t.bytes = T, t.pos[0] = 0;
- for (var B = new Uint8Array(R), w = 0, E = 0; w < k.length; w++) B.set(k[w], E), E += k[w].length;
- var y = new Float32Array(B.buffer);
- if (1 < A.channels) {
- for (var C = [], w = 0; w < y.length;) C.push(y[w]), w += A.channels;
- y = new Float32Array(C);
- }
- return y;
- }
- }
- },
- H = function (e, t) {
- if (!e || e.length != t.length) return !1;
- if (1 == e.length) return e[0] == t[0];
- for (var a = 0; a < e.length; a++) if (e[a] != t[a]) return !1;
- return !0;
- },
- F = function (e) {
- for (var t = "", a = 0; a < e.length; a++) {
- var n = e[a];
- t += (n < 16 ? "0" : "") + n.toString(16);
- }
- return parseInt(t, 16) || 0;
- },
- j = function (e, t, a) {
- var n = t[0];
- if (!(n >= e.length)) {
- var s = e[n],
- r = ("0000000" + s.toString(2)).substr(-8),
- i = /^(0*1)(\d*)$/.exec(r);
- if (i) {
- var o = i[1].length,
- _ = [];
- if (!(n + o > e.length)) {
- for (var l = 0; l < o; l++) _[l] = e[n], n++;
- return a && (_[0] = parseInt(i[2] || "0", 2)), t[0] = n, _;
- }
- }
- }
- },
- X = function (e, t) {
- var a = j(e, t, 1);
- if (a) {
- var n = F(a),
- s = t[0],
- r = [];
- if (n < 2147483647) {
- if (s + n > e.length) return;
- for (var i = 0; i < n; i++) r[i] = e[s], s++;
- }
- return t[0] = s, r;
- }
- },
- Y = N.i18n = {
- lang: "zh-CN",
- alias: {
- "zh-CN": "zh",
- "en-US": "en"
- },
- locales: {},
- data: {},
- put: function (e, t) {
- var a = R + ".i18n.put: ",
- n = e.overwrite;
- n = null == n || n;
- var s = e.lang;
- if (!(s = Y.alias[s] || s)) throw new Error(a + "set.lang?");
- var r = Y.locales[s];
- r || (r = {}, Y.locales[s] = r);
- for (var i, o = /^([\w\-]+):/, _ = 0; _ < t.length; _++) {
- var l = t[_];
- if (i = o.exec(l)) {
- var f = i[1],
- l = l.substr(f.length + 1);
- !n && r[f] || (r[f] = l);
- } else O(a + "'key:'? " + l, 3, e);
- }
- },
- get: function () {
- return Y.v_G.apply(null, arguments);
- },
- v_G: function (n, s, e) {
- s = s || [], e = e || Y.lang, e = Y.alias[e] || e;
- var t = Y.locales[e],
- r = t && t[n] || "";
- return r || "zh" == e ? (Y.lastLang = e, "=Empty" == r ? "" : r.replace(/\{(\d+)(\!?)\}/g, function (e, t, a) {
- return e = s[(t = +t || 0) - 1], (t < 1 || t > s.length) && (e = "{?}", O("i18n[" + n + "] no {" + t + "}: " + r, 3)), a ? "" : e;
- })) : "en" == e ? Y.v_G(n, s, "zh") : Y.v_G(n, s, "en");
- },
- $T: function () {
- return Y.v_T.apply(null, arguments);
- },
- v_T: function () {
- for (var e, t = arguments, a = "", n = [], s = 0, r = R + ".i18n.$T:", i = /^([\w\-]*):/, o = 0; o < t.length; o++) {
- var _ = t[o];
- if (0 == o) {
- if (e = i.exec(_), !(a = e && e[1])) throw new Error(r + "0 'key:'?");
- _ = _.substr(a.length + 1);
- }
- if (-1 === s) n.push(_);else {
- if (s) throw new Error(r + " bad args");
- if (0 === _) s = -1;else if (f(_)) {
- if (_ < 1) throw new Error(r + " bad args");
- s = _;
- } else {
- var l = 1 == o ? "en" : o ? "" : "zh";
- if ((e = i.exec(_)) && (l = e[1] || l, _ = _.substr(e[1].length + 1)), !e || !l) throw new Error(r + o + " 'lang:'?");
- Y.put({
- lang: l,
- overwrite: !1
- }, [a + ":" + _]);
- }
- }
- }
- return a ? 0 < s ? a : Y.v_G(a, n) : "";
- }
- },
- z = Y.$T;
- z.G = Y.get, z("NonBrowser-1::非浏览器环境,不支持{1}", 1), z("IllegalArgs-1::参数错误:{1}", 1), z("NeedImport-2::调用{1}需要先导入{2}", 2), z("NotSupport-1::不支持:{1}", 1), N.TrafficImgUrl = "//ia.51.la/go1?id=20469973&pvFlag=1";
- var u = N.Traffic = function (e) {
- if (w) {
- e = e ? "/" + R + "/Report/" + e : "";
- var t = N.TrafficImgUrl;
- if (t) {
- var a = N.Traffic,
- n = /^(https?:..[^\/#]*\/?)[^#]*/i.exec(location.href) || [],
- s = n[1] || "http://file/",
- r = (n[0] || s) + e;
- if (0 == t.indexOf("//") && (t = /^https:/i.test(r) ? "https:" + t : "http:" + t), e && (t = t + "&cu=" + encodeURIComponent(s + e)), !a[r]) {
- a[r] = 1;
- var i = new Image();
- i.src = t, O("Traffic Analysis Image: " + (e || R + ".TrafficImgUrl=" + N.TrafficImgUrl));
+ t._ht = 1, H("WebM Tracks", a), n();
+ break;
}
}
}
+ var A = t.track0;
+ if (A) {
+ if (16 == A.bitDepth && /FLOAT/i.test(A.codec) && (A.bitDepth = 32, H("WebM 16改32位", 3)), A[N] != t[N] || 32 != A.bitDepth || A.channels < 1 || !/(\b|_)PCM\b/i.test(A.codec)) return t.bytes = [], t.bad || H("WebM Track非预期", 3, t), -(t.bad = 1);
+ for (var B = [], k = 0; s[0] < i.length;) {
+ var c = X(i, s),
+ h = q(i, s);
+ if (!h) break;
+ if (D(c, [163])) {
+ var y = 15 & h[0],
+ m = a[y];
+ if (m) {
+ if (0 === m.idx) {
+ for (var T = new Uint8Array(h.length - 4), S = 4; S < h.length; S++) T[S - 4] = h[S];
+ B.push(T), k += T.length;
+ }
+ } else H("WebM !Track" + y, 1, a);
+ }
+ n();
+ }
+ if (k) {
+ var x = new Uint8Array(i.length - t.pos[0]);
+ x.set(i.subarray(t.pos[0])), t.bytes = x, t.pos[0] = 0;
+ for (var T = new Uint8Array(k), S = 0, E = 0; S < B.length; S++) T.set(B[S], E), E += B[S].length;
+ var R = new Float32Array(T.buffer);
+ if (1 < A.channels) {
+ for (var P = [], S = 0; S < R.length;) P.push(R[S]), S += A.channels;
+ R = new Float32Array(P);
+ }
+ return R;
+ }
+ }
+ },
+ D = function (e, t) {
+ if (!e || e.length != t.length) return !1;
+ if (1 == e.length) return e[0] == t[0];
+ for (var a = 0; a < e.length; a++) if (e[a] != t[a]) return !1;
+ return !0;
+ },
+ Y = function (e) {
+ for (var t = "", a = 0; a < e.length; a++) {
+ var s = e[a];
+ t += (s < 16 ? "0" : "") + s.toString(16);
+ }
+ return parseInt(t, 16) || 0;
+ },
+ X = function (e, t, a) {
+ var s = t[0];
+ if (!(s >= e.length)) {
+ var n = e[s],
+ r = ("0000000" + n.toString(2)).substr(-8),
+ i = /^(0*1)(\d*)$/.exec(r);
+ if (i) {
+ var o = i[1].length,
+ _ = [];
+ if (!(s + o > e.length)) {
+ for (var l = 0; l < o; l++) _[l] = e[s], s++;
+ return a && (_[0] = parseInt(i[2] || "0", 2)), t[0] = s, _;
+ }
+ }
+ }
+ },
+ q = function (e, t) {
+ var a = X(e, t, 1);
+ if (a) {
+ var s = Y(a),
+ n = t[0],
+ r = [];
+ if (s < 2147483647) {
+ if (n + s > e.length) return;
+ for (var i = 0; i < s; i++) r[i] = e[n], n++;
+ }
+ return t[0] = n, r;
+ }
};
- t && (O(z("8HO5::覆盖导入{1}", 0, R), 1), t.Destroy());
- e[R] = N;
- }(a, t), module.exports && (module.exports = a.Recorder);
-}(), function (e) {
- var t = "object" == typeof window && !!window.document,
- a = (t ? window : Object).Recorder,
- n = a.i18n;
- !function (m, e, u, t) {
+ V.TrafficImgUrl = "//ia.51.la/go1?id=20469973&pvFlag=1";
+ var r = V.Traffic = function (e) {
+ e = e ? "/" + T + "/Report/" + e : "";
+ var t = V.TrafficImgUrl;
+ if (t) {
+ var a = V.Traffic,
+ s = /^(https?:..[^\/#]*\/?)[^#]*/i.exec(location.href) || [],
+ n = s[1] || "http://file/",
+ r = (s[0] || n) + e;
+ if (0 == t.indexOf("//") && (t = /^https:/i.test(r) ? "https:" + t : "http:" + t), e && (t = t + "&cu=" + encodeURIComponent(n + e)), !a[r]) {
+ a[r] = 1;
+ var i = new Image();
+ i.src = t, H("Traffic Analysis Image: " + (e || T + ".TrafficImgUrl=" + V.TrafficImgUrl));
+ }
+ }
+ };
+}(window), module.exports && (module.exports = Recorder), function () {
- var o = "48000, 44100, 32000, 24000, 22050, 16000, 12000, 11025, 8000",
- _ = "8, 16, 24, 32, 40, 48, 56, 64, 80, 96, 112, 128, 144, 160, 192, 224, 256, 320";
- m.prototype.enc_mp3 = {
- stable: !0,
- takeEC: "full",
- getTestMsg: function () {
- return u("Zm7L::采样率范围:{1};比特率范围:{2}(不同比特率支持的采样率范围不同,小于32kbps时采样率需小于32000)", 0, o, _);
- }
- };
- var h,
- v = function (e) {
- var t = e.bitRate,
- a = e.sampleRate,
- n = a;
- if (-1 == (" " + _ + ",").indexOf(" " + t + ",") && m.CLog(u("eGB9::{1}不在mp3支持的取值范围:{2}", 0, "bitRate=" + t, _), 3), -1 == (" " + o + ",").indexOf(" " + a + ",")) {
- for (var s = o.split(", "), r = [], i = 0; i < s.length; i++) r.push({
- v: +s[i],
- s: Math.abs(s[i] - a)
- });
- r.sort(function (e, t) {
- return e.s - t.s;
- }), n = r[0].v, e.sampleRate = n, m.CLog(u("zLTa::sampleRate已更新为{1},因为{2}不在mp3支持的取值范围:{3}", 0, n, a, o), 3);
+ var i;
+ Recorder.prototype.enc_mp3 = {
+ stable: !0,
+ testmsg: "采样率范围48000, 44100, 32000, 24000, 22050, 16000, 12000, 11025, 8000"
+ }, Recorder.prototype.mp3 = function (a, s, e) {
+ var n = this.set,
+ r = a.length,
+ t = this.mp3_start(n);
+ if (t) return this.mp3_encode(t, a), void this.mp3_complete(t, s, e, 1);
+ var i = new Recorder.lamejs.Mp3Encoder(1, n.sampleRate, n.bitRate),
+ o = [],
+ _ = 0,
+ l = 0,
+ f = function () {
+ if (_ < r) {
+ 0 < (e = i.encodeBuffer(a.subarray(_, _ + 57600))).length && (l += e.buffer.byteLength, o.push(e.buffer)), _ += 57600, setTimeout(f);
+ } else {
+ var e;
+ 0 < (e = i.flush()).length && (l += e.buffer.byteLength, o.push(e.buffer));
+ var t = c.fn(o, l, r, n.sampleRate);
+ h(t, n), s(new Blob(o, {
+ type: "audio/mp3"
+ }));
}
- },
- n = function () {
- return u.G("NeedImport-2", ["mp3.js", "src/engine/mp3-engine.js"]);
- },
- d = t && "function" == typeof Worker;
- m.prototype.mp3 = function (r, i, o) {
- var e = this,
- _ = e.set,
- l = r.length;
- if (m.lamejs) {
- if (d) {
- var t = e.mp3_start(_);
- if (t) {
- if (t.isW) return e.mp3_encode(t, r), void e.mp3_complete(t, i, o, 1);
- e.mp3_stop(t);
- }
- }
- v(_);
- var f = new m.lamejs.Mp3Encoder(1, _.sampleRate, _.bitRate),
- c = new Int8Array(5e5),
- u = 0,
- h = 0,
- b = 0,
- p = function () {
- try {
- if (h < l) var e = f.encodeBuffer(r.subarray(h, h + 57600));else {
- b = 1;
- var e = f.flush();
- }
- } catch (e) {
- if (console.error(e), !b) try {
- f.flush();
- } catch (e) {
- console.error(e);
- }
- return void o("MP3 Encoder: " + e.message);
- }
- var t = e.length;
- if (0 < t) {
- if (u + t > c.length) {
- var a = new Int8Array(c.length + Math.max(5e5, t));
- a.set(c.subarray(0, u)), c = a;
- }
- c.set(e, u), u += t;
- }
- if (h < l) h += 57600, setTimeout(p);else {
- var n = [c.buffer.slice(0, u)],
- s = g.fn(n, u, l, _.sampleRate);
- w(s, _), i(n[0] || new ArrayBuffer(0), "audio/mp3");
- }
- };
- p();
- } else o(n());
- }, m.BindDestroy("mp3Worker", function () {
- h && (m.CLog("mp3Worker Destroy"), h.terminate(), h = null);
- }), m.prototype.mp3_envCheck = function (e, t) {
- var a = "";
- return t.takeoffEncodeChunk && (p() || (a = u("yhUs::当前浏览器版本太低,无法实时处理"))), a || m.lamejs || (a = n()), a;
- }, m.prototype.mp3_start = function (e) {
- return p(e);
- };
- var b = {
- id: 0
- },
- p = function (t, e) {
- var f,
- a = function (e) {
+ };
+ f();
+ }, Recorder.BindDestroy("mp3Worker", function () {
+ Recorder.CLog("mp3Worker Destroy"), i && i.terminate(), i = null;
+ }), Recorder.prototype.mp3_envCheck = function (e, t) {
+ var a = "";
+ return t.takeoffEncodeChunk && (e.canProcess ? s() || (a = "当前浏览器版本太低,无法实时处理") : a = e.envName + "环境不支持实时处理"), a;
+ }, Recorder.prototype.mp3_start = function (e) {
+ return s(e);
+ };
+ var o = {
+ id: 0
+ },
+ s = function (e) {
+ var t = i;
+ try {
+ if (!t) {
+ var a = ");wk_lame();var wk_ctxs={};self.onmessage=" + function (e) {
var t = e.data,
- a = f.wkScope.wk_ctxs,
- n = f.wkScope.wk_lame,
- s = f.wkScope.wk_mp3TrimFix,
- r = a[t.id];
- if ("init" == t.action) a[t.id] = {
+ a = wk_ctxs[t.id];
+ if ("init" == t.action) wk_ctxs[t.id] = {
sampleRate: t.sampleRate,
bitRate: t.bitRate,
takeoff: t.takeoff,
+ mp3Size: 0,
pcmSize: 0,
- memory: new Int8Array(5e5),
- mOffset: 0,
- encObj: new n.Mp3Encoder(1, t.sampleRate, t.bitRate)
- };else if (!r) return;
- var i = function (e) {
- var t = e.length;
- if (r.mOffset + t > r.memory.length) {
- var a = new Int8Array(r.memory.length + Math.max(5e5, t));
- a.set(r.memory.subarray(0, r.mOffset)), r.memory = a;
- }
- r.memory.set(e, r.mOffset), r.mOffset += t;
- };
+ encArr: [],
+ encObj: new wk_lame.Mp3Encoder(1, t.sampleRate, t.bitRate)
+ };else if (!a) return;
switch (t.action) {
case "stop":
- if (!r.isCp) try {
- r.encObj.flush();
- } catch (e) {
- console.error(e);
- }
- r.encObj = null, delete a[t.id];
+ a.encObj = null, delete wk_ctxs[t.id];
break;
case "encode":
- if (r.isCp) break;
- r.pcmSize += t.pcm.length;
- try {
- var o = r.encObj.encodeBuffer(t.pcm);
- } catch (e) {
- r.err = e, console.error(e);
- }
- o && 0 < o.length && (r.takeoff ? c.onmessage({
+ a.pcmSize += t.pcm.length, 0 < (s = a.encObj.encodeBuffer(t.pcm)).length && (a.takeoff ? self.postMessage({
action: "takeoff",
id: t.id,
- chunk: o
- }) : i(o));
+ chunk: s
+ }) : (a.mp3Size += s.buffer.byteLength, a.encArr.push(s.buffer)));
break;
case "complete":
- r.isCp = 1;
- try {
- var o = r.encObj.flush();
- } catch (e) {
- r.err = e, console.error(e);
- }
- if (o && 0 < o.length && (r.takeoff ? c.onmessage({
+ var s;
+ 0 < (s = a.encObj.flush()).length && (a.takeoff ? self.postMessage({
action: "takeoff",
id: t.id,
- chunk: o
- }) : i(o)), r.err) {
- c.onmessage({
- action: t.action,
- id: t.id,
- err: "MP3 Encoder: " + r.err.message
- });
- break;
- }
- var _ = [r.memory.buffer.slice(0, r.mOffset)],
- l = s.fn(_, r.mOffset, r.pcmSize, r.sampleRate);
- c.onmessage({
+ chunk: s
+ }) : (a.mp3Size += s.buffer.byteLength, a.encArr.push(s.buffer)));
+ var n = wk_mp3TrimFix.fn(a.encArr, a.mp3Size, a.pcmSize, a.sampleRate);
+ self.postMessage({
action: t.action,
id: t.id,
- blob: _[0] || new ArrayBuffer(0),
- meta: l
+ blob: new Blob(a.encArr, {
+ type: "audio/mp3"
+ }),
+ meta: n
});
}
- },
- n = function (n) {
- c.onmessage = function (e) {
- var t = e;
- n && (t = e.data);
- var a = b[t.id];
- a && ("takeoff" == t.action ? a.set.takeoffEncodeChunk(new Uint8Array(t.chunk.buffer)) : (a.call && a.call(t), a.call = null));
- };
- },
- s = function () {
- var e = {
- worker: c,
- set: t
- };
- return t ? (e.id = ++b.id, b[e.id] = e, v(t), c.postMessage({
- action: "init",
- id: e.id,
- sampleRate: t.sampleRate,
- bitRate: t.bitRate,
- takeoff: !!t.takeoffEncodeChunk,
- x: new Int16Array(5)
- })) : c.postMessage({
- x: new Int16Array(5)
- }), e;
- },
- c = h;
- if (e || !d) return m.CLog(u("k9PT::当前环境不支持Web Worker,mp3实时编码器运行在主线程中"), 3), c = {
- postMessage: function (e) {
- a({
- data: e
- });
- }
- }, f = {
- wkScope: {
- wk_ctxs: {},
- wk_lame: m.lamejs,
- wk_mp3TrimFix: g
- }
- }, n(), s();
- try {
- if (!c) {
- var r = (a + "").replace(/[\w\$]+\.onmessage/g, "self.postMessage"),
- i = ");wk_lame();self.onmessage=" + (r = r.replace(/[\w\$]+\.wkScope/g, "wkScope"));
- i += ";var wkScope={ wk_ctxs:{},wk_lame:wk_lame", i += ",wk_mp3TrimFix:{rm:" + g.rm + ",fn:" + g.fn + "} }";
- var o = m.lamejs.toString(),
- _ = (window.URL || webkitURL).createObjectURL(new Blob(["var wk_lame=(", o, i], {
- type: "text/javascript"
- }));
- c = new Worker(_), setTimeout(function () {
- (window.URL || webkitURL).revokeObjectURL(_);
- }, 1e4), n(1);
- }
- var l = s();
- return l.isW = 1, h = c, l;
- } catch (e) {
- return c && c.terminate(), console.error(e), p(t, 1);
- }
- };
- m.prototype.mp3_stop = function (e) {
- if (e && e.worker) {
- e.worker.postMessage({
- action: "stop",
- id: e.id
- }), e.worker = null, delete b[e.id];
- var t = -1;
- for (var a in b) t++;
- t && m.CLog(u("fT6M::mp3 worker剩{1}个未stop", 0, t), 3);
- }
- }, m.prototype.mp3_encode = function (e, t) {
- e && e.worker && e.worker.postMessage({
- action: "encode",
- id: e.id,
- pcm: t
- });
- }, m.prototype.mp3_complete = function (t, a, n, s) {
- var r = this;
- t && t.worker ? (t.call = function (e) {
- s && r.mp3_stop(t), e.err ? n(e.err) : (w(e.meta, t.set), a(e.blob, "audio/mp3"));
- }, t.worker.postMessage({
- action: "complete",
- id: t.id
- })) : n(u("mPxH::mp3编码器未start"));
- }, m.mp3ReadMeta = function (e, t) {
- var a = "undefined" != typeof window && window.parseInt || "undefined" != typeof self && self.parseInt || parseInt,
- n = new Uint8Array(e[0] || []);
- if (n.length < 4) return null;
- var s = function (e, t) {
- return ("0000000" + ((t || n)[e] || 0).toString(2)).substr(-8);
- },
- r = s(0) + s(1),
- i = s(2) + s(3);
- if (!/^1{11}/.test(r)) return null;
- var o = {
- "00": 2.5,
- 10: 2,
- 11: 1
- }[r.substr(11, 2)],
- _ = {
- "01": 3
- }[r.substr(13, 2)],
- l = {
- 1: [44100, 48e3, 32e3],
- 2: [22050, 24e3, 16e3],
- 2.5: [11025, 12e3, 8e3]
- }[o];
- l && (l = l[a(i.substr(4, 2), 2)]);
- var f = [[0, 8, 16, 24, 32, 40, 48, 56, 64, 80, 96, 112, 128, 144, 160], [0, 32, 40, 48, 56, 64, 80, 96, 112, 128, 160, 192, 224, 256, 320]][1 == o ? 1 : 0][a(i.substr(0, 4), 2)];
- if (!(o && _ && f && l)) return null;
- for (var c = Math.round(8 * t / f), u = 1 == _ ? 384 : 2 == _ ? 1152 : 1 == o ? 1152 : 576, h = u / l * 1e3, b = Math.floor(u * f / 8 / l * 1e3), p = 0, m = 0, v = 0; v < e.length; v++) {
- var d = e[v];
- if (m += d.byteLength, b + 3 <= m) {
- var g = new Uint8Array(d),
- w = d.byteLength - (m - (b + 3) + 1),
- S = s(w, g);
- p = "1" == S.charAt(6);
- break;
- }
- }
- return p && b++, {
- version: o,
- layer: _,
- sampleRate: l,
- bitRate: f,
- duration: c,
- size: t,
- hasPadding: p,
- frameSize: b,
- frameDurationFloat: h
- };
- };
- var g = {
- rm: m.mp3ReadMeta,
- fn: function (e, t, a, n) {
- var s = this.rm(e, t);
- if (!s) return {
- err: "mp3 unknown format"
};
- var r = Math.round(a / n * 1e3),
- i = Math.floor((s.duration - r) / s.frameDurationFloat);
- if (0 < i) {
- var o = i * s.frameSize - (s.hasPadding ? 1 : 0);
- t -= o;
- for (var _ = 0, l = [], f = 0; f < e.length; f++) {
- var c = e[f];
- if (o <= 0) break;
- o >= c.byteLength ? (o -= c.byteLength, l.push(c), e.splice(f, 1), f--) : (e[f] = c.slice(o), _ = c, o = 0);
- }
- var u = this.rm(e, t);
- if (!u) {
- _ && (e[0] = _);
- for (var f = 0; f < l.length; f++) e.splice(f, 0, l[f]);
- s.err = "mp3 fix error: 已还原,错误原因不明";
- }
- var h = s.trimFix = {};
- h.remove = i, h.removeDuration = Math.round(i * s.frameDurationFloat), h.duration = Math.round(8 * t / s.bitRate);
- }
- return s;
+ a += ";var wk_mp3TrimFix={rm:" + c.rm + ",fn:" + c.fn + "}";
+ var s = Recorder.lamejs.toString(),
+ n = (window.URL || webkitURL).createObjectURL(new Blob(["var wk_lame=(", s, a], {
+ type: "text/javascript"
+ }));
+ t = new Worker(n), setTimeout(function () {
+ (window.URL || webkitURL).revokeObjectURL(n);
+ }, 1e4), t.onmessage = function (e) {
+ var t = e.data,
+ a = o[t.id];
+ a && ("takeoff" == t.action ? a.set.takeoffEncodeChunk(new Uint8Array(t.chunk.buffer)) : (a.call && a.call(t), a.call = null));
+ };
}
+ var r = {
+ worker: t,
+ set: e,
+ takeoffQueue: []
+ };
+ return e ? (r.id = ++o.id, o[r.id] = r, t.postMessage({
+ action: "init",
+ id: r.id,
+ sampleRate: e.sampleRate,
+ bitRate: e.bitRate,
+ takeoff: !!e.takeoffEncodeChunk,
+ x: new Int16Array(5)
+ })) : t.postMessage({
+ x: new Int16Array(5)
+ }), i = t, r;
+ } catch (e) {
+ return t && t.terminate(), console.error(e), null;
+ }
+ };
+ Recorder.prototype.mp3_stop = function (e) {
+ if (e && e.worker) {
+ e.worker.postMessage({
+ action: "stop",
+ id: e.id
+ }), e.worker = null, delete o[e.id];
+ var t = -1;
+ for (var a in o) t++;
+ t && Recorder.CLog("mp3 worker剩" + t + "个在串行等待", 3);
+ }
+ }, Recorder.prototype.mp3_encode = function (e, t) {
+ e && e.worker && e.worker.postMessage({
+ action: "encode",
+ id: e.id,
+ pcm: t
+ });
+ }, Recorder.prototype.mp3_complete = function (t, a, e, s) {
+ var n = this;
+ t && t.worker ? (t.call = function (e) {
+ h(e.meta, t.set), a(e.blob), s && n.mp3_stop(t);
+ }, t.worker.postMessage({
+ action: "complete",
+ id: t.id
+ })) : e("mp3编码器未打开");
+ }, Recorder.mp3ReadMeta = function (e, t) {
+ var a = "object" == typeof window ? window.parseInt : self.parseInt,
+ s = new Uint8Array(e[0] || []);
+ if (s.length < 4) return null;
+ var n = function (e, t) {
+ return ("0000000" + ((t || s)[e] || 0).toString(2)).substr(-8);
},
- w = function (e, t) {
- var a = "MP3 Info: ";
- (e.sampleRate && e.sampleRate != t.sampleRate || e.bitRate && e.bitRate != t.bitRate) && (m.CLog(a + u("uY9i::和设置的不匹配{1},已更新成{2}", 0, "set:" + t.bitRate + "kbps " + t.sampleRate + "hz", "set:" + e.bitRate + "kbps " + e.sampleRate + "hz"), 3, t), t.sampleRate = e.sampleRate, t.bitRate = e.bitRate);
- var n = e.trimFix;
- n ? (a += u("iMSm::Fix移除{1}帧", 0, n.remove) + " " + n.removeDuration + "ms -> " + n.duration + "ms", 2 < n.remove && (e.err = (e.err ? e.err + ", " : "") + u("b9zm::移除帧数过多"))) : a += (e.duration || "-") + "ms", e.err ? m.CLog(a, 1, e.err, e) : m.CLog(a, e);
- };
- }(a, 0, n.$T, t);
-}(), function (e) {
+ r = n(0) + n(1),
+ i = n(2) + n(3);
+ if (!/^1{11}/.test(r)) return null;
+ var o = {
+ "00": 2.5,
+ 10: 2,
+ 11: 1
+ }[r.substr(11, 2)],
+ _ = {
+ "01": 3
+ }[r.substr(13, 2)],
+ l = {
+ 1: [44100, 48e3, 32e3],
+ 2: [22050, 24e3, 16e3],
+ 2.5: [11025, 12e3, 8e3]
+ }[o];
+ l && (l = l[a(i.substr(4, 2), 2)]);
+ var f = [[0, 8, 16, 24, 32, 40, 48, 56, 64, 80, 96, 112, 128, 144, 160], [0, 32, 40, 48, 56, 64, 80, 96, 112, 128, 160, 192, 224, 256, 320]][1 == o ? 1 : 0][a(i.substr(0, 4), 2)];
+ if (!(o && _ && f && l)) return null;
+ for (var c = Math.round(8 * t / f), h = 1 == _ ? 384 : 2 == _ ? 1152 : 1 == o ? 1152 : 576, u = h / l * 1e3, m = Math.floor(h * f / 8 / l * 1e3), p = 0, b = 0, v = 0; v < e.length; v++) {
+ var d = e[v];
+ if (m + 3 <= (b += d.byteLength)) {
+ var g = new Uint8Array(d);
+ p = "1" == n(d.byteLength - (b - (m + 3) + 1), g).charAt(6);
+ break;
+ }
+ }
+ return p && m++, {
+ version: o,
+ layer: _,
+ sampleRate: l,
+ bitRate: f,
+ duration: c,
+ size: t,
+ hasPadding: p,
+ frameSize: m,
+ frameDurationFloat: u
+ };
+ };
+ var c = {
+ rm: Recorder.mp3ReadMeta,
+ fn: function (e, t, a, s) {
+ var n = this.rm(e, t);
+ if (!n) return {
+ err: "mp3非预定格式"
+ };
+ var r = Math.round(a / s * 1e3),
+ i = Math.floor((n.duration - r) / n.frameDurationFloat);
+ if (0 < i) {
+ var o = i * n.frameSize - (n.hasPadding ? 1 : 0);
+ t -= o;
+ for (var _ = 0, l = [], f = 0; f < e.length; f++) {
+ var c = e[f];
+ if (o <= 0) break;
+ o >= c.byteLength ? (o -= c.byteLength, l.push(c), e.splice(f, 1), f--) : (e[f] = c.slice(o), _ = c, o = 0);
+ }
+ if (!this.rm(e, t)) {
+ _ && (e[0] = _);
+ for (f = 0; f < l.length; f++) e.splice(f, 0, l[f]);
+ n.err = "fix后数据错误,已还原,错误原因不明";
+ }
+ var h = n.trimFix = {};
+ h.remove = i, h.removeDuration = Math.round(i * n.frameDurationFloat), h.duration = Math.round(8 * t / n.bitRate);
+ }
+ return n;
+ }
+ },
+ h = function (e, t) {
+ var a = "MP3信息 ";
+ (e.sampleRate && e.sampleRate != t.sampleRate || e.bitRate && e.bitRate != t.bitRate) && (Recorder.CLog(a + "和设置的不匹配set:" + t.bitRate + "kbps " + t.sampleRate + "hz,已更新set:" + e.bitRate + "kbps " + e.sampleRate + "hz", 3, t), t.sampleRate = e.sampleRate, t.bitRate = e.bitRate);
+ var s = e.trimFix;
+ s ? (a += "Fix移除" + s.remove + "帧" + s.removeDuration + "ms -> " + s.duration + "ms", 2 < s.remove && (e.err = (e.err ? e.err + ", " : "") + "移除帧数过多")) : a += (e.duration || "-") + "ms", e.err ? Recorder.CLog(a, 1, e.err, e) : Recorder.CLog(a, e);
+ };
+}(), function () {
function t() {
- var d = function (e) {
- return Math.log(e) / Math.log(10);
- },
- me = function (e) {
- throw new Error("abort(" + e + ")");
- };
- function S(e) {
+ var B = function (e) {
+ return Math.log(e) / Math.log(10);
+ };
+ function A(e) {
return new Int8Array(e);
}
- function s(e) {
+ function n(e) {
return new Int16Array(e);
}
- function ve(e) {
+ function Ae(e) {
return new Int32Array(e);
}
- function de(e) {
+ function Be(e) {
return new Float32Array(e);
}
- function n(e) {
+ function s(e) {
return new Float64Array(e);
}
- function ge(e) {
- if (1 == e.length) return de(e[0]);
+ function ke(e) {
+ if (1 == e.length) return Be(e[0]);
var t = e[0];
e = e.slice(1);
- for (var a = [], n = 0; n < t; n++) a.push(ge(e));
+ for (var a = [], s = 0; s < t; s++) a.push(ke(e));
return a;
}
- function w(e) {
- if (1 == e.length) return ve(e[0]);
+ function Y(e) {
+ if (1 == e.length) return Ae(e[0]);
var t = e[0];
e = e.slice(1);
- for (var a = [], n = 0; n < t; n++) a.push(w(e));
+ for (var a = [], s = 0; s < t; s++) a.push(Y(e));
return a;
}
- function M(e) {
- if (1 == e.length) return s(e[0]);
+ function p(e) {
+ if (1 == e.length) return n(e[0]);
var t = e[0];
e = e.slice(1);
- for (var a = [], n = 0; n < t; n++) a.push(M(e));
+ for (var a = [], s = 0; s < t; s++) a.push(p(e));
return a;
}
- function E(e) {
+ function O(e) {
if (1 == e.length) return new Array(e[0]);
var t = e[0];
e = e.slice(1);
- for (var a = [], n = 0; n < t; n++) a.push(E(e));
+ for (var a = [], s = 0; s < t; s++) a.push(O(e));
return a;
}
- var we = {
- fill: function (e, t, a, n) {
- if (2 == arguments.length) for (var s = 0; s < e.length; s++) e[s] = t;else for (var s = t; s < a; s++) e[s] = n;
+ var ye = {
+ fill: function (e, t, a, s) {
+ if (2 == arguments.length) for (var n = 0; n < e.length; n++) e[n] = t;else for (n = t; n < a; n++) e[n] = s;
}
},
- I = {
- arraycopy: function (e, t, a, n, s) {
- for (var r = t + s; t < r;) a[n++] = e[t++];
+ $ = {
+ arraycopy: function (e, t, a, s, n) {
+ for (var r = t + n; t < r;) a[s++] = e[t++];
}
},
- V = {};
- function Se(e) {
+ ee = {};
+ function Te(e) {
this.ordinal = e;
}
- V.SQRT2 = 1.4142135623730951, V.FAST_LOG10 = function (e) {
- return d(e);
- }, V.FAST_LOG10_X = function (e, t) {
- return d(e) * t;
- }, Se.short_block_allowed = new Se(0), Se.short_block_coupled = new Se(1), Se.short_block_dispensed = new Se(2), Se.short_block_forced = new Se(3);
- var D = {};
- function Me(e) {
+ ee.SQRT2 = 1.4142135623730951, ee.FAST_LOG10 = function (e) {
+ return B(e);
+ }, ee.FAST_LOG10_X = function (e, t) {
+ return B(e) * t;
+ }, Te.short_block_allowed = new Te(0), Te.short_block_coupled = new Te(1), Te.short_block_dispensed = new Te(2), Te.short_block_forced = new Te(3);
+ var K = {};
+ function xe(e) {
this.ordinal = e;
}
- function ye(e) {
+ K.MAX_VALUE = 3.4028235e38, xe.vbr_off = new xe(0), xe.vbr_mt = new xe(1), xe.vbr_rh = new xe(2), xe.vbr_abr = new xe(3), xe.vbr_mtrh = new xe(4), xe.vbr_default = xe.vbr_mtrh;
+ function Ee(e) {
var t = e;
this.ordinal = function () {
return t;
};
}
- function A() {
- var S = null;
+ function k() {
+ var M = null;
function v(e) {
this.bits = 0 | e;
}
this.qupvt = null, this.setModules = function (e) {
- this.qupvt = e, S = e;
+ this.qupvt = e, M = e;
};
- var s = [[0, 0], [0, 0], [0, 0], [0, 0], [0, 0], [0, 1], [1, 1], [1, 1], [1, 2], [2, 2], [2, 3], [2, 3], [3, 4], [3, 4], [3, 4], [4, 5], [4, 5], [4, 6], [5, 6], [5, 6], [5, 7], [6, 7], [6, 7]];
- function M(e, t, a, n, s, r) {
+ var n = [[0, 0], [0, 0], [0, 0], [0, 0], [0, 0], [0, 1], [1, 1], [1, 1], [1, 2], [2, 2], [2, 3], [2, 3], [3, 4], [3, 4], [3, 4], [4, 5], [4, 5], [4, 6], [5, 6], [5, 6], [5, 7], [6, 7], [6, 7]];
+ function w(e, t, a, s, n, r) {
var i = .5946 / t;
- for (e >>= 1; 0 != e--;) s[r++] = i > a[n++] ? 0 : 1, s[r++] = i > a[n++] ? 0 : 1;
+ for (e >>= 1; 0 != e--;) n[r++] = i > a[s++] ? 0 : 1, n[r++] = i > a[s++] ? 0 : 1;
}
- function y(e, t, a, n, s, r) {
+ function R(e, t, a, s, n, r) {
var i = (e >>= 1) % 2;
for (e >>= 1; 0 != e--;) {
- var o, _, l, f, c, u, h, b;
- o = a[n++] * t, _ = a[n++] * t, c = 0 | o, l = a[n++] * t, u = 0 | _, f = a[n++] * t, h = 0 | l, o += S.adj43[c], b = 0 | f, _ += S.adj43[u], s[r++] = 0 | o, l += S.adj43[h], s[r++] = 0 | _, f += S.adj43[b], s[r++] = 0 | l, s[r++] = 0 | f;
+ var o, _, l, f, c, h, u, m;
+ o = a[s++] * t, _ = a[s++] * t, c = 0 | o, l = a[s++] * t, h = 0 | _, f = a[s++] * t, u = 0 | l, o += M.adj43[c], m = 0 | f, _ += M.adj43[h], n[r++] = 0 | o, l += M.adj43[u], n[r++] = 0 | _, f += M.adj43[m], n[r++] = 0 | l, n[r++] = 0 | f;
}
- 0 != i && (o = a[n++] * t, _ = a[n++] * t, c = 0 | o, u = 0 | _, o += S.adj43[c], _ += S.adj43[u], s[r++] = 0 | o, s[r++] = 0 | _);
+ 0 != i && (c = 0 | (o = a[s++] * t), h = 0 | (_ = a[s++] * t), o += M.adj43[c], _ += M.adj43[h], n[r++] = 0 | o, n[r++] = 0 | _);
}
var o = [1, 2, 5, 7, 7, 10, 10, 13, 13, 13, 13, 13, 13, 13, 13];
- function d(e, t, a, n) {
- var s = function (e, t, a) {
- var n = 0,
- s = 0;
+ function d(e, t, a, s) {
+ var n = function (e, t, a) {
+ var s = 0,
+ n = 0;
do {
var r = e[t++],
i = e[t++];
- n < r && (n = r), s < i && (s = i);
+ s < r && (s = r), n < i && (n = i);
} while (t < a);
- return n < s && (n = s), n;
+ return s < n && (s = n), s;
}(e, t, a);
- switch (s) {
+ switch (n) {
case 0:
- return s;
+ return n;
case 1:
- return function (e, t, a, n) {
- var s = 0,
- r = k.ht[1].hlen;
+ return function (e, t, a, s) {
+ var n = 0,
+ r = F.ht[1].hlen;
do {
var i = 2 * e[t + 0] + e[t + 1];
- t += 2, s += r[i];
+ t += 2, n += r[i];
} while (t < a);
- return n.bits += s, 1;
- }(e, t, a, n);
+ return s.bits += n, 1;
+ }(e, t, a, s);
case 2:
case 3:
- return function (e, t, a, n, s) {
+ return function (e, t, a, s, n) {
var r,
i,
o = 0,
- _ = k.ht[n].xlen;
- i = 2 == n ? k.table23 : k.table56;
+ _ = F.ht[s].xlen;
+ i = 2 == s ? F.table23 : F.table56;
do {
var l = e[t + 0] * _ + e[t + 1];
t += 2, o += i[l];
} while (t < a);
- return (r = 65535 & o) < (o >>= 16) && (o = r, n++), s.bits += o, n;
- }(e, t, a, o[s - 1], n);
+ return (r = 65535 & o) < (o >>= 16) && (o = r, s++), n.bits += o, s;
+ }(e, t, a, o[n - 1], s);
case 4:
case 5:
case 6:
@@ -13457,84 +13106,86 @@ src: recorder-core.js,engine/mp3.js,engine/mp3-engine.js
case 13:
case 14:
case 15:
- return function (e, t, a, n, s) {
+ return function (e, t, a, s, n) {
var r = 0,
i = 0,
o = 0,
- _ = k.ht[n].xlen,
- l = k.ht[n].hlen,
- f = k.ht[n + 1].hlen,
- c = k.ht[n + 2].hlen;
+ _ = F.ht[s].xlen,
+ l = F.ht[s].hlen,
+ f = F.ht[s + 1].hlen,
+ c = F.ht[s + 2].hlen;
do {
- var u = e[t + 0] * _ + e[t + 1];
- t += 2, r += l[u], i += f[u], o += c[u];
+ var h = e[t + 0] * _ + e[t + 1];
+ t += 2, r += l[h], i += f[h], o += c[h];
} while (t < a);
- var h = n;
- return i < r && (r = i, h++), o < r && (r = o, h = n + 2), s.bits += r, h;
- }(e, t, a, o[s - 1], n);
+ var u = s;
+ return i < r && (r = i, u++), o < r && (r = o, u = s + 2), n.bits += r, u;
+ }(e, t, a, o[n - 1], s);
default:
+ if (x.IXMAX_VAL < n) return s.bits = x.LARGE_BITS, -1;
var r, i;
- for (T.IXMAX_VAL < s && me(), s -= 15, r = 24; r < 32 && !(k.ht[r].linmax >= s); r++);
- for (i = r - 8; i < 24 && !(k.ht[i].linmax >= s); i++);
- return function (e, t, a, n, s, r) {
+ for (n -= 15, r = 24; r < 32 && !(F.ht[r].linmax >= n); r++);
+ for (i = r - 8; i < 24 && !(F.ht[i].linmax >= n); i++);
+ return function (e, t, a, s, n, r) {
var i,
- o = 65536 * k.ht[n].xlen + k.ht[s].xlen,
+ o = 65536 * F.ht[s].xlen + F.ht[n].xlen,
_ = 0;
do {
var l = e[t++],
f = e[t++];
- 0 != l && (14 < l && (l = 15, _ += o), l *= 16), 0 != f && (14 < f && (f = 15, _ += o), l += f), _ += k.largetbl[l];
+ 0 != l && (14 < l && (l = 15, _ += o), l *= 16), 0 != f && (14 < f && (f = 15, _ += o), l += f), _ += F.largetbl[l];
} while (t < a);
- return (i = 65535 & _) < (_ >>= 16) && (_ = i, n = s), r.bits += _, n;
- }(e, t, a, i, r, n);
+ return (i = 65535 & _) < (_ >>= 16) && (_ = i, s = n), r.bits += _, s;
+ }(e, t, a, i, r, s);
}
}
- function h(e, t, a, n, s, r, i, o) {
- for (var _ = t.big_values, l = 2; l < Ae.SBMAX_l + 1; l++) {
+ function u(e, t, a, s, n, r, i, o) {
+ for (var _ = t.big_values, l = 2; l < Pe.SBMAX_l + 1; l++) {
var f = e.scalefac_band.l[l];
if (_ <= f) break;
- var c = s[l - 2] + t.count1bits;
+ var c = n[l - 2] + t.count1bits;
if (a.part2_3_length <= c) break;
- var u = new v(c),
- h = d(n, f, _, u);
- c = u.bits, a.part2_3_length <= c || (a.assign(t), a.part2_3_length = c, a.region0_count = r[l - 2], a.region1_count = l - 2 - r[l - 2], a.table_select[0] = i[l - 2], a.table_select[1] = o[l - 2], a.table_select[2] = h);
+ var h = new v(c),
+ u = d(s, f, _, h);
+ c = h.bits, a.part2_3_length <= c || (a.assign(t), a.part2_3_length = c, a.region0_count = r[l - 2], a.region1_count = l - 2 - r[l - 2], a.table_select[0] = i[l - 2], a.table_select[1] = o[l - 2], a.table_select[2] = u);
}
}
this.noquant_count_bits = function (e, t, a) {
- var n = t.l3_enc,
- s = Math.min(576, t.max_nonzero_coeff + 2 >> 1 << 1);
- for (null != a && (a.sfb_count1 = 0); 1 < s && 0 == (n[s - 1] | n[s - 2]); s -= 2);
- t.count1 = s;
- for (var r = 0, i = 0; 3 < s; s -= 4) {
+ var s = t.l3_enc,
+ n = Math.min(576, t.max_nonzero_coeff + 2 >> 1 << 1);
+ for (null != a && (a.sfb_count1 = 0); 1 < n && 0 == (s[n - 1] | s[n - 2]); n -= 2);
+ t.count1 = n;
+ for (var r = 0, i = 0; 3 < n; n -= 4) {
var o;
- if (1 < (2147483647 & (n[s - 1] | n[s - 2] | n[s - 3] | n[s - 4]))) break;
- o = 2 * (2 * (2 * n[s - 4] + n[s - 3]) + n[s - 2]) + n[s - 1], r += k.t32l[o], i += k.t33l[o];
+ if (1 < (2147483647 & (s[n - 1] | s[n - 2] | s[n - 3] | s[n - 4]))) break;
+ o = 2 * (2 * (2 * s[n - 4] + s[n - 3]) + s[n - 2]) + s[n - 1], r += F.t32l[o], i += F.t33l[o];
}
var _ = r;
- if (t.count1table_select = 0, i < r && (_ = i, t.count1table_select = 1), t.count1bits = _, 0 == (t.big_values = s)) return _;
- if (t.block_type == Ae.SHORT_TYPE) (r = 3 * e.scalefac_band.s[3]) > t.big_values && (r = t.big_values), i = t.big_values;else if (t.block_type == Ae.NORM_TYPE) {
- if (r = t.region0_count = e.bv_scf[s - 2], i = t.region1_count = e.bv_scf[s - 1], i = e.scalefac_band.l[r + i + 2], r = e.scalefac_band.l[r + 1], i < s) {
+ if (t.count1table_select = 0, i < r && (_ = i, t.count1table_select = 1), t.count1bits = _, 0 == (t.big_values = n)) return _;
+ if (t.block_type == Pe.SHORT_TYPE) (r = 3 * e.scalefac_band.s[3]) > t.big_values && (r = t.big_values), i = t.big_values;else if (t.block_type == Pe.NORM_TYPE) {
+ if (r = t.region0_count = e.bv_scf[n - 2], i = t.region1_count = e.bv_scf[n - 1], i = e.scalefac_band.l[r + i + 2], r = e.scalefac_band.l[r + 1], i < n) {
var l = new v(_);
- t.table_select[2] = d(n, i, s, l), _ = l.bits;
+ t.table_select[2] = d(s, i, n, l), _ = l.bits;
}
- } else t.region0_count = 7, t.region1_count = Ae.SBMAX_l - 1 - 7 - 1, r = e.scalefac_band.l[8], (i = s) < r && (r = i);
- if (r = Math.min(r, s), i = Math.min(i, s), 0 < r) {
- var l = new v(_);
- t.table_select[0] = d(n, 0, r, l), _ = l.bits;
+ } else t.region0_count = 7, t.region1_count = Pe.SBMAX_l - 1 - 7 - 1, (i = n) < (r = e.scalefac_band.l[8]) && (r = i);
+ if (r = Math.min(r, n), i = Math.min(i, n), 0 < r) {
+ l = new v(_);
+ t.table_select[0] = d(s, 0, r, l), _ = l.bits;
}
if (r < i) {
- var l = new v(_);
- t.table_select[1] = d(n, r, i, l), _ = l.bits;
+ l = new v(_);
+ t.table_select[1] = d(s, r, i, l), _ = l.bits;
}
- if (2 == e.use_best_huffman && me(), null != a && t.block_type == Ae.NORM_TYPE) {
+ if (2 == e.use_best_huffman && (t.part2_3_length = _, best_huffman_divide(e, t), _ = t.part2_3_length), null != a && t.block_type == Pe.NORM_TYPE) {
for (var f = 0; e.scalefac_band.l[f] < t.big_values;) f++;
a.sfb_count1 = f;
}
return _;
- }, this.count_bits = function (e, t, a, n) {
- var s = a.l3_enc,
- r = T.IXMAX_VAL / S.IPOW20(a.global_gain);
- return a.xrpow_max > r ? T.LARGE_BITS : (function (e, t, a, n, s) {
+ }, this.count_bits = function (e, t, a, s) {
+ var n = a.l3_enc,
+ r = x.IXMAX_VAL / M.IPOW20(a.global_gain);
+ if (a.xrpow_max > r) return x.LARGE_BITS;
+ if (function (e, t, a, s, n) {
var r,
i,
o,
@@ -13542,123 +13193,127 @@ src: recorder-core.js,engine/mp3.js,engine/mp3-engine.js
l = 0,
f = 0,
c = 0,
- u = t,
- h = 0,
- b = u,
+ h = t,
+ u = 0,
+ m = h,
p = 0,
- m = e,
+ b = e,
v = 0;
- for (o = null != s && n.global_gain == s.global_gain, i = n.block_type == Ae.SHORT_TYPE ? 38 : 21, r = 0; r <= i; r++) {
+ for (o = null != n && s.global_gain == n.global_gain, i = s.block_type == Pe.SHORT_TYPE ? 38 : 21, r = 0; r <= i; r++) {
var d = -1;
- if ((o || n.block_type == Ae.NORM_TYPE) && (d = n.global_gain - (n.scalefac[r] + (0 != n.preflag ? S.pretab[r] : 0) << n.scalefac_scale + 1) - 8 * n.subblock_gain[n.window[r]]), o && s.step[r] == d) 0 != l && (y(l, a, m, v, b, p), l = 0), 0 != f && me();else {
+ if ((o || s.block_type == Pe.NORM_TYPE) && (d = s.global_gain - (s.scalefac[r] + (0 != s.preflag ? M.pretab[r] : 0) << s.scalefac_scale + 1) - 8 * s.subblock_gain[s.window[r]]), o && n.step[r] == d) 0 != l && (R(l, a, b, v, m, p), l = 0), 0 != f && (w(f, a, b, v, m, p), f = 0);else {
var g,
- w = n.width[r];
- if (_ + n.width[r] > n.max_nonzero_coeff && (g = n.max_nonzero_coeff - _ + 1, we.fill(t, n.max_nonzero_coeff, 576, 0), (w = g) < 0 && (w = 0), r = i + 1), 0 == l && 0 == f && (b = u, p = h, m = e, v = c), null != s && 0 < s.sfb_count1 && r >= s.sfb_count1 && 0 < s.step[r] && d >= s.step[r] ? (0 != l && (y(l, a, m, v, b, p), l = 0, b = u, p = h, m = e, v = c), f += w) : (0 != f && (M(f, a, m, v, b, p), f = 0, b = u, p = h, m = e, v = c), l += w), w <= 0) {
- 0 != f && me(), 0 != l && me();
+ S = s.width[r];
+ if (_ + s.width[r] > s.max_nonzero_coeff && (g = s.max_nonzero_coeff - _ + 1, ye.fill(t, s.max_nonzero_coeff, 576, 0), (S = g) < 0 && (S = 0), r = i + 1), 0 == l && 0 == f && (m = h, p = u, b = e, v = c), null != n && 0 < n.sfb_count1 && r >= n.sfb_count1 && 0 < n.step[r] && d >= n.step[r] ? (0 != l && (R(l, a, b, v, m, p), l = 0, m = h, p = u, b = e, v = c), f += S) : (0 != f && (w(f, a, b, v, m, p), f = 0, m = h, p = u, b = e, v = c), l += S), S <= 0) {
+ 0 != f && (w(f, a, b, v, m, p), f = 0), 0 != l && (R(l, a, b, v, m, p), l = 0);
break;
}
}
- r <= i && (h += n.width[r], c += n.width[r], _ += n.width[r]);
+ r <= i && (u += s.width[r], c += s.width[r], _ += s.width[r]);
}
- 0 != l && (y(l, a, m, v, b, p), l = 0), 0 != f && me();
- }(t, s, S.IPOW20(a.global_gain), a, n), 0 != (2 & e.substep_shaping) && me(), this.noquant_count_bits(e, a, n));
+ 0 != l && (R(l, a, b, v, m, p), l = 0), 0 != f && (w(f, a, b, v, m, p), f = 0);
+ }(t, n, M.IPOW20(a.global_gain), a, s), 0 != (2 & e.substep_shaping)) for (var i = 0, o = a.global_gain + a.scalefac_scale, _ = .634521682242439 / M.IPOW20(o), l = 0; l < a.sfbmax; l++) {
+ var f,
+ c = a.width[l];
+ if (0 == e.pseudohalf[l]) i += c;else for (f = i, i += c; f < i; ++f) n[f] = t[f] >= _ ? n[f] : 0;
+ }
+ return this.noquant_count_bits(e, a, s);
}, this.best_huffman_divide = function (e, t) {
- var a = new B(),
- n = t.l3_enc,
- s = ve(23),
- r = ve(23),
- i = ve(23),
- o = ve(23);
- if (t.block_type != Ae.SHORT_TYPE || 1 != e.mode_gr) {
- a.assign(t), t.block_type == Ae.NORM_TYPE && (function (e, t, a, n, s, r, i) {
- for (var o = t.big_values, _ = 0; _ <= 22; _++) n[_] = T.LARGE_BITS;
- for (var _ = 0; _ < 16; _++) {
+ var a = new T(),
+ s = t.l3_enc,
+ n = Ae(23),
+ r = Ae(23),
+ i = Ae(23),
+ o = Ae(23);
+ if (t.block_type != Pe.SHORT_TYPE || 1 != e.mode_gr) {
+ a.assign(t), t.block_type == Pe.NORM_TYPE && (!function (e, t, a, s, n, r, i) {
+ for (var o = t.big_values, _ = 0; _ <= 22; _++) s[_] = x.LARGE_BITS;
+ for (_ = 0; _ < 16; _++) {
var l = e.scalefac_band.l[_ + 1];
if (o <= l) break;
var f = 0,
c = new v(f),
- u = d(a, 0, l, c);
+ h = d(a, 0, l, c);
f = c.bits;
- for (var h = 0; h < 8; h++) {
- var b = e.scalefac_band.l[_ + h + 2];
- if (o <= b) break;
- var p = f;
- c = new v(p);
- var m = d(a, l, b, c);
- p = c.bits, n[_ + h] > p && (n[_ + h] = p, s[_ + h] = _, r[_ + h] = u, i[_ + h] = m);
+ for (var u = 0; u < 8; u++) {
+ var m = e.scalefac_band.l[_ + u + 2];
+ if (o <= m) break;
+ var p = f,
+ b = d(a, l, m, c = new v(p));
+ p = c.bits, s[_ + u] > p && (s[_ + u] = p, r[(n[_ + u] = _) + u] = h, i[_ + u] = b);
}
}
- }(e, t, n, s, r, i, o), h(e, a, t, n, s, r, i, o));
+ }(e, t, s, n, r, i, o), u(e, a, t, s, n, r, i, o));
var _ = a.big_values;
- if (!(0 == _ || 1 < (n[_ - 2] | n[_ - 1]) || 576 < (_ = t.count1 + 2))) {
+ if (!(0 == _ || 1 < (s[_ - 2] | s[_ - 1]) || 576 < (_ = t.count1 + 2))) {
a.assign(t), a.count1 = _;
for (var l = 0, f = 0; _ > a.big_values; _ -= 4) {
- var c = 2 * (2 * (2 * n[_ - 4] + n[_ - 3]) + n[_ - 2]) + n[_ - 1];
- l += k.t32l[c], f += k.t33l[c];
+ var c = 2 * (2 * (2 * s[_ - 4] + s[_ - 3]) + s[_ - 2]) + s[_ - 1];
+ l += F.t32l[c], f += F.t33l[c];
}
- if (a.big_values = _, a.count1table_select = 0, f < l && (l = f, a.count1table_select = 1), a.count1bits = l, a.block_type == Ae.NORM_TYPE) h(e, a, t, n, s, r, i, o);else {
- if (a.part2_3_length = l, l = e.scalefac_band.l[8], _ < l && (l = _), 0 < l) {
- var u = new v(a.part2_3_length);
- a.table_select[0] = d(n, 0, l, u), a.part2_3_length = u.bits;
+ if (a.big_values = _, a.count1table_select = 0, f < l && (l = f, a.count1table_select = 1), a.count1bits = l, a.block_type == Pe.NORM_TYPE) u(e, a, t, s, n, r, i, o);else {
+ if (a.part2_3_length = l, _ < (l = e.scalefac_band.l[8]) && (l = _), 0 < l) {
+ var h = new v(a.part2_3_length);
+ a.table_select[0] = d(s, 0, l, h), a.part2_3_length = h.bits;
}
if (l < _) {
- var u = new v(a.part2_3_length);
- a.table_select[1] = d(n, l, _, u), a.part2_3_length = u.bits;
+ h = new v(a.part2_3_length);
+ a.table_select[1] = d(s, l, _, h), a.part2_3_length = h.bits;
}
t.part2_3_length > a.part2_3_length && t.assign(a);
}
}
}
};
- var u = [1, 1, 1, 1, 8, 2, 2, 2, 4, 4, 4, 8, 8, 8, 16, 16],
- b = [1, 2, 4, 8, 1, 2, 4, 8, 2, 4, 8, 2, 4, 8, 4, 8],
+ var h = [1, 1, 1, 1, 8, 2, 2, 2, 4, 4, 4, 8, 8, 8, 16, 16],
+ m = [1, 2, 4, 8, 1, 2, 4, 8, 2, 4, 8, 2, 4, 8, 4, 8],
p = [0, 0, 0, 0, 3, 1, 1, 1, 2, 2, 2, 3, 3, 3, 4, 4],
- m = [0, 1, 2, 3, 0, 1, 2, 3, 1, 2, 3, 1, 2, 3, 2, 3];
- A.slen1_tab = p, A.slen2_tab = m, this.best_scalefac_store = function (e, t, a, n) {
- var s,
+ b = [0, 1, 2, 3, 0, 1, 2, 3, 1, 2, 3, 1, 2, 3, 2, 3];
+ k.slen1_tab = p, k.slen2_tab = b, this.best_scalefac_store = function (e, t, a, s) {
+ var n,
r,
i,
o,
- _ = n.tt[t][a],
+ _ = s.tt[t][a],
l = 0;
- for (s = i = 0; s < _.sfbmax; s++) {
- var f = _.width[s];
+ for (n = i = 0; n < _.sfbmax; n++) {
+ var f = _.width[n];
for (i += f, o = -f; o < 0 && 0 == _.l3_enc[o + i]; o++);
- 0 == o && (_.scalefac[s] = l = -2);
+ 0 == o && (_.scalefac[n] = l = -2);
}
if (0 == _.scalefac_scale && 0 == _.preflag) {
var c = 0;
- for (s = 0; s < _.sfbmax; s++) 0 < _.scalefac[s] && (c |= _.scalefac[s]);
+ for (n = 0; n < _.sfbmax; n++) 0 < _.scalefac[n] && (c |= _.scalefac[n]);
if (0 == (1 & c) && 0 != c) {
- for (s = 0; s < _.sfbmax; s++) 0 < _.scalefac[s] && (_.scalefac[s] >>= 1);
+ for (n = 0; n < _.sfbmax; n++) 0 < _.scalefac[n] && (_.scalefac[n] >>= 1);
_.scalefac_scale = l = 1;
}
}
- if (0 == _.preflag && _.block_type != Ae.SHORT_TYPE && 2 == e.mode_gr) {
- for (s = 11; s < Ae.SBPSY_l && !(_.scalefac[s] < S.pretab[s] && -2 != _.scalefac[s]); s++);
- if (s == Ae.SBPSY_l) {
- for (s = 11; s < Ae.SBPSY_l; s++) 0 < _.scalefac[s] && (_.scalefac[s] -= S.pretab[s]);
+ if (0 == _.preflag && _.block_type != Pe.SHORT_TYPE && 2 == e.mode_gr) {
+ for (n = 11; n < Pe.SBPSY_l && !(_.scalefac[n] < M.pretab[n] && -2 != _.scalefac[n]); n++);
+ if (n == Pe.SBPSY_l) {
+ for (n = 11; n < Pe.SBPSY_l; n++) 0 < _.scalefac[n] && (_.scalefac[n] -= M.pretab[n]);
_.preflag = l = 1;
}
}
- for (r = 0; r < 4; r++) n.scfsi[a][r] = 0;
- for (2 == e.mode_gr && 1 == t && n.tt[0][a].block_type != Ae.SHORT_TYPE && n.tt[1][a].block_type != Ae.SHORT_TYPE && (function (e, t) {
- for (var a, n = t.tt[1][e], s = t.tt[0][e], r = 0; r < k.scfsi_band.length - 1; r++) {
- for (a = k.scfsi_band[r]; a < k.scfsi_band[r + 1] && !(s.scalefac[a] != n.scalefac[a] && 0 <= n.scalefac[a]); a++);
- if (a == k.scfsi_band[r + 1]) {
- for (a = k.scfsi_band[r]; a < k.scfsi_band[r + 1]; a++) n.scalefac[a] = -1;
+ for (r = 0; r < 4; r++) s.scfsi[a][r] = 0;
+ for (2 == e.mode_gr && 1 == t && s.tt[0][a].block_type != Pe.SHORT_TYPE && s.tt[1][a].block_type != Pe.SHORT_TYPE && (!function (e, t) {
+ for (var a, s = t.tt[1][e], n = t.tt[0][e], r = 0; r < F.scfsi_band.length - 1; r++) {
+ for (a = F.scfsi_band[r]; a < F.scfsi_band[r + 1] && !(n.scalefac[a] != s.scalefac[a] && 0 <= s.scalefac[a]); a++);
+ if (a == F.scfsi_band[r + 1]) {
+ for (a = F.scfsi_band[r]; a < F.scfsi_band[r + 1]; a++) s.scalefac[a] = -1;
t.scfsi[e][r] = 1;
}
}
var i = 0,
o = 0;
- for (a = 0; a < 11; a++) -1 != n.scalefac[a] && (o++, i < n.scalefac[a] && (i = n.scalefac[a]));
- for (var _ = 0, l = 0; a < Ae.SBPSY_l; a++) -1 != n.scalefac[a] && (l++, _ < n.scalefac[a] && (_ = n.scalefac[a]));
- for (var r = 0; r < 16; r++) if (i < u[r] && _ < b[r]) {
- var f = p[r] * o + m[r] * l;
- n.part2_length > f && (n.part2_length = f, n.scalefac_compress = r);
+ for (a = 0; a < 11; a++) -1 != s.scalefac[a] && (o++, i < s.scalefac[a] && (i = s.scalefac[a]));
+ for (var _ = 0, l = 0; a < Pe.SBPSY_l; a++) -1 != s.scalefac[a] && (l++, _ < s.scalefac[a] && (_ = s.scalefac[a]));
+ for (r = 0; r < 16; r++) if (i < h[r] && _ < m[r]) {
+ var f = p[r] * o + b[r] * l;
+ s.part2_length > f && (s.part2_length = f, s.scalefac_compress = r);
}
- }(a, n), l = 0), s = 0; s < _.sfbmax; s++) -2 == _.scalefac[s] && (_.scalefac[s] = 0);
+ }(a, s), l = 0), n = 0; n < _.sfbmax; n++) -2 == _.scalefac[n] && (_.scalefac[n] = 0);
0 != l && (2 == e.mode_gr ? this.scale_bitcount(_) : this.scale_bitcount_lsf(e, _));
};
var _ = [0, 18, 36, 54, 54, 36, 54, 72, 54, 72, 90, 72, 90, 108, 108, 126],
@@ -13667,458 +13322,476 @@ src: recorder-core.js,engine/mp3.js,engine/mp3-engine.js
this.scale_bitcount = function (e) {
var t,
a,
- n,
- s = 0,
+ s,
+ n = 0,
r = 0,
i = e.scalefac;
- if (e.block_type == Ae.SHORT_TYPE) n = _, 0 != e.mixed_block_flag && (n = l);else if (n = f, 0 == e.preflag) {
- for (a = 11; a < Ae.SBPSY_l && !(i[a] < S.pretab[a]); a++);
- if (a == Ae.SBPSY_l) for (e.preflag = 1, a = 11; a < Ae.SBPSY_l; a++) i[a] -= S.pretab[a];
+ if (e.block_type == Pe.SHORT_TYPE) s = _, 0 != e.mixed_block_flag && (s = l);else if (s = f, 0 == e.preflag) {
+ for (a = 11; a < Pe.SBPSY_l && !(i[a] < M.pretab[a]); a++);
+ if (a == Pe.SBPSY_l) for (e.preflag = 1, a = 11; a < Pe.SBPSY_l; a++) i[a] -= M.pretab[a];
}
- for (a = 0; a < e.sfbdivide; a++) s < i[a] && (s = i[a]);
+ for (a = 0; a < e.sfbdivide; a++) n < i[a] && (n = i[a]);
for (; a < e.sfbmax; a++) r < i[a] && (r = i[a]);
- for (e.part2_length = T.LARGE_BITS, t = 0; t < 16; t++) s < u[t] && r < b[t] && e.part2_length > n[t] && (e.part2_length = n[t], e.scalefac_compress = t);
- return e.part2_length == T.LARGE_BITS;
+ for (e.part2_length = x.LARGE_BITS, t = 0; t < 16; t++) n < h[t] && r < m[t] && e.part2_length > s[t] && (e.part2_length = s[t], e.scalefac_compress = t);
+ return e.part2_length == x.LARGE_BITS;
};
var g = [[15, 15, 7, 7], [15, 15, 7, 0], [7, 3, 0, 0], [15, 31, 31, 0], [7, 7, 7, 0], [3, 3, 0, 0]];
this.scale_bitcount_lsf = function (e, t) {
var a,
- n,
s,
+ n,
r,
i,
o,
_,
l,
- f = ve(4),
+ f = Ae(4),
c = t.scalefac;
for (a = 0 != t.preflag ? 2 : 0, _ = 0; _ < 4; _++) f[_] = 0;
- if (t.block_type == Ae.SHORT_TYPE) {
- n = 1;
- var u = S.nr_of_sfb_block[a][n];
- for (s = l = 0; s < 4; s++) for (r = u[s] / 3, _ = 0; _ < r; _++, l++) for (i = 0; i < 3; i++) c[3 * l + i] > f[s] && (f[s] = c[3 * l + i]);
+ if (t.block_type == Pe.SHORT_TYPE) {
+ s = 1;
+ var h = M.nr_of_sfb_block[a][s];
+ for (n = l = 0; n < 4; n++) for (r = h[n] / 3, _ = 0; _ < r; _++, l++) for (i = 0; i < 3; i++) c[3 * l + i] > f[n] && (f[n] = c[3 * l + i]);
} else {
- n = 0;
- var u = S.nr_of_sfb_block[a][n];
- for (s = l = 0; s < 4; s++) for (r = u[s], _ = 0; _ < r; _++, l++) c[l] > f[s] && (f[s] = c[l]);
+ s = 0;
+ h = M.nr_of_sfb_block[a][s];
+ for (n = l = 0; n < 4; n++) for (r = h[n], _ = 0; _ < r; _++, l++) c[l] > f[n] && (f[n] = c[l]);
}
- for (o = !1, s = 0; s < 4; s++) f[s] > g[a][s] && (o = !0);
+ for (o = !1, n = 0; n < 4; n++) f[n] > g[a][n] && (o = !0);
if (!o) {
- var h, b, p, m;
- for (t.sfb_partition_table = S.nr_of_sfb_block[a][n], s = 0; s < 4; s++) t.slen[s] = w[f[s]];
- switch (h = t.slen[0], b = t.slen[1], p = t.slen[2], m = t.slen[3], a) {
+ var u, m, p, b;
+ for (t.sfb_partition_table = M.nr_of_sfb_block[a][s], n = 0; n < 4; n++) t.slen[n] = S[f[n]];
+ switch (u = t.slen[0], m = t.slen[1], p = t.slen[2], b = t.slen[3], a) {
case 0:
- t.scalefac_compress = (5 * h + b << 4) + (p << 2) + m;
+ t.scalefac_compress = (5 * u + m << 4) + (p << 2) + b;
break;
case 1:
- t.scalefac_compress = 400 + (5 * h + b << 2) + p;
+ t.scalefac_compress = 400 + (5 * u + m << 2) + p;
break;
case 2:
- t.scalefac_compress = 500 + 3 * h + b;
+ t.scalefac_compress = 500 + 3 * u + m;
+ break;
+ default:
+ $.err.printf("intensity stereo not implemented yet\n");
}
}
- if (!o) for (t.part2_length = 0, s = 0; s < 4; s++) t.part2_length += t.slen[s] * t.sfb_partition_table[s];
+ if (!o) for (n = t.part2_length = 0; n < 4; n++) t.part2_length += t.slen[n] * t.sfb_partition_table[n];
return o;
};
- var w = [0, 1, 2, 2, 3, 3, 3, 3, 4, 4, 4, 4, 4, 4, 4, 4];
+ var S = [0, 1, 2, 2, 3, 3, 3, 3, 4, 4, 4, 4, 4, 4, 4, 4];
this.huffman_init = function (e) {
for (var t = 2; t <= 576; t += 2) {
- for (var a, n = 0; e.scalefac_band.l[++n] < t;);
- for (a = s[n][0]; e.scalefac_band.l[a + 1] > t;) a--;
- for (a < 0 && (a = s[n][0]), e.bv_scf[t - 2] = a, a = s[n][1]; e.scalefac_band.l[a + e.bv_scf[t - 2] + 2] > t;) a--;
- a < 0 && (a = s[n][1]), e.bv_scf[t - 1] = a;
+ for (var a, s = 0; e.scalefac_band.l[++s] < t;);
+ for (a = n[s][0]; e.scalefac_band.l[a + 1] > t;) a--;
+ for (a < 0 && (a = n[s][0]), e.bv_scf[t - 2] = a, a = n[s][1]; e.scalefac_band.l[a + e.bv_scf[t - 2] + 2] > t;) a--;
+ a < 0 && (a = n[s][1]), e.bv_scf[t - 1] = a;
}
};
}
- function O() {}
- function y() {
- this.setModules = function (e, t, a) {};
+ function X() {}
+ function M() {
+ this.setModules = function (e, t, a) {
+ };
var o = [0, 49345, 49537, 320, 49921, 960, 640, 49729, 50689, 1728, 1920, 51009, 1280, 50625, 50305, 1088, 52225, 3264, 3456, 52545, 3840, 53185, 52865, 3648, 2560, 51905, 52097, 2880, 51457, 2496, 2176, 51265, 55297, 6336, 6528, 55617, 6912, 56257, 55937, 6720, 7680, 57025, 57217, 8e3, 56577, 7616, 7296, 56385, 5120, 54465, 54657, 5440, 55041, 6080, 5760, 54849, 53761, 4800, 4992, 54081, 4352, 53697, 53377, 4160, 61441, 12480, 12672, 61761, 13056, 62401, 62081, 12864, 13824, 63169, 63361, 14144, 62721, 13760, 13440, 62529, 15360, 64705, 64897, 15680, 65281, 16320, 16e3, 65089, 64001, 15040, 15232, 64321, 14592, 63937, 63617, 14400, 10240, 59585, 59777, 10560, 60161, 11200, 10880, 59969, 60929, 11968, 12160, 61249, 11520, 60865, 60545, 11328, 58369, 9408, 9600, 58689, 9984, 59329, 59009, 9792, 8704, 58049, 58241, 9024, 57601, 8640, 8320, 57409, 40961, 24768, 24960, 41281, 25344, 41921, 41601, 25152, 26112, 42689, 42881, 26432, 42241, 26048, 25728, 42049, 27648, 44225, 44417, 27968, 44801, 28608, 28288, 44609, 43521, 27328, 27520, 43841, 26880, 43457, 43137, 26688, 30720, 47297, 47489, 31040, 47873, 31680, 31360, 47681, 48641, 32448, 32640, 48961, 32e3, 48577, 48257, 31808, 46081, 29888, 30080, 46401, 30464, 47041, 46721, 30272, 29184, 45761, 45953, 29504, 45313, 29120, 28800, 45121, 20480, 37057, 37249, 20800, 37633, 21440, 21120, 37441, 38401, 22208, 22400, 38721, 21760, 38337, 38017, 21568, 39937, 23744, 23936, 40257, 24320, 40897, 40577, 24128, 23040, 39617, 39809, 23360, 39169, 22976, 22656, 38977, 34817, 18624, 18816, 35137, 19200, 35777, 35457, 19008, 19968, 36545, 36737, 20288, 36097, 19904, 19584, 35905, 17408, 33985, 34177, 17728, 34561, 18368, 18048, 34369, 33281, 17088, 17280, 33601, 16640, 33217, 32897, 16448];
- this.updateMusicCRC = function (e, t, a, n) {
- for (var s = 0; s < n; ++s) e[0] = (r = t[a + s], i = (i = e[0]) >> 8 ^ o[255 & (i ^ r)]);
+ this.updateMusicCRC = function (e, t, a, s) {
+ for (var n = 0; n < s; ++n) e[0] = (r = t[a + n], i = (i = e[0]) >> 8 ^ o[255 & (i ^ r)]);
var r, i;
};
}
- function N() {
- var i = this,
+ function q() {
+ var _ = this,
+ s = 32773,
+ c = null,
+ h = null,
r = null,
- o = null;
- this.setModules = function (e, t, a, n) {
- r = a, o = n;
+ u = null;
+ this.setModules = function (e, t, a, s) {
+ c = e, h = t, r = a, u = s;
};
- var _ = null,
+ var m = null,
l = 0,
- f = 0,
- c = 0;
+ p = 0,
+ b = 0;
function v(e, t, a) {
for (; 0 < a;) {
- var n;
- 0 == c && (c = 8, f++, e.header[e.w_ptr].write_timing == l && (s = e, I.arraycopy(s.header[s.w_ptr].buf, 0, _, f, s.sideinfo_len), f += s.sideinfo_len, l += 8 * s.sideinfo_len, s.w_ptr = s.w_ptr + 1 & j.MAX_HEADER_BUF - 1), _[f] = 0), n = Math.min(a, c), a -= n, c -= n, _[f] |= t >> a << c, l += n;
+ var s;
+ 0 == b && (b = 8, p++, e.header[e.w_ptr].write_timing == l && (n = e, $.arraycopy(n.header[n.w_ptr].buf, 0, m, p, n.sideinfo_len), p += n.sideinfo_len, l += 8 * n.sideinfo_len, n.w_ptr = n.w_ptr + 1 & Z.MAX_HEADER_BUF - 1), m[p] = 0), a -= s = Math.min(a, b), b -= s, m[p] |= t >> a << b, l += s;
}
- var s;
+ var n;
}
- function u(e, t) {
+ function i(e, t, a) {
+ for (; 0 < a;) {
+ var s;
+ 0 == b && (b = 8, m[++p] = 0), a -= s = Math.min(a, b), b -= s, m[p] |= t >> a << b, l += s;
+ }
+ }
+ function o(e, t) {
var a,
- n = e.internal_flags;
- if (8 <= t && (v(n, 76, 8), t -= 8), 8 <= t && (v(n, 65, 8), t -= 8), 8 <= t && (v(n, 77, 8), t -= 8), 8 <= t && (v(n, 69, 8), t -= 8), 32 <= t) {
- var s = r.getLameShortVersion();
- if (32 <= t) for (a = 0; a < s.length && 8 <= t; ++a) t -= 8, v(n, s.charCodeAt(a), 8);
+ s = e.internal_flags;
+ if (8 <= t && (v(s, 76, 8), t -= 8), 8 <= t && (v(s, 65, 8), t -= 8), 8 <= t && (v(s, 77, 8), t -= 8), 8 <= t && (v(s, 69, 8), t -= 8), 32 <= t) {
+ var n = r.getLameShortVersion();
+ if (32 <= t) for (a = 0; a < n.length && 8 <= t; ++a) t -= 8, v(s, n.charCodeAt(a), 8);
}
- for (; 1 <= t; t -= 1) v(n, n.ancillary_flag, 1), n.ancillary_flag ^= e.disable_reservoir ? 0 : 1;
+ for (; 1 <= t; t -= 1) v(s, s.ancillary_flag, 1), s.ancillary_flag ^= e.disable_reservoir ? 0 : 1;
}
- function h(e, t, a) {
- for (var n = e.header[e.h_ptr].ptr; 0 < a;) {
- var s = Math.min(a, 8 - (7 & n));
- a -= s, e.header[e.h_ptr].buf[n >> 3] |= t >> a << 8 - (7 & n) - s, n += s;
+ function f(e, t, a) {
+ for (var s = e.header[e.h_ptr].ptr; 0 < a;) {
+ var n = Math.min(a, 8 - (7 & s));
+ a -= n, e.header[e.h_ptr].buf[s >> 3] |= t >> a << 8 - (7 & s) - n, s += n;
}
- e.header[e.h_ptr].ptr = n;
+ e.header[e.h_ptr].ptr = s;
}
- function m(e, t) {
+ function n(e, t) {
+ e <<= 8;
+ for (var a = 0; a < 8; a++) 0 != (65536 & ((t <<= 1) ^ (e <<= 1))) && (t ^= s);
+ return t;
+ }
+ function d(e, t) {
var a,
- n = k.ht[t.count1table_select + 32],
- s = 0,
+ s = F.ht[t.count1table_select + 32],
+ n = 0,
r = t.big_values,
i = t.big_values;
for (a = (t.count1 - t.big_values) / 4; 0 < a; --a) {
var o = 0,
_ = 0;
- 0 != t.l3_enc[r + 0] && (_ += 8, t.xr[i + 0] < 0 && o++), 0 != t.l3_enc[r + 1] && (_ += 4, o *= 2, t.xr[i + 1] < 0 && o++), 0 != t.l3_enc[r + 2] && (_ += 2, o *= 2, t.xr[i + 2] < 0 && o++), 0 != t.l3_enc[r + 3] && (_++, o *= 2, t.xr[i + 3] < 0 && o++), r += 4, i += 4, v(e, o + n.table[_], n.hlen[_]), s += n.hlen[_];
+ 0 != t.l3_enc[r + 0] && (_ += 8, t.xr[i + 0] < 0 && o++), 0 != t.l3_enc[r + 1] && (_ += 4, o *= 2, t.xr[i + 1] < 0 && o++), 0 != t.l3_enc[r + 2] && (_ += 2, o *= 2, t.xr[i + 2] < 0 && o++), 0 != t.l3_enc[r + 3] && (_++, o *= 2, t.xr[i + 3] < 0 && o++), r += 4, i += 4, v(e, o + s.table[_], s.hlen[_]), n += s.hlen[_];
}
- return s;
+ return n;
}
- function b(e, t, a, n, s) {
- var r = k.ht[t],
+ function g(e, t, a, s, n) {
+ var r = F.ht[t],
i = 0;
if (0 == t) return i;
- for (var o = a; o < n; o += 2) {
+ for (var o = a; o < s; o += 2) {
var _ = 0,
l = 0,
f = r.xlen,
c = r.xlen,
- u = 0,
- h = s.l3_enc[o],
- b = s.l3_enc[o + 1];
- if (0 != h && (s.xr[o] < 0 && u++, _--), 15 < t) {
- if (14 < h) {
- var p = h - 15;
- u |= p << 1, l = f, h = 15;
- }
- if (14 < b) {
- var m = b - 15;
- u <<= f, u |= m, l += f, b = 15;
- }
+ h = 0,
+ u = n.l3_enc[o],
+ m = n.l3_enc[o + 1];
+ if (0 != u && (n.xr[o] < 0 && h++, _--), 15 < t) {
+ if (14 < u) h |= u - 15 << 1, l = f, u = 15;
+ if (14 < m) h <<= f, h |= m - 15, l += f, m = 15;
c = 16;
}
- 0 != b && (u <<= 1, s.xr[o + 1] < 0 && u++, _--), h = h * c + b, l -= _, _ += r.hlen[h], v(e, r.table[h], _), v(e, u, l), i += _ + l;
+ 0 != m && (h <<= 1, n.xr[o + 1] < 0 && h++, _--), u = u * c + m, l -= _, _ += r.hlen[u], v(e, r.table[u], _), v(e, h, l), i += _ + l;
}
return i;
}
- function d(e, t) {
+ function S(e, t) {
var a = 3 * e.scalefac_band.s[3];
a > t.big_values && (a = t.big_values);
- var n = b(e, t.table_select[0], 0, a, t);
- return n += b(e, t.table_select[1], a, t.big_values, t);
+ var s = g(e, t.table_select[0], 0, a, t);
+ return s += g(e, t.table_select[1], a, t.big_values, t);
}
- function g(e, t) {
- var a, n, s, r;
+ function M(e, t) {
+ var a, s, n, r;
a = t.big_values;
var i = t.region0_count + 1;
- return s = e.scalefac_band.l[i], i += t.region1_count + 1, r = e.scalefac_band.l[i], a < s && (s = a), a < r && (r = a), n = b(e, t.table_select[0], 0, s, t), n += b(e, t.table_select[1], s, r, t), n += b(e, t.table_select[2], r, a, t);
+ return n = e.scalefac_band.l[i], i += t.region1_count + 1, a < n && (n = a), a < (r = e.scalefac_band.l[i]) && (r = a), s = g(e, t.table_select[0], 0, n, t), s += g(e, t.table_select[1], n, r, t), s += g(e, t.table_select[2], r, a, t);
}
- function p() {
+ function w() {
this.total = 0;
}
- function w(e, t) {
+ function R(e, t) {
var a,
- n,
s,
- r = e.internal_flags;
- return r.w_ptr, -1 == (s = r.h_ptr - 1) && (s = j.MAX_HEADER_BUF - 1), a = r.header[s].write_timing - l, 0 <= (t.total = a) && me(), n = i.getframebits(e), a += n, t.total += n, t.total % 8 != 0 ? t.total = 1 + t.total / 8 : t.total = t.total / 8, t.total += f + 1, a;
+ n,
+ r,
+ i,
+ o = e.internal_flags;
+ return i = o.w_ptr, -1 == (r = o.h_ptr - 1) && (r = Z.MAX_HEADER_BUF - 1), a = o.header[r].write_timing - l, 0 <= (t.total = a) && (s = 1 + r - i, r < i && (s = 1 + r - i + Z.MAX_HEADER_BUF), a -= 8 * s * o.sideinfo_len), a += n = _.getframebits(e), t.total += n, t.total % 8 != 0 ? t.total = 1 + t.total / 8 : t.total = t.total / 8, t.total += p + 1, a < 0 && $.err.println("strange error flushing buffer ... \n"), a;
}
this.getframebits = function (e) {
var t,
a = e.internal_flags;
- t = 0 != a.bitrate_index ? k.bitrate_table[e.version][a.bitrate_index] : e.brate;
- var n = 0 | 72e3 * (e.version + 1) * t / e.out_samplerate + a.padding;
- return 8 * n;
+ return t = 0 != a.bitrate_index ? F.bitrate_table[e.version][a.bitrate_index] : e.brate, 8 * (0 | 72e3 * (e.version + 1) * t / e.out_samplerate + a.padding);
+ }, this.CRC_writeheader = function (e, t) {
+ var a = 65535;
+ a = n(255 & t[2], a), a = n(255 & t[3], a);
+ for (var s = 6; s < e.sideinfo_len; s++) a = n(255 & t[s], a);
+ t[4] = byte(a >> 8), t[5] = byte(255 & a);
}, this.flush_bitstream = function (e) {
var t,
a,
- n = e.internal_flags;
- n.h_ptr - 1;
- t = n.l3_side, (a = w(e, new p())) < 0 || (u(e, a), n.ResvSize = 0, t.main_data_begin = 0, n.findReplayGain && me(), n.findPeakSample && me());
+ s = e.internal_flags;
+ s.h_ptr - 1;
+ if (t = s.l3_side, !((a = R(e, new w())) < 0)) {
+ if (o(e, a), s.ResvSize = 0, t.main_data_begin = 0, s.findReplayGain) {
+ var r = c.GetTitleGain(s.rgdata);
+ s.RadioGain = 0 | Math.floor(10 * r + .5);
+ }
+ s.findPeakSample && (s.noclipGainChange = 0 | Math.ceil(20 * B(s.PeakSample / 32767) * 10), 0 < s.noclipGainChange && (EQ(e.scale, 1) || EQ(e.scale, 0)) ? s.noclipScale = Math.floor(32767 / s.PeakSample * 100) / 100 : s.noclipScale = -1);
+ }
+ }, this.add_dummy_byte = function (e, t, a) {
+ for (var s, n = e.internal_flags; 0 < a--;) for (i(0, t, 8), s = 0; s < Z.MAX_HEADER_BUF; ++s) n.header[s].write_timing += 8;
}, this.format_bitstream = function (e) {
var t,
a = e.internal_flags;
t = a.l3_side;
- var n = this.getframebits(e);
- u(e, t.resvDrain_pre), function (e, t) {
+ var s = this.getframebits(e);
+ o(e, t.resvDrain_pre), function (e, t) {
var a,
- n,
s,
+ n,
r = e.internal_flags;
- if (a = r.l3_side, r.header[r.h_ptr].ptr = 0, we.fill(r.header[r.h_ptr].buf, 0, r.sideinfo_len, 0), e.out_samplerate < 16e3 ? h(r, 4094, 12) : h(r, 4095, 12), h(r, e.version, 1), h(r, 1, 2), h(r, e.error_protection ? 0 : 1, 1), h(r, r.bitrate_index, 4), h(r, r.samplerate_index, 2), h(r, r.padding, 1), h(r, e.extension, 1), h(r, e.mode.ordinal(), 2), h(r, r.mode_ext, 2), h(r, e.copyright, 1), h(r, e.original, 1), h(r, e.emphasis, 2), e.error_protection && h(r, 0, 16), 1 == e.version) {
- for (h(r, a.main_data_begin, 9), 2 == r.channels_out ? h(r, a.private_bits, 3) : h(r, a.private_bits, 5), s = 0; s < r.channels_out; s++) {
+ if (a = r.l3_side, r.header[r.h_ptr].ptr = 0, ye.fill(r.header[r.h_ptr].buf, 0, r.sideinfo_len, 0), e.out_samplerate < 16e3 ? f(r, 4094, 12) : f(r, 4095, 12), f(r, e.version, 1), f(r, 1, 2), f(r, e.error_protection ? 0 : 1, 1), f(r, r.bitrate_index, 4), f(r, r.samplerate_index, 2), f(r, r.padding, 1), f(r, e.extension, 1), f(r, e.mode.ordinal(), 2), f(r, r.mode_ext, 2), f(r, e.copyright, 1), f(r, e.original, 1), f(r, e.emphasis, 2), e.error_protection && f(r, 0, 16), 1 == e.version) {
+ for (f(r, a.main_data_begin, 9), 2 == r.channels_out ? f(r, a.private_bits, 3) : f(r, a.private_bits, 5), n = 0; n < r.channels_out; n++) {
var i;
- for (i = 0; i < 4; i++) h(r, a.scfsi[s][i], 1);
+ for (i = 0; i < 4; i++) f(r, a.scfsi[n][i], 1);
}
- for (n = 0; n < 2; n++) for (s = 0; s < r.channels_out; s++) {
- var o = a.tt[n][s];
- h(r, o.part2_3_length + o.part2_length, 12), h(r, o.big_values / 2, 9), h(r, o.global_gain, 8), h(r, o.scalefac_compress, 4), o.block_type != Ae.NORM_TYPE ? (h(r, 1, 1), h(r, o.block_type, 2), h(r, o.mixed_block_flag, 1), 14 == o.table_select[0] && (o.table_select[0] = 16), h(r, o.table_select[0], 5), 14 == o.table_select[1] && (o.table_select[1] = 16), h(r, o.table_select[1], 5), h(r, o.subblock_gain[0], 3), h(r, o.subblock_gain[1], 3), h(r, o.subblock_gain[2], 3)) : (h(r, 0, 1), 14 == o.table_select[0] && (o.table_select[0] = 16), h(r, o.table_select[0], 5), 14 == o.table_select[1] && (o.table_select[1] = 16), h(r, o.table_select[1], 5), 14 == o.table_select[2] && (o.table_select[2] = 16), h(r, o.table_select[2], 5), h(r, o.region0_count, 4), h(r, o.region1_count, 3)), h(r, o.preflag, 1), h(r, o.scalefac_scale, 1), h(r, o.count1table_select, 1);
- }
- } else for (h(r, a.main_data_begin, 8), h(r, a.private_bits, r.channels_out), s = n = 0; s < r.channels_out; s++) {
- var o = a.tt[n][s];
- h(r, o.part2_3_length + o.part2_length, 12), h(r, o.big_values / 2, 9), h(r, o.global_gain, 8), h(r, o.scalefac_compress, 9), o.block_type != Ae.NORM_TYPE ? (h(r, 1, 1), h(r, o.block_type, 2), h(r, o.mixed_block_flag, 1), 14 == o.table_select[0] && (o.table_select[0] = 16), h(r, o.table_select[0], 5), 14 == o.table_select[1] && (o.table_select[1] = 16), h(r, o.table_select[1], 5), h(r, o.subblock_gain[0], 3), h(r, o.subblock_gain[1], 3), h(r, o.subblock_gain[2], 3)) : (h(r, 0, 1), 14 == o.table_select[0] && (o.table_select[0] = 16), h(r, o.table_select[0], 5), 14 == o.table_select[1] && (o.table_select[1] = 16), h(r, o.table_select[1], 5), 14 == o.table_select[2] && (o.table_select[2] = 16), h(r, o.table_select[2], 5), h(r, o.region0_count, 4), h(r, o.region1_count, 3)), h(r, o.scalefac_scale, 1), h(r, o.count1table_select, 1);
+ for (s = 0; s < 2; s++) for (n = 0; n < r.channels_out; n++) f(r, (o = a.tt[s][n]).part2_3_length + o.part2_length, 12), f(r, o.big_values / 2, 9), f(r, o.global_gain, 8), f(r, o.scalefac_compress, 4), o.block_type != Pe.NORM_TYPE ? (f(r, 1, 1), f(r, o.block_type, 2), f(r, o.mixed_block_flag, 1), 14 == o.table_select[0] && (o.table_select[0] = 16), f(r, o.table_select[0], 5), 14 == o.table_select[1] && (o.table_select[1] = 16), f(r, o.table_select[1], 5), f(r, o.subblock_gain[0], 3), f(r, o.subblock_gain[1], 3), f(r, o.subblock_gain[2], 3)) : (f(r, 0, 1), 14 == o.table_select[0] && (o.table_select[0] = 16), f(r, o.table_select[0], 5), 14 == o.table_select[1] && (o.table_select[1] = 16), f(r, o.table_select[1], 5), 14 == o.table_select[2] && (o.table_select[2] = 16), f(r, o.table_select[2], 5), f(r, o.region0_count, 4), f(r, o.region1_count, 3)), f(r, o.preflag, 1), f(r, o.scalefac_scale, 1), f(r, o.count1table_select, 1);
+ } else for (f(r, a.main_data_begin, 8), f(r, a.private_bits, r.channels_out), n = s = 0; n < r.channels_out; n++) {
+ var o;
+ f(r, (o = a.tt[s][n]).part2_3_length + o.part2_length, 12), f(r, o.big_values / 2, 9), f(r, o.global_gain, 8), f(r, o.scalefac_compress, 9), o.block_type != Pe.NORM_TYPE ? (f(r, 1, 1), f(r, o.block_type, 2), f(r, o.mixed_block_flag, 1), 14 == o.table_select[0] && (o.table_select[0] = 16), f(r, o.table_select[0], 5), 14 == o.table_select[1] && (o.table_select[1] = 16), f(r, o.table_select[1], 5), f(r, o.subblock_gain[0], 3), f(r, o.subblock_gain[1], 3), f(r, o.subblock_gain[2], 3)) : (f(r, 0, 1), 14 == o.table_select[0] && (o.table_select[0] = 16), f(r, o.table_select[0], 5), 14 == o.table_select[1] && (o.table_select[1] = 16), f(r, o.table_select[1], 5), 14 == o.table_select[2] && (o.table_select[2] = 16), f(r, o.table_select[2], 5), f(r, o.region0_count, 4), f(r, o.region1_count, 3)), f(r, o.scalefac_scale, 1), f(r, o.count1table_select, 1);
}
- e.error_protection && me();
+ e.error_protection && CRC_writeheader(r, r.header[r.h_ptr].buf);
var _ = r.h_ptr;
- r.h_ptr = _ + 1 & j.MAX_HEADER_BUF - 1, r.header[r.h_ptr].write_timing = r.header[_].write_timing + t, r.h_ptr, r.w_ptr;
- }(e, n);
- var s = 8 * a.sideinfo_len;
- if (s += function (e) {
+ r.h_ptr = _ + 1 & Z.MAX_HEADER_BUF - 1, r.header[r.h_ptr].write_timing = r.header[_].write_timing + t, r.h_ptr == r.w_ptr && $.err.println("Error: MAX_HEADER_BUF too small in bitstream.c \n");
+ }(e, s);
+ var n = 8 * a.sideinfo_len;
+ if (n += function (e) {
var t,
a,
- n,
s,
+ n,
r = 0,
i = e.internal_flags,
o = i.l3_side;
if (1 == e.version) for (t = 0; t < 2; t++) for (a = 0; a < i.channels_out; a++) {
var _ = o.tt[t][a],
- l = A.slen1_tab[_.scalefac_compress],
- f = A.slen2_tab[_.scalefac_compress];
- for (n = s = 0; n < _.sfbdivide; n++) -1 != _.scalefac[n] && (v(i, _.scalefac[n], l), s += l);
- for (; n < _.sfbmax; n++) -1 != _.scalefac[n] && (v(i, _.scalefac[n], f), s += f);
- _.block_type == Ae.SHORT_TYPE ? s += d(i, _) : s += g(i, _), s += m(i, _), r += s;
+ l = k.slen1_tab[_.scalefac_compress],
+ f = k.slen2_tab[_.scalefac_compress];
+ for (s = n = 0; s < _.sfbdivide; s++) -1 != _.scalefac[s] && (v(i, _.scalefac[s], l), n += l);
+ for (; s < _.sfbmax; s++) -1 != _.scalefac[s] && (v(i, _.scalefac[s], f), n += f);
+ _.block_type == Pe.SHORT_TYPE ? n += S(i, _) : n += M(i, _), r += n += d(i, _);
} else for (a = t = 0; a < i.channels_out; a++) {
var c,
- u,
- _ = o.tt[t][a],
- h = 0;
- if (u = n = s = 0, _.block_type == Ae.SHORT_TYPE) {
- for (; u < 4; u++) {
- var b = _.sfb_partition_table[u] / 3,
- p = _.slen[u];
- for (c = 0; c < b; c++, n++) v(i, Math.max(_.scalefac[3 * n + 0], 0), p), v(i, Math.max(_.scalefac[3 * n + 1], 0), p), v(i, Math.max(_.scalefac[3 * n + 2], 0), p), h += 3 * p;
+ h,
+ u = 0;
+ if (h = s = n = 0, (_ = o.tt[t][a]).block_type == Pe.SHORT_TYPE) {
+ for (; h < 4; h++) {
+ var m = _.sfb_partition_table[h] / 3,
+ p = _.slen[h];
+ for (c = 0; c < m; c++, s++) v(i, Math.max(_.scalefac[3 * s + 0], 0), p), v(i, Math.max(_.scalefac[3 * s + 1], 0), p), v(i, Math.max(_.scalefac[3 * s + 2], 0), p), u += 3 * p;
}
- s += d(i, _);
+ n += S(i, _);
} else {
- for (; u < 4; u++) {
- var b = _.sfb_partition_table[u],
- p = _.slen[u];
- for (c = 0; c < b; c++, n++) v(i, Math.max(_.scalefac[n], 0), p), h += p;
- }
- s += g(i, _);
+ for (; h < 4; h++) for (m = _.sfb_partition_table[h], p = _.slen[h], c = 0; c < m; c++, s++) v(i, Math.max(_.scalefac[s], 0), p), u += p;
+ n += M(i, _);
}
- s += m(i, _), r += h + s;
+ r += u + (n += d(i, _));
}
return r;
- }(e), u(e, t.resvDrain_post), s += t.resvDrain_post, t.main_data_begin += (n - s) / 8, w(e, new p()), a.ResvSize, 8 * t.main_data_begin != a.ResvSize && (a.ResvSize = 8 * t.main_data_begin), 1e9 < l) {
+ }(e), o(e, t.resvDrain_post), n += t.resvDrain_post, t.main_data_begin += (s - n) / 8, R(e, new w()) != a.ResvSize && $.err.println("Internal buffer inconsistency. flushbits <> ResvSize"), 8 * t.main_data_begin != a.ResvSize && ($.err.printf("bit reservoir error: \nl3_side.main_data_begin: %d \nResvoir size: %d \nresv drain (post) %d \nresv drain (pre) %d \nheader and sideinfo: %d \ndata bits: %d \ntotal bits: %d (remainder: %d) \nbitsperframe: %d \n", 8 * t.main_data_begin, a.ResvSize, t.resvDrain_post, t.resvDrain_pre, 8 * a.sideinfo_len, n - t.resvDrain_post - 8 * a.sideinfo_len, n, n % 8, s), $.err.println("This is a fatal error. It has several possible causes:"), $.err.println("90%% LAME compiled with buggy version of gcc using advanced optimizations"), $.err.println(" 9%% Your system is overclocked"), $.err.println(" 1%% bug in LAME encoding library"), a.ResvSize = 8 * t.main_data_begin), 1e9 < l) {
var r;
- for (r = 0; r < j.MAX_HEADER_BUF; ++r) a.header[r].write_timing -= l;
+ for (r = 0; r < Z.MAX_HEADER_BUF; ++r) a.header[r].write_timing -= l;
l = 0;
}
return 0;
- }, this.copy_buffer = function (e, t, a, n, s) {
- var r = f + 1;
+ }, this.copy_buffer = function (e, t, a, s, n) {
+ var r = p + 1;
if (r <= 0) return 0;
- if (0 != n && n < r) return -1;
- if (I.arraycopy(_, 0, t, a, r), f = -1, (c = 0) != s) {
- var i = ve(1);
- i[0] = e.nMusicCRC, o.updateMusicCRC(i, t, a, r), e.nMusicCRC = i[0], 0 < r && (e.VBR_seek_table.nBytesWritten += r), e.decode_on_the_fly && me();
+ if (0 != s && s < r) return -1;
+ if ($.arraycopy(m, 0, t, a, r), p = -1, (b = 0) != n) {
+ var i = Ae(1);
+ if (i[0] = e.nMusicCRC, u.updateMusicCRC(i, t, a, r), e.nMusicCRC = i[0], 0 < r && (e.VBR_seek_table.nBytesWritten += r), e.decode_on_the_fly) for (var o, _ = ke([2, 1152]), l = r, f = -1; 0 != f;) if (f = h.hip_decode1_unclipped(e.hip, t, a, l, _[0], _[1]), l = 0, -1 == f && (f = 0), 0 < f) {
+ if (e.findPeakSample) {
+ for (o = 0; o < f; o++) _[0][o] > e.PeakSample ? e.PeakSample = _[0][o] : -_[0][o] > e.PeakSample && (e.PeakSample = -_[0][o]);
+ if (1 < e.channels_out) for (o = 0; o < f; o++) _[1][o] > e.PeakSample ? e.PeakSample = _[1][o] : -_[1][o] > e.PeakSample && (e.PeakSample = -_[1][o]);
+ }
+ if (e.findReplayGain && c.AnalyzeSamples(e.rgdata, _[0], 0, _[1], 0, f, e.channels_out) == X.GAIN_ANALYSIS_ERROR) return -6;
+ }
}
return r;
}, this.init_bit_stream_w = function (e) {
- _ = S(Y.LAME_MAXMP3BUFFER), e.h_ptr = e.w_ptr = 0, e.header[e.h_ptr].write_timing = 0, f = -1, l = c = 0;
+ m = A(U.LAME_MAXMP3BUFFER), e.h_ptr = e.w_ptr = 0, e.header[e.h_ptr].write_timing = 0, p = -1, l = b = 0;
};
}
- function e(e, t, a, n) {
- this.xlen = e, this.linmax = t, this.table = a, this.hlen = n;
+ function e(e, t, a, s) {
+ this.xlen = e, this.linmax = t, this.table = a, this.hlen = s;
}
- D.MAX_VALUE = 3.4028235e38, Me.vbr_off = new Me(0), Me.vbr_mt = new Me(1), Me.vbr_rh = new Me(2), Me.vbr_abr = new Me(3), Me.vbr_mtrh = new Me(4), Me.vbr_default = Me.vbr_mtrh, ye.STEREO = new ye(0), ye.JOINT_STEREO = new ye(1), ye.DUAL_CHANNEL = new ye(2), ye.MONO = new ye(3), ye.NOT_SET = new ye(4), O.STEPS_per_dB = 100, O.MAX_dB = 120, O.GAIN_NOT_ENOUGH_SAMPLES = -24601, O.GAIN_ANALYSIS_ERROR = 0, O.GAIN_ANALYSIS_OK = 1, O.INIT_GAIN_ANALYSIS_ERROR = 0, O.INIT_GAIN_ANALYSIS_OK = 1, O.MAX_ORDER = O.YULE_ORDER = 10, O.MAX_SAMPLES_PER_WINDOW = (O.MAX_SAMP_FREQ = 48e3) * (O.RMS_WINDOW_TIME_NUMERATOR = 1) / (O.RMS_WINDOW_TIME_DENOMINATOR = 20) + 1, y.NUMTOCENTRIES = 100, y.MAXFRAMESIZE = 2880, N.EQ = function (e, t) {
+ Ee.STEREO = new Ee(0), Ee.JOINT_STEREO = new Ee(1), Ee.DUAL_CHANNEL = new Ee(2), Ee.MONO = new Ee(3), Ee.NOT_SET = new Ee(4), X.STEPS_per_dB = 100, X.MAX_dB = 120, X.GAIN_NOT_ENOUGH_SAMPLES = -24601, X.GAIN_ANALYSIS_ERROR = 0, X.GAIN_ANALYSIS_OK = 1, X.INIT_GAIN_ANALYSIS_ERROR = 0, X.INIT_GAIN_ANALYSIS_OK = 1, X.MAX_ORDER = X.YULE_ORDER = 10, X.MAX_SAMPLES_PER_WINDOW = (X.MAX_SAMP_FREQ = 48e3) * (X.RMS_WINDOW_TIME_NUMERATOR = 1) / (X.RMS_WINDOW_TIME_DENOMINATOR = 20) + 1, M.NUMTOCENTRIES = 100, M.MAXFRAMESIZE = 2880, q.EQ = function (e, t) {
return Math.abs(e) > Math.abs(t) ? Math.abs(e - t) <= 1e-6 * Math.abs(e) : Math.abs(e - t) <= 1e-6 * Math.abs(t);
- }, N.NEQ = function (e, t) {
- return !N.EQ(e, t);
+ }, q.NEQ = function (e, t) {
+ return !q.EQ(e, t);
};
- var k = {};
- function R(e) {
+ var F = {};
+ function j(e) {
this.bits = e;
}
- function x() {
+ function y() {
this.over_noise = 0, this.tot_noise = 0, this.max_noise = 0, this.over_count = 0, this.over_SSD = 0, this.bits = 0;
}
- function r(e, t, a, n) {
- this.l = ve(1 + Ae.SBMAX_l), this.s = ve(1 + Ae.SBMAX_s), this.psfb21 = ve(1 + Ae.PSFB21), this.psfb12 = ve(1 + Ae.PSFB12);
- var s = this.l,
+ function r(e, t, a, s) {
+ this.l = Ae(1 + Pe.SBMAX_l), this.s = Ae(1 + Pe.SBMAX_s), this.psfb21 = Ae(1 + Pe.PSFB21), this.psfb12 = Ae(1 + Pe.PSFB12);
+ var n = this.l,
r = this.s;
- 4 == arguments.length && (this.arrL = e, this.arrS = t, this.arr21 = a, this.arr12 = n, I.arraycopy(this.arrL, 0, s, 0, Math.min(this.arrL.length, this.l.length)), I.arraycopy(this.arrS, 0, r, 0, Math.min(this.arrS.length, this.s.length)), I.arraycopy(this.arr21, 0, this.psfb21, 0, Math.min(this.arr21.length, this.psfb21.length)), I.arraycopy(this.arr12, 0, this.psfb12, 0, Math.min(this.arr12.length, this.psfb12.length)));
+ 4 == arguments.length && (this.arrL = e, this.arrS = t, this.arr21 = a, this.arr12 = s, $.arraycopy(this.arrL, 0, n, 0, Math.min(this.arrL.length, this.l.length)), $.arraycopy(this.arrS, 0, r, 0, Math.min(this.arrS.length, this.s.length)), $.arraycopy(this.arr21, 0, this.psfb21, 0, Math.min(this.arr21.length, this.psfb21.length)), $.arraycopy(this.arr12, 0, this.psfb12, 0, Math.min(this.arr12.length, this.psfb12.length)));
}
- function T() {
+ function x() {
var l = null,
- b = null,
- n = null;
+ m = null,
+ s = null;
this.setModules = function (e, t, a) {
- l = e, b = t, n = a;
+ l = e, m = t, s = a;
}, this.IPOW20 = function (e) {
- return h[e];
+ return u[e];
};
- var B = 2.220446049250313e-16,
- e = T.IXMAX_VAL,
- f = e + 2,
- c = T.Q_MAX,
- u = T.Q_MAX2,
- s = 100;
+ var T = 2.220446049250313e-16,
+ f = x.IXMAX_VAL + 2,
+ c = x.Q_MAX,
+ h = x.Q_MAX2,
+ n = 100;
this.nr_of_sfb_block = [[[6, 5, 5, 5], [9, 9, 9, 9], [6, 9, 9, 9]], [[6, 5, 7, 3], [9, 9, 12, 6], [6, 9, 12, 6]], [[11, 10, 0, 0], [18, 18, 0, 0], [15, 18, 0, 0]], [[7, 7, 7, 0], [12, 12, 12, 0], [6, 15, 12, 0]], [[6, 6, 6, 3], [12, 9, 9, 6], [6, 12, 9, 6]], [[8, 8, 5, 0], [15, 12, 9, 0], [6, 18, 9, 0]]];
- var M = [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 2, 2, 3, 3, 3, 2, 0];
- this.pretab = M, this.sfBandIndex = [new r([0, 6, 12, 18, 24, 30, 36, 44, 54, 66, 80, 96, 116, 140, 168, 200, 238, 284, 336, 396, 464, 522, 576], [0, 4, 8, 12, 18, 24, 32, 42, 56, 74, 100, 132, 174, 192], [0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0]), new r([0, 6, 12, 18, 24, 30, 36, 44, 54, 66, 80, 96, 114, 136, 162, 194, 232, 278, 332, 394, 464, 540, 576], [0, 4, 8, 12, 18, 26, 36, 48, 62, 80, 104, 136, 180, 192], [0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0]), new r([0, 6, 12, 18, 24, 30, 36, 44, 54, 66, 80, 96, 116, 140, 168, 200, 238, 284, 336, 396, 464, 522, 576], [0, 4, 8, 12, 18, 26, 36, 48, 62, 80, 104, 134, 174, 192], [0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0]), new r([0, 4, 8, 12, 16, 20, 24, 30, 36, 44, 52, 62, 74, 90, 110, 134, 162, 196, 238, 288, 342, 418, 576], [0, 4, 8, 12, 16, 22, 30, 40, 52, 66, 84, 106, 136, 192], [0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0]), new r([0, 4, 8, 12, 16, 20, 24, 30, 36, 42, 50, 60, 72, 88, 106, 128, 156, 190, 230, 276, 330, 384, 576], [0, 4, 8, 12, 16, 22, 28, 38, 50, 64, 80, 100, 126, 192], [0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0]), new r([0, 4, 8, 12, 16, 20, 24, 30, 36, 44, 54, 66, 82, 102, 126, 156, 194, 240, 296, 364, 448, 550, 576], [0, 4, 8, 12, 16, 22, 30, 42, 58, 78, 104, 138, 180, 192], [0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0]), new r([0, 6, 12, 18, 24, 30, 36, 44, 54, 66, 80, 96, 116, 140, 168, 200, 238, 284, 336, 396, 464, 522, 576], [0, 4, 8, 12, 18, 26, 36, 48, 62, 80, 104, 134, 174, 192], [0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0]), new r([0, 6, 12, 18, 24, 30, 36, 44, 54, 66, 80, 96, 116, 140, 168, 200, 238, 284, 336, 396, 464, 522, 576], [0, 4, 8, 12, 18, 26, 36, 48, 62, 80, 104, 134, 174, 192], [0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0]), new r([0, 12, 24, 36, 48, 60, 72, 88, 108, 132, 160, 192, 232, 280, 336, 400, 476, 566, 568, 570, 572, 574, 576], [0, 8, 16, 24, 36, 52, 72, 96, 124, 160, 162, 164, 166, 192], [0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0])];
- var y = de(c + u + 1),
- h = de(c),
- p = de(f),
- m = de(f);
+ var w = [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 2, 2, 3, 3, 3, 2, 0];
+ this.pretab = w, this.sfBandIndex = [new r([0, 6, 12, 18, 24, 30, 36, 44, 54, 66, 80, 96, 116, 140, 168, 200, 238, 284, 336, 396, 464, 522, 576], [0, 4, 8, 12, 18, 24, 32, 42, 56, 74, 100, 132, 174, 192], [0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0]), new r([0, 6, 12, 18, 24, 30, 36, 44, 54, 66, 80, 96, 114, 136, 162, 194, 232, 278, 332, 394, 464, 540, 576], [0, 4, 8, 12, 18, 26, 36, 48, 62, 80, 104, 136, 180, 192], [0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0]), new r([0, 6, 12, 18, 24, 30, 36, 44, 54, 66, 80, 96, 116, 140, 168, 200, 238, 284, 336, 396, 464, 522, 576], [0, 4, 8, 12, 18, 26, 36, 48, 62, 80, 104, 134, 174, 192], [0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0]), new r([0, 4, 8, 12, 16, 20, 24, 30, 36, 44, 52, 62, 74, 90, 110, 134, 162, 196, 238, 288, 342, 418, 576], [0, 4, 8, 12, 16, 22, 30, 40, 52, 66, 84, 106, 136, 192], [0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0]), new r([0, 4, 8, 12, 16, 20, 24, 30, 36, 42, 50, 60, 72, 88, 106, 128, 156, 190, 230, 276, 330, 384, 576], [0, 4, 8, 12, 16, 22, 28, 38, 50, 64, 80, 100, 126, 192], [0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0]), new r([0, 4, 8, 12, 16, 20, 24, 30, 36, 44, 54, 66, 82, 102, 126, 156, 194, 240, 296, 364, 448, 550, 576], [0, 4, 8, 12, 16, 22, 30, 42, 58, 78, 104, 138, 180, 192], [0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0]), new r([0, 6, 12, 18, 24, 30, 36, 44, 54, 66, 80, 96, 116, 140, 168, 200, 238, 284, 336, 396, 464, 522, 576], [0, 4, 8, 12, 18, 26, 36, 48, 62, 80, 104, 134, 174, 192], [0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0]), new r([0, 6, 12, 18, 24, 30, 36, 44, 54, 66, 80, 96, 116, 140, 168, 200, 238, 284, 336, 396, 464, 522, 576], [0, 4, 8, 12, 18, 26, 36, 48, 62, 80, 104, 134, 174, 192], [0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0]), new r([0, 12, 24, 36, 48, 60, 72, 88, 108, 132, 160, 192, 232, 280, 336, 400, 476, 566, 568, 570, 572, 574, 576], [0, 8, 16, 24, 36, 52, 72, 96, 124, 160, 162, 164, 166, 192], [0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0])];
+ var R = Be(c + h + 1),
+ u = Be(c),
+ p = Be(f),
+ b = Be(f);
function v(e, t) {
- var a = n.ATHformula(t, e);
- return a -= s, a = Math.pow(10, a / 10 + e.ATHlower);
+ var a = s.ATHformula(t, e);
+ return a -= n, a = Math.pow(10, a / 10 + e.ATHlower);
}
function A(e) {
this.s = e;
}
- this.adj43 = m, this.iteration_init = function (e) {
+ this.adj43 = b, this.iteration_init = function (e) {
var t,
a = e.internal_flags,
- n = a.l3_side;
+ s = a.l3_side;
if (0 == a.iteration_init_init) {
- for (a.iteration_init_init = 1, n.main_data_begin = 0, function (e) {
- for (var t = e.internal_flags.ATH.l, a = e.internal_flags.ATH.psfb21, n = e.internal_flags.ATH.s, s = e.internal_flags.ATH.psfb12, r = e.internal_flags, i = e.out_samplerate, o = 0; o < Ae.SBMAX_l; o++) {
+ for (a.iteration_init_init = 1, s.main_data_begin = 0, function (e) {
+ for (var t = e.internal_flags.ATH.l, a = e.internal_flags.ATH.psfb21, s = e.internal_flags.ATH.s, n = e.internal_flags.ATH.psfb12, r = e.internal_flags, i = e.out_samplerate, o = 0; o < Pe.SBMAX_l; o++) {
var _ = r.scalefac_band.l[o],
l = r.scalefac_band.l[o + 1];
- t[o] = D.MAX_VALUE;
+ t[o] = K.MAX_VALUE;
for (var f = _; f < l; f++) {
- var c = f * i / 1152,
- u = v(e, c);
- t[o] = Math.min(t[o], u);
+ var c = v(e, f * i / 1152);
+ t[o] = Math.min(t[o], c);
}
}
- for (var o = 0; o < Ae.PSFB21; o++) {
- var _ = r.scalefac_band.psfb21[o],
- l = r.scalefac_band.psfb21[o + 1];
- a[o] = D.MAX_VALUE;
- for (var f = _; f < l; f++) {
- var c = f * i / 1152,
- u = v(e, c);
- a[o] = Math.min(a[o], u);
- }
+ for (o = 0; o < Pe.PSFB21; o++) for (_ = r.scalefac_band.psfb21[o], l = r.scalefac_band.psfb21[o + 1], a[o] = K.MAX_VALUE, f = _; f < l; f++) c = v(e, f * i / 1152), a[o] = Math.min(a[o], c);
+ for (o = 0; o < Pe.SBMAX_s; o++) {
+ for (_ = r.scalefac_band.s[o], l = r.scalefac_band.s[o + 1], s[o] = K.MAX_VALUE, f = _; f < l; f++) c = v(e, f * i / 384), s[o] = Math.min(s[o], c);
+ s[o] *= r.scalefac_band.s[o + 1] - r.scalefac_band.s[o];
}
- for (var o = 0; o < Ae.SBMAX_s; o++) {
- var _ = r.scalefac_band.s[o],
- l = r.scalefac_band.s[o + 1];
- n[o] = D.MAX_VALUE;
- for (var f = _; f < l; f++) {
- var c = f * i / 384,
- u = v(e, c);
- n[o] = Math.min(n[o], u);
- }
- n[o] *= r.scalefac_band.s[o + 1] - r.scalefac_band.s[o];
+ for (o = 0; o < Pe.PSFB12; o++) {
+ for (_ = r.scalefac_band.psfb12[o], l = r.scalefac_band.psfb12[o + 1], n[o] = K.MAX_VALUE, f = _; f < l; f++) c = v(e, f * i / 384), n[o] = Math.min(n[o], c);
+ n[o] *= r.scalefac_band.s[13] - r.scalefac_band.s[12];
}
- for (var o = 0; o < Ae.PSFB12; o++) {
- var _ = r.scalefac_band.psfb12[o],
- l = r.scalefac_band.psfb12[o + 1];
- s[o] = D.MAX_VALUE;
- for (var f = _; f < l; f++) {
- var c = f * i / 384,
- u = v(e, c);
- s[o] = Math.min(s[o], u);
- }
- s[o] *= r.scalefac_band.s[13] - r.scalefac_band.s[12];
+ if (e.noATH) {
+ for (o = 0; o < Pe.SBMAX_l; o++) t[o] = 1e-20;
+ for (o = 0; o < Pe.PSFB21; o++) a[o] = 1e-20;
+ for (o = 0; o < Pe.SBMAX_s; o++) s[o] = 1e-20;
+ for (o = 0; o < Pe.PSFB12; o++) n[o] = 1e-20;
}
- e.noATH && me(), r.ATH.floor = 10 * d(v(e, -1));
+ r.ATH.floor = 10 * B(v(e, -1));
}(e), p[0] = 0, t = 1; t < f; t++) p[t] = Math.pow(t, 4 / 3);
- for (t = 0; t < f - 1; t++) m[t] = t + 1 - Math.pow(.5 * (p[t] + p[t + 1]), .75);
- for (m[t] = .5, t = 0; t < c; t++) h[t] = Math.pow(2, -.1875 * (t - 210));
- for (t = 0; t <= c + u; t++) y[t] = Math.pow(2, .25 * (t - 210 - u));
- var s, r, i, o;
- for (l.huffman_init(a), 32 <= (t = e.exp_nspsytune >> 2 & 63) && (t -= 64), s = Math.pow(10, t / 4 / 10), 32 <= (t = e.exp_nspsytune >> 8 & 63) && (t -= 64), r = Math.pow(10, t / 4 / 10), 32 <= (t = e.exp_nspsytune >> 14 & 63) && (t -= 64), i = Math.pow(10, t / 4 / 10), 32 <= (t = e.exp_nspsytune >> 20 & 63) && (t -= 64), o = i * Math.pow(10, t / 4 / 10), t = 0; t < Ae.SBMAX_l; t++) _ = t <= 6 ? s : t <= 13 ? r : t <= 20 ? i : o, a.nsPsy.longfact[t] = _;
- for (t = 0; t < Ae.SBMAX_s; t++) {
+ for (t = 0; t < f - 1; t++) b[t] = t + 1 - Math.pow(.5 * (p[t] + p[t + 1]), .75);
+ for (b[t] = .5, t = 0; t < c; t++) u[t] = Math.pow(2, -.1875 * (t - 210));
+ for (t = 0; t <= c + h; t++) R[t] = Math.pow(2, .25 * (t - 210 - h));
+ var n, r, i, o;
+ for (l.huffman_init(a), 32 <= (t = e.exp_nspsytune >> 2 & 63) && (t -= 64), n = Math.pow(10, t / 4 / 10), 32 <= (t = e.exp_nspsytune >> 8 & 63) && (t -= 64), r = Math.pow(10, t / 4 / 10), 32 <= (t = e.exp_nspsytune >> 14 & 63) && (t -= 64), i = Math.pow(10, t / 4 / 10), 32 <= (t = e.exp_nspsytune >> 20 & 63) && (t -= 64), o = i * Math.pow(10, t / 4 / 10), t = 0; t < Pe.SBMAX_l; t++) {
+ _ = t <= 6 ? n : t <= 13 ? r : t <= 20 ? i : o, a.nsPsy.longfact[t] = _;
+ }
+ for (t = 0; t < Pe.SBMAX_s; t++) {
var _;
- _ = t <= 5 ? s : t <= 10 ? r : t <= 11 ? i : o, a.nsPsy.shortfact[t] = _;
+ _ = t <= 5 ? n : t <= 10 ? r : t <= 11 ? i : o, a.nsPsy.shortfact[t] = _;
}
}
- }, this.on_pe = function (e, t, a, n, s, r) {
+ }, this.on_pe = function (e, t, a, s, n, r) {
var i,
o,
_ = e.internal_flags,
l = 0,
- f = ve(2),
- c = new R(l),
- u = b.ResvMaxBits(e, n, c, r),
- h = (l = c.bits) + u;
- for (j.MAX_BITS_PER_GRANULE < h && (h = j.MAX_BITS_PER_GRANULE), o = i = 0; o < _.channels_out; ++o) a[o] = Math.min(j.MAX_BITS_PER_CHANNEL, l / _.channels_out), f[o] = 0 | a[o] * t[s][o] / 700 - a[o], f[o] > 3 * n / 4 && (f[o] = 3 * n / 4), f[o] < 0 && (f[o] = 0), f[o] + a[o] > j.MAX_BITS_PER_CHANNEL && (f[o] = Math.max(0, j.MAX_BITS_PER_CHANNEL - a[o])), i += f[o];
- if (u < i) for (o = 0; o < _.channels_out; ++o) f[o] = u * f[o] / i;
- for (o = 0; o < _.channels_out; ++o) a[o] += f[o], u -= f[o];
+ f = Ae(2),
+ c = new j(l),
+ h = m.ResvMaxBits(e, s, c, r),
+ u = (l = c.bits) + h;
+ for (Z.MAX_BITS_PER_GRANULE < u && (u = Z.MAX_BITS_PER_GRANULE), o = i = 0; o < _.channels_out; ++o) a[o] = Math.min(Z.MAX_BITS_PER_CHANNEL, l / _.channels_out), f[o] = 0 | a[o] * t[n][o] / 700 - a[o], f[o] > 3 * s / 4 && (f[o] = 3 * s / 4), f[o] < 0 && (f[o] = 0), f[o] + a[o] > Z.MAX_BITS_PER_CHANNEL && (f[o] = Math.max(0, Z.MAX_BITS_PER_CHANNEL - a[o])), i += f[o];
+ if (h < i) for (o = 0; o < _.channels_out; ++o) f[o] = h * f[o] / i;
+ for (o = 0; o < _.channels_out; ++o) a[o] += f[o], h -= f[o];
for (o = i = 0; o < _.channels_out; ++o) i += a[o];
- return j.MAX_BITS_PER_GRANULE < i && me(), h;
+ if (Z.MAX_BITS_PER_GRANULE < i) {
+ for (o = 0; o < _.channels_out; ++o) a[o] *= Z.MAX_BITS_PER_GRANULE, a[o] /= i, a[o];
+ }
+ return u;
+ }, this.reduce_side = function (e, t, a, s) {
+ var n = .33 * (.5 - t) / .5;
+ n < 0 && (n = 0), .5 < n && (n = .5);
+ var r = 0 | .5 * n * (e[0] + e[1]);
+ r > Z.MAX_BITS_PER_CHANNEL - e[0] && (r = Z.MAX_BITS_PER_CHANNEL - e[0]), r < 0 && (r = 0), 125 <= e[1] && (125 < e[1] - r ? (e[0] < a && (e[0] += r), e[1] -= r) : (e[0] += e[1] - 125, e[1] = 125)), s < (r = e[0] + e[1]) && (e[0] = s * e[0] / r, e[1] = s * e[1] / r);
}, this.athAdjust = function (e, t, a) {
- var n = 90.30873362,
- s = V.FAST_LOG10_X(t, 10),
+ var s = 90.30873362,
+ n = ee.FAST_LOG10_X(t, 10),
r = e * e,
i = 0;
- return s -= a, 1e-20 < r && (i = 1 + V.FAST_LOG10_X(r, 10 / n)), i < 0 && (i = 0), s *= i, s += a + n - 94.82444863, Math.pow(10, .1 * s);
- }, this.calc_xmin = function (e, t, a, n) {
- var s,
+ return n -= a, 1e-20 < r && (i = 1 + ee.FAST_LOG10_X(r, 10 / s)), i < 0 && (i = 0), n *= i, n += a + s - 94.82444863, Math.pow(10, .1 * n);
+ }, this.calc_xmin = function (e, t, a, s) {
+ var n,
r = 0,
i = e.internal_flags,
o = 0,
_ = 0,
l = i.ATH,
f = a.xr,
- c = e.VBR == Me.vbr_mtrh ? 1 : 0,
- u = i.masking_lower;
- for (e.VBR != Me.vbr_mtrh && e.VBR != Me.vbr_mt || (u = 1), s = 0; s < a.psy_lmax; s++) {
- for (w = e.VBR == Me.vbr_rh || e.VBR == Me.vbr_mtrh ? athAdjust(l.adjust, l.l[s], l.floor) : l.adjust * l.l[s], v = a.width[s], S = w / v, M = B, A = v >> 1, y = 0; k = f[o] * f[o], y += k, M += k < S ? k : S, R = f[++o] * f[o], y += R, M += R < S ? R : S, o++, 0 < --A;);
- if (w < y && _++, s == Ae.SBPSY_l && me(), 0 != c && (w = M), !e.ATHonly) {
- var h = t.en.l[s];
- 0 < h && (x = y * t.thm.l[s] * u / h, 0 != c && (x *= i.nsPsy.longfact[s]), w < x && (w = x));
- }
- n[r++] = 0 != c ? w : w * i.nsPsy.longfact[s];
+ c = e.VBR == xe.vbr_mtrh ? 1 : 0,
+ h = i.masking_lower;
+ for (e.VBR != xe.vbr_mtrh && e.VBR != xe.vbr_mt || (h = 1), n = 0; n < a.psy_lmax; n++) {
+ S = (g = e.VBR == xe.vbr_rh || e.VBR == xe.vbr_mtrh ? athAdjust(l.adjust, l.l[n], l.floor) : l.adjust * l.l[n]) / (b = a.width[n]), M = T, B = b >> 1, A = 0;
+ do {
+ A += k = f[o] * f[o], M += k < S ? k : S, A += y = f[++o] * f[o], M += y < S ? y : S, o++;
+ } while (0 < --B);
+ if (g < A && _++, n == Pe.SBPSY_l) M < (R = g * i.nsPsy.longfact[n]) && (M = R);
+ if (0 != c && (g = M), !e.ATHonly) if (0 < (w = t.en.l[n])) R = A * t.thm.l[n] * h / w, 0 != c && (R *= i.nsPsy.longfact[n]), g < R && (g = R);
+ s[r++] = 0 != c ? g : g * i.nsPsy.longfact[n];
}
- var b = 575;
- if (a.block_type != Ae.SHORT_TYPE) for (var p = 576; 0 != p-- && N.EQ(f[p], 0);) b = p;
- a.max_nonzero_coeff = b;
- for (var m = a.sfb_smin; s < a.psymax; m++, s += 3) {
- var v, d, g;
- for (g = e.VBR == Me.vbr_rh || e.VBR == Me.vbr_mtrh ? athAdjust(l.adjust, l.s[m], l.floor) : l.adjust * l.s[m], v = a.width[s], d = 0; d < 3; d++) {
- var w,
+ var u = 575;
+ if (a.block_type != Pe.SHORT_TYPE) for (var m = 576; 0 != m-- && q.EQ(f[m], 0);) u = m;
+ a.max_nonzero_coeff = u;
+ for (var p = a.sfb_smin; n < a.psymax; p++, n += 3) {
+ var b, v, d;
+ for (d = e.VBR == xe.vbr_rh || e.VBR == xe.vbr_mtrh ? athAdjust(l.adjust, l.s[p], l.floor) : l.adjust * l.s[p], b = a.width[n], v = 0; v < 3; v++) {
+ var g,
S,
M,
- y = 0,
- A = v >> 1;
- S = g / v, M = B;
+ w,
+ R,
+ A = 0,
+ B = b >> 1;
+ S = d / b, M = T;
do {
- var k, R;
- k = f[o] * f[o], y += k, M += k < S ? k : S, R = f[++o] * f[o], y += R, M += R < S ? R : S, o++;
- } while (0 < --A);
- if (g < y && _++, m == Ae.SBPSY_s && me(), w = 0 != c ? M : g, !e.ATHonly && !e.ATHshort) {
- var x,
- h = t.en.s[m][d];
- 0 < h && (x = y * t.thm.s[m][d] * u / h, 0 != c && (x *= i.nsPsy.shortfact[m]), w < x && (w = x));
- }
- n[r++] = 0 != c ? w : w * i.nsPsy.shortfact[m];
+ var k, y;
+ A += k = f[o] * f[o], M += k < S ? k : S, A += y = f[++o] * f[o], M += y < S ? y : S, o++;
+ } while (0 < --B);
+ if (d < A && _++, p == Pe.SBPSY_s) M < (R = d * i.nsPsy.shortfact[p]) && (M = R);
+ if (g = 0 != c ? M : d, !e.ATHonly && !e.ATHshort) if (0 < (w = t.en.s[p][v])) R = A * t.thm.s[p][v] * h / w, 0 != c && (R *= i.nsPsy.shortfact[p]), g < R && (g = R);
+ s[r++] = 0 != c ? g : g * i.nsPsy.shortfact[p];
}
- e.useTemporal && (n[r - 3] > n[r - 3 + 1] && (n[r - 3 + 1] += (n[r - 3] - n[r - 3 + 1]) * i.decay), n[r - 3 + 1] > n[r - 3 + 2] && (n[r - 3 + 2] += (n[r - 3 + 1] - n[r - 3 + 2]) * i.decay));
+ e.useTemporal && (s[r - 3] > s[r - 3 + 1] && (s[r - 3 + 1] += (s[r - 3] - s[r - 3 + 1]) * i.decay), s[r - 3 + 1] > s[r - 3 + 2] && (s[r - 3 + 2] += (s[r - 3 + 1] - s[r - 3 + 2]) * i.decay));
}
return _;
- }, this.calc_noise_core = function (e, t, a, n) {
- var s = 0,
+ }, this.calc_noise_core = function (e, t, a, s) {
+ var n = 0,
r = t.s,
i = e.l3_enc;
- if (r > e.count1) for (; 0 != a--;) _ = e.xr[r], r++, s += _ * _, _ = e.xr[r], r++, s += _ * _;else if (r > e.big_values) {
- var o = de(2);
- for (o[0] = 0, o[1] = n; 0 != a--;) _ = Math.abs(e.xr[r]) - o[i[r]], r++, s += _ * _, _ = Math.abs(e.xr[r]) - o[i[r]], r++, s += _ * _;
+ if (r > e.count1) for (; 0 != a--;) {
+ _ = e.xr[r], r++, n += _ * _, _ = e.xr[r], r++, n += _ * _;
+ } else if (r > e.big_values) {
+ var o = Be(2);
+ for (o[0] = 0, o[1] = s; 0 != a--;) {
+ _ = Math.abs(e.xr[r]) - o[i[r]], r++, n += _ * _, _ = Math.abs(e.xr[r]) - o[i[r]], r++, n += _ * _;
+ }
} else for (; 0 != a--;) {
var _;
- _ = Math.abs(e.xr[r]) - p[i[r]] * n, r++, s += _ * _, _ = Math.abs(e.xr[r]) - p[i[r]] * n, r++, s += _ * _;
+ _ = Math.abs(e.xr[r]) - p[i[r]] * s, r++, n += _ * _, _ = Math.abs(e.xr[r]) - p[i[r]] * s, r++, n += _ * _;
}
- return t.s = r, s;
- }, this.calc_noise = function (e, t, a, n, s) {
+ return t.s = r, n;
+ }, this.calc_noise = function (e, t, a, s, n) {
var r,
i,
o = 0,
@@ -14126,54 +13799,83 @@ src: recorder-core.js,engine/mp3.js,engine/mp3-engine.js
l = 0,
f = 0,
c = 0,
- u = -20,
- h = 0,
- b = e.scalefac,
+ h = -20,
+ u = 0,
+ m = e.scalefac,
p = 0;
- for (n.over_SSD = 0, r = 0; r < e.psymax; r++) {
- var m,
- v = e.global_gain - (b[p++] + (0 != e.preflag ? M[r] : 0) << e.scalefac_scale + 1) - 8 * e.subblock_gain[e.window[r]],
+ for (r = s.over_SSD = 0; r < e.psymax; r++) {
+ var b,
+ v = e.global_gain - (m[p++] + (0 != e.preflag ? w[r] : 0) << e.scalefac_scale + 1) - 8 * e.subblock_gain[e.window[r]],
d = 0;
- if (null != s && s.step[r] == v) d = s.noise[r], h += e.width[r], a[o++] = d / t[_++], d = s.noise_log[r];else {
+ if (null != n && n.step[r] == v) d = n.noise[r], u += e.width[r], a[o++] = d / t[_++], d = n.noise_log[r];else {
var g,
- w = y[v + T.Q_MAX2];
- i = e.width[r] >> 1, h + e.width[r] > e.max_nonzero_coeff && (g = e.max_nonzero_coeff - h + 1, i = 0 < g ? g >> 1 : 0);
- var S = new A(h);
- d = this.calc_noise_core(e, S, i, w), h = S.s, null != s && (s.step[r] = v, s.noise[r] = d), d = a[o++] = d / t[_++], d = V.FAST_LOG10(Math.max(d, 1e-20)), null != s && (s.noise_log[r] = d);
+ S = R[v + x.Q_MAX2];
+ if (i = e.width[r] >> 1, u + e.width[r] > e.max_nonzero_coeff) i = 0 < (g = e.max_nonzero_coeff - u + 1) ? g >> 1 : 0;
+ var M = new A(u);
+ d = this.calc_noise_core(e, M, i, S), u = M.s, null != n && (n.step[r] = v, n.noise[r] = d), d = a[o++] = d / t[_++], d = ee.FAST_LOG10(Math.max(d, 1e-20)), null != n && (n.noise_log[r] = d);
}
- null != s && (s.global_gain = e.global_gain), c += d, 0 < d && (m = Math.max(0 | 10 * d + .5, 1), n.over_SSD += m * m, l++, f += d), u = Math.max(u, d);
+ if (null != n && (n.global_gain = e.global_gain), c += d, 0 < d) b = Math.max(0 | 10 * d + .5, 1), s.over_SSD += b * b, l++, f += d;
+ h = Math.max(h, d);
}
- return n.over_count = l, n.tot_noise = c, n.over_noise = f, n.max_noise = u, l;
+ return s.over_count = l, s.tot_noise = c, s.over_noise = f, s.max_noise = h, l;
+ }, this.set_pinfo = function (e, t, a, s, n) {
+ var r,
+ i,
+ o,
+ _,
+ l,
+ f = e.internal_flags,
+ c = 0 == t.scalefac_scale ? .5 : 1,
+ h = t.scalefac,
+ u = Be(z.SFBMAX),
+ m = Be(z.SFBMAX),
+ p = new y();
+ calc_xmin(e, a, t, u), calc_noise(t, u, m, p, null);
+ var b = 0;
+ for (i = t.sfb_lmax, t.block_type != Pe.SHORT_TYPE && 0 == t.mixed_block_flag && (i = 22), r = 0; r < i; r++) {
+ var v = f.scalefac_band.l[r],
+ d = (g = f.scalefac_band.l[r + 1]) - v;
+ for (_ = 0; b < g; b++) _ += t.xr[b] * t.xr[b];
+ _ /= d, l = 1e15, f.pinfo.en[s][n][r] = l * _, f.pinfo.xfsf[s][n][r] = l * u[r] * m[r] / d, 0 < a.en.l[r] && !e.ATHonly ? _ /= a.en.l[r] : _ = 0, f.pinfo.thr[s][n][r] = l * Math.max(_ * a.thm.l[r], f.ATH.l[r]), (f.pinfo.LAMEsfb[s][n][r] = 0) != t.preflag && 11 <= r && (f.pinfo.LAMEsfb[s][n][r] = -c * w[r]), r < Pe.SBPSY_l && (f.pinfo.LAMEsfb[s][n][r] -= c * h[r]);
+ }
+ if (t.block_type == Pe.SHORT_TYPE) for (i = r, r = t.sfb_smin; r < Pe.SBMAX_s; r++) {
+ v = f.scalefac_band.s[r], d = (g = f.scalefac_band.s[r + 1]) - v;
+ for (var g, S = 0; S < 3; S++) {
+ for (_ = 0, o = v; o < g; o++) _ += t.xr[b] * t.xr[b], b++;
+ _ = Math.max(_ / d, 1e-20), l = 1e15, f.pinfo.en_s[s][n][3 * r + S] = l * _, f.pinfo.xfsf_s[s][n][3 * r + S] = l * u[i] * m[i] / d, 0 < a.en.s[r][S] ? _ /= a.en.s[r][S] : _ = 0, (e.ATHonly || e.ATHshort) && (_ = 0), f.pinfo.thr_s[s][n][3 * r + S] = l * Math.max(_ * a.thm.s[r][S], f.ATH.s[r]), f.pinfo.LAMEsfb_s[s][n][3 * r + S] = -2 * t.subblock_gain[S], r < Pe.SBPSY_s && (f.pinfo.LAMEsfb_s[s][n][3 * r + S] -= c * h[i]), i++;
+ }
+ }
+ f.pinfo.LAMEqss[s][n] = t.global_gain, f.pinfo.LAMEmainbits[s][n] = t.part2_3_length + t.part2_length, f.pinfo.LAMEsfbits[s][n] = t.part2_length, f.pinfo.over[s][n] = p.over_count, f.pinfo.max_noise[s][n] = 10 * p.max_noise, f.pinfo.over_noise[s][n] = 10 * p.over_noise, f.pinfo.tot_noise[s][n] = 10 * p.tot_noise, f.pinfo.over_SSD[s][n] = p.over_SSD;
};
}
- function B() {
- this.xr = de(576), this.l3_enc = ve(576), this.scalefac = ve(F.SFBMAX), this.xrpow_max = 0, this.part2_3_length = 0, this.big_values = 0, this.count1 = 0, this.global_gain = 0, this.scalefac_compress = 0, this.block_type = 0, this.mixed_block_flag = 0, this.table_select = ve(3), this.subblock_gain = ve(4), this.region0_count = 0, this.region1_count = 0, this.preflag = 0, this.scalefac_scale = 0, this.count1table_select = 0, this.part2_length = 0, this.sfb_lmax = 0, this.sfb_smin = 0, this.psy_lmax = 0, this.sfbmax = 0, this.psymax = 0, this.sfbdivide = 0, this.width = ve(F.SFBMAX), this.window = ve(F.SFBMAX), this.count1bits = 0, this.sfb_partition_table = null, this.slen = ve(4), this.max_nonzero_coeff = 0;
+ function T() {
+ this.xr = Be(576), this.l3_enc = Ae(576), this.scalefac = Ae(z.SFBMAX), this.xrpow_max = 0, this.part2_3_length = 0, this.big_values = 0, this.count1 = 0, this.global_gain = 0, this.scalefac_compress = 0, this.block_type = 0, this.mixed_block_flag = 0, this.table_select = Ae(3), this.subblock_gain = Ae(4), this.region0_count = 0, this.region1_count = 0, this.preflag = 0, this.scalefac_scale = 0, this.count1table_select = 0, this.part2_length = 0, this.sfb_lmax = 0, this.sfb_smin = 0, this.psy_lmax = 0, this.sfbmax = 0, this.psymax = 0, this.sfbdivide = 0, this.width = Ae(z.SFBMAX), this.window = Ae(z.SFBMAX), this.count1bits = 0, this.sfb_partition_table = null, this.slen = Ae(4), this.max_nonzero_coeff = 0;
var a = this;
- function n(e) {
+ function s(e) {
return new Int32Array(e);
}
this.assign = function (e) {
var t;
- a.xr = (t = e.xr, new Float32Array(t)), a.l3_enc = n(e.l3_enc), a.scalefac = n(e.scalefac), a.xrpow_max = e.xrpow_max, a.part2_3_length = e.part2_3_length, a.big_values = e.big_values, a.count1 = e.count1, a.global_gain = e.global_gain, a.scalefac_compress = e.scalefac_compress, a.block_type = e.block_type, a.mixed_block_flag = e.mixed_block_flag, a.table_select = n(e.table_select), a.subblock_gain = n(e.subblock_gain), a.region0_count = e.region0_count, a.region1_count = e.region1_count, a.preflag = e.preflag, a.scalefac_scale = e.scalefac_scale, a.count1table_select = e.count1table_select, a.part2_length = e.part2_length, a.sfb_lmax = e.sfb_lmax, a.sfb_smin = e.sfb_smin, a.psy_lmax = e.psy_lmax, a.sfbmax = e.sfbmax, a.psymax = e.psymax, a.sfbdivide = e.sfbdivide, a.width = n(e.width), a.window = n(e.window), a.count1bits = e.count1bits, a.sfb_partition_table = e.sfb_partition_table.slice(0), a.slen = n(e.slen), a.max_nonzero_coeff = e.max_nonzero_coeff;
+ a.xr = (t = e.xr, new Float32Array(t)), a.l3_enc = s(e.l3_enc), a.scalefac = s(e.scalefac), a.xrpow_max = e.xrpow_max, a.part2_3_length = e.part2_3_length, a.big_values = e.big_values, a.count1 = e.count1, a.global_gain = e.global_gain, a.scalefac_compress = e.scalefac_compress, a.block_type = e.block_type, a.mixed_block_flag = e.mixed_block_flag, a.table_select = s(e.table_select), a.subblock_gain = s(e.subblock_gain), a.region0_count = e.region0_count, a.region1_count = e.region1_count, a.preflag = e.preflag, a.scalefac_scale = e.scalefac_scale, a.count1table_select = e.count1table_select, a.part2_length = e.part2_length, a.sfb_lmax = e.sfb_lmax, a.sfb_smin = e.sfb_smin, a.psy_lmax = e.psy_lmax, a.sfbmax = e.sfbmax, a.psymax = e.psymax, a.sfbdivide = e.sfbdivide, a.width = s(e.width), a.window = s(e.window), a.count1bits = e.count1bits, a.sfb_partition_table = e.sfb_partition_table.slice(0), a.slen = s(e.slen), a.max_nonzero_coeff = e.max_nonzero_coeff;
};
}
- k.t1HB = [1, 1, 1, 0], k.t2HB = [1, 2, 1, 3, 1, 1, 3, 2, 0], k.t3HB = [3, 2, 1, 1, 1, 1, 3, 2, 0], k.t5HB = [1, 2, 6, 5, 3, 1, 4, 4, 7, 5, 7, 1, 6, 1, 1, 0], k.t6HB = [7, 3, 5, 1, 6, 2, 3, 2, 5, 4, 4, 1, 3, 3, 2, 0], k.t7HB = [1, 2, 10, 19, 16, 10, 3, 3, 7, 10, 5, 3, 11, 4, 13, 17, 8, 4, 12, 11, 18, 15, 11, 2, 7, 6, 9, 14, 3, 1, 6, 4, 5, 3, 2, 0], k.t8HB = [3, 4, 6, 18, 12, 5, 5, 1, 2, 16, 9, 3, 7, 3, 5, 14, 7, 3, 19, 17, 15, 13, 10, 4, 13, 5, 8, 11, 5, 1, 12, 4, 4, 1, 1, 0], k.t9HB = [7, 5, 9, 14, 15, 7, 6, 4, 5, 5, 6, 7, 7, 6, 8, 8, 8, 5, 15, 6, 9, 10, 5, 1, 11, 7, 9, 6, 4, 1, 14, 4, 6, 2, 6, 0], k.t10HB = [1, 2, 10, 23, 35, 30, 12, 17, 3, 3, 8, 12, 18, 21, 12, 7, 11, 9, 15, 21, 32, 40, 19, 6, 14, 13, 22, 34, 46, 23, 18, 7, 20, 19, 33, 47, 27, 22, 9, 3, 31, 22, 41, 26, 21, 20, 5, 3, 14, 13, 10, 11, 16, 6, 5, 1, 9, 8, 7, 8, 4, 4, 2, 0], k.t11HB = [3, 4, 10, 24, 34, 33, 21, 15, 5, 3, 4, 10, 32, 17, 11, 10, 11, 7, 13, 18, 30, 31, 20, 5, 25, 11, 19, 59, 27, 18, 12, 5, 35, 33, 31, 58, 30, 16, 7, 5, 28, 26, 32, 19, 17, 15, 8, 14, 14, 12, 9, 13, 14, 9, 4, 1, 11, 4, 6, 6, 6, 3, 2, 0], k.t12HB = [9, 6, 16, 33, 41, 39, 38, 26, 7, 5, 6, 9, 23, 16, 26, 11, 17, 7, 11, 14, 21, 30, 10, 7, 17, 10, 15, 12, 18, 28, 14, 5, 32, 13, 22, 19, 18, 16, 9, 5, 40, 17, 31, 29, 17, 13, 4, 2, 27, 12, 11, 15, 10, 7, 4, 1, 27, 12, 8, 12, 6, 3, 1, 0], k.t13HB = [1, 5, 14, 21, 34, 51, 46, 71, 42, 52, 68, 52, 67, 44, 43, 19, 3, 4, 12, 19, 31, 26, 44, 33, 31, 24, 32, 24, 31, 35, 22, 14, 15, 13, 23, 36, 59, 49, 77, 65, 29, 40, 30, 40, 27, 33, 42, 16, 22, 20, 37, 61, 56, 79, 73, 64, 43, 76, 56, 37, 26, 31, 25, 14, 35, 16, 60, 57, 97, 75, 114, 91, 54, 73, 55, 41, 48, 53, 23, 24, 58, 27, 50, 96, 76, 70, 93, 84, 77, 58, 79, 29, 74, 49, 41, 17, 47, 45, 78, 74, 115, 94, 90, 79, 69, 83, 71, 50, 59, 38, 36, 15, 72, 34, 56, 95, 92, 85, 91, 90, 86, 73, 77, 65, 51, 44, 43, 42, 43, 20, 30, 44, 55, 78, 72, 87, 78, 61, 46, 54, 37, 30, 20, 16, 53, 25, 41, 37, 44, 59, 54, 81, 66, 76, 57, 54, 37, 18, 39, 11, 35, 33, 31, 57, 42, 82, 72, 80, 47, 58, 55, 21, 22, 26, 38, 22, 53, 25, 23, 38, 70, 60, 51, 36, 55, 26, 34, 23, 27, 14, 9, 7, 34, 32, 28, 39, 49, 75, 30, 52, 48, 40, 52, 28, 18, 17, 9, 5, 45, 21, 34, 64, 56, 50, 49, 45, 31, 19, 12, 15, 10, 7, 6, 3, 48, 23, 20, 39, 36, 35, 53, 21, 16, 23, 13, 10, 6, 1, 4, 2, 16, 15, 17, 27, 25, 20, 29, 11, 17, 12, 16, 8, 1, 1, 0, 1], k.t15HB = [7, 12, 18, 53, 47, 76, 124, 108, 89, 123, 108, 119, 107, 81, 122, 63, 13, 5, 16, 27, 46, 36, 61, 51, 42, 70, 52, 83, 65, 41, 59, 36, 19, 17, 15, 24, 41, 34, 59, 48, 40, 64, 50, 78, 62, 80, 56, 33, 29, 28, 25, 43, 39, 63, 55, 93, 76, 59, 93, 72, 54, 75, 50, 29, 52, 22, 42, 40, 67, 57, 95, 79, 72, 57, 89, 69, 49, 66, 46, 27, 77, 37, 35, 66, 58, 52, 91, 74, 62, 48, 79, 63, 90, 62, 40, 38, 125, 32, 60, 56, 50, 92, 78, 65, 55, 87, 71, 51, 73, 51, 70, 30, 109, 53, 49, 94, 88, 75, 66, 122, 91, 73, 56, 42, 64, 44, 21, 25, 90, 43, 41, 77, 73, 63, 56, 92, 77, 66, 47, 67, 48, 53, 36, 20, 71, 34, 67, 60, 58, 49, 88, 76, 67, 106, 71, 54, 38, 39, 23, 15, 109, 53, 51, 47, 90, 82, 58, 57, 48, 72, 57, 41, 23, 27, 62, 9, 86, 42, 40, 37, 70, 64, 52, 43, 70, 55, 42, 25, 29, 18, 11, 11, 118, 68, 30, 55, 50, 46, 74, 65, 49, 39, 24, 16, 22, 13, 14, 7, 91, 44, 39, 38, 34, 63, 52, 45, 31, 52, 28, 19, 14, 8, 9, 3, 123, 60, 58, 53, 47, 43, 32, 22, 37, 24, 17, 12, 15, 10, 2, 1, 71, 37, 34, 30, 28, 20, 17, 26, 21, 16, 10, 6, 8, 6, 2, 0], k.t16HB = [1, 5, 14, 44, 74, 63, 110, 93, 172, 149, 138, 242, 225, 195, 376, 17, 3, 4, 12, 20, 35, 62, 53, 47, 83, 75, 68, 119, 201, 107, 207, 9, 15, 13, 23, 38, 67, 58, 103, 90, 161, 72, 127, 117, 110, 209, 206, 16, 45, 21, 39, 69, 64, 114, 99, 87, 158, 140, 252, 212, 199, 387, 365, 26, 75, 36, 68, 65, 115, 101, 179, 164, 155, 264, 246, 226, 395, 382, 362, 9, 66, 30, 59, 56, 102, 185, 173, 265, 142, 253, 232, 400, 388, 378, 445, 16, 111, 54, 52, 100, 184, 178, 160, 133, 257, 244, 228, 217, 385, 366, 715, 10, 98, 48, 91, 88, 165, 157, 148, 261, 248, 407, 397, 372, 380, 889, 884, 8, 85, 84, 81, 159, 156, 143, 260, 249, 427, 401, 392, 383, 727, 713, 708, 7, 154, 76, 73, 141, 131, 256, 245, 426, 406, 394, 384, 735, 359, 710, 352, 11, 139, 129, 67, 125, 247, 233, 229, 219, 393, 743, 737, 720, 885, 882, 439, 4, 243, 120, 118, 115, 227, 223, 396, 746, 742, 736, 721, 712, 706, 223, 436, 6, 202, 224, 222, 218, 216, 389, 386, 381, 364, 888, 443, 707, 440, 437, 1728, 4, 747, 211, 210, 208, 370, 379, 734, 723, 714, 1735, 883, 877, 876, 3459, 865, 2, 377, 369, 102, 187, 726, 722, 358, 711, 709, 866, 1734, 871, 3458, 870, 434, 0, 12, 10, 7, 11, 10, 17, 11, 9, 13, 12, 10, 7, 5, 3, 1, 3], k.t24HB = [15, 13, 46, 80, 146, 262, 248, 434, 426, 669, 653, 649, 621, 517, 1032, 88, 14, 12, 21, 38, 71, 130, 122, 216, 209, 198, 327, 345, 319, 297, 279, 42, 47, 22, 41, 74, 68, 128, 120, 221, 207, 194, 182, 340, 315, 295, 541, 18, 81, 39, 75, 70, 134, 125, 116, 220, 204, 190, 178, 325, 311, 293, 271, 16, 147, 72, 69, 135, 127, 118, 112, 210, 200, 188, 352, 323, 306, 285, 540, 14, 263, 66, 129, 126, 119, 114, 214, 202, 192, 180, 341, 317, 301, 281, 262, 12, 249, 123, 121, 117, 113, 215, 206, 195, 185, 347, 330, 308, 291, 272, 520, 10, 435, 115, 111, 109, 211, 203, 196, 187, 353, 332, 313, 298, 283, 531, 381, 17, 427, 212, 208, 205, 201, 193, 186, 177, 169, 320, 303, 286, 268, 514, 377, 16, 335, 199, 197, 191, 189, 181, 174, 333, 321, 305, 289, 275, 521, 379, 371, 11, 668, 184, 183, 179, 175, 344, 331, 314, 304, 290, 277, 530, 383, 373, 366, 10, 652, 346, 171, 168, 164, 318, 309, 299, 287, 276, 263, 513, 375, 368, 362, 6, 648, 322, 316, 312, 307, 302, 292, 284, 269, 261, 512, 376, 370, 364, 359, 4, 620, 300, 296, 294, 288, 282, 273, 266, 515, 380, 374, 369, 365, 361, 357, 2, 1033, 280, 278, 274, 267, 264, 259, 382, 378, 372, 367, 363, 360, 358, 356, 0, 43, 20, 19, 17, 15, 13, 11, 9, 7, 6, 4, 7, 5, 3, 1, 3], k.t32HB = [1, 10, 8, 20, 12, 20, 16, 32, 14, 12, 24, 0, 28, 16, 24, 16], k.t33HB = [15, 28, 26, 48, 22, 40, 36, 64, 14, 24, 20, 32, 12, 16, 8, 0], k.t1l = [1, 4, 3, 5], k.t2l = [1, 4, 7, 4, 5, 7, 6, 7, 8], k.t3l = [2, 3, 7, 4, 4, 7, 6, 7, 8], k.t5l = [1, 4, 7, 8, 4, 5, 8, 9, 7, 8, 9, 10, 8, 8, 9, 10], k.t6l = [3, 4, 6, 8, 4, 4, 6, 7, 5, 6, 7, 8, 7, 7, 8, 9], k.t7l = [1, 4, 7, 9, 9, 10, 4, 6, 8, 9, 9, 10, 7, 7, 9, 10, 10, 11, 8, 9, 10, 11, 11, 11, 8, 9, 10, 11, 11, 12, 9, 10, 11, 12, 12, 12], k.t8l = [2, 4, 7, 9, 9, 10, 4, 4, 6, 10, 10, 10, 7, 6, 8, 10, 10, 11, 9, 10, 10, 11, 11, 12, 9, 9, 10, 11, 12, 12, 10, 10, 11, 11, 13, 13], k.t9l = [3, 4, 6, 7, 9, 10, 4, 5, 6, 7, 8, 10, 5, 6, 7, 8, 9, 10, 7, 7, 8, 9, 9, 10, 8, 8, 9, 9, 10, 11, 9, 9, 10, 10, 11, 11], k.t10l = [1, 4, 7, 9, 10, 10, 10, 11, 4, 6, 8, 9, 10, 11, 10, 10, 7, 8, 9, 10, 11, 12, 11, 11, 8, 9, 10, 11, 12, 12, 11, 12, 9, 10, 11, 12, 12, 12, 12, 12, 10, 11, 12, 12, 13, 13, 12, 13, 9, 10, 11, 12, 12, 12, 13, 13, 10, 10, 11, 12, 12, 13, 13, 13], k.t11l = [2, 4, 6, 8, 9, 10, 9, 10, 4, 5, 6, 8, 10, 10, 9, 10, 6, 7, 8, 9, 10, 11, 10, 10, 8, 8, 9, 11, 10, 12, 10, 11, 9, 10, 10, 11, 11, 12, 11, 12, 9, 10, 11, 12, 12, 13, 12, 13, 9, 9, 9, 10, 11, 12, 12, 12, 9, 9, 10, 11, 12, 12, 12, 12], k.t12l = [4, 4, 6, 8, 9, 10, 10, 10, 4, 5, 6, 7, 9, 9, 10, 10, 6, 6, 7, 8, 9, 10, 9, 10, 7, 7, 8, 8, 9, 10, 10, 10, 8, 8, 9, 9, 10, 10, 10, 11, 9, 9, 10, 10, 10, 11, 10, 11, 9, 9, 9, 10, 10, 11, 11, 12, 10, 10, 10, 11, 11, 11, 11, 12], k.t13l = [1, 5, 7, 8, 9, 10, 10, 11, 10, 11, 12, 12, 13, 13, 14, 14, 4, 6, 8, 9, 10, 10, 11, 11, 11, 11, 12, 12, 13, 14, 14, 14, 7, 8, 9, 10, 11, 11, 12, 12, 11, 12, 12, 13, 13, 14, 15, 15, 8, 9, 10, 11, 11, 12, 12, 12, 12, 13, 13, 13, 13, 14, 15, 15, 9, 9, 11, 11, 12, 12, 13, 13, 12, 13, 13, 14, 14, 15, 15, 16, 10, 10, 11, 12, 12, 12, 13, 13, 13, 13, 14, 13, 15, 15, 16, 16, 10, 11, 12, 12, 13, 13, 13, 13, 13, 14, 14, 14, 15, 15, 16, 16, 11, 11, 12, 13, 13, 13, 14, 14, 14, 14, 15, 15, 15, 16, 18, 18, 10, 10, 11, 12, 12, 13, 13, 14, 14, 14, 14, 15, 15, 16, 17, 17, 11, 11, 12, 12, 13, 13, 13, 15, 14, 15, 15, 16, 16, 16, 18, 17, 11, 12, 12, 13, 13, 14, 14, 15, 14, 15, 16, 15, 16, 17, 18, 19, 12, 12, 12, 13, 14, 14, 14, 14, 15, 15, 15, 16, 17, 17, 17, 18, 12, 13, 13, 14, 14, 15, 14, 15, 16, 16, 17, 17, 17, 18, 18, 18, 13, 13, 14, 15, 15, 15, 16, 16, 16, 16, 16, 17, 18, 17, 18, 18, 14, 14, 14, 15, 15, 15, 17, 16, 16, 19, 17, 17, 17, 19, 18, 18, 13, 14, 15, 16, 16, 16, 17, 16, 17, 17, 18, 18, 21, 20, 21, 18], k.t15l = [3, 5, 6, 8, 8, 9, 10, 10, 10, 11, 11, 12, 12, 12, 13, 14, 5, 5, 7, 8, 9, 9, 10, 10, 10, 11, 11, 12, 12, 12, 13, 13, 6, 7, 7, 8, 9, 9, 10, 10, 10, 11, 11, 12, 12, 13, 13, 13, 7, 8, 8, 9, 9, 10, 10, 11, 11, 11, 12, 12, 12, 13, 13, 13, 8, 8, 9, 9, 10, 10, 11, 11, 11, 11, 12, 12, 12, 13, 13, 13, 9, 9, 9, 10, 10, 10, 11, 11, 11, 11, 12, 12, 13, 13, 13, 14, 10, 9, 10, 10, 10, 11, 11, 11, 11, 12, 12, 12, 13, 13, 14, 14, 10, 10, 10, 11, 11, 11, 11, 12, 12, 12, 12, 12, 13, 13, 13, 14, 10, 10, 10, 11, 11, 11, 11, 12, 12, 12, 12, 13, 13, 14, 14, 14, 10, 10, 11, 11, 11, 11, 12, 12, 12, 13, 13, 13, 13, 14, 14, 14, 11, 11, 11, 11, 12, 12, 12, 12, 12, 13, 13, 13, 13, 14, 15, 14, 11, 11, 11, 11, 12, 12, 12, 12, 13, 13, 13, 13, 14, 14, 14, 15, 12, 12, 11, 12, 12, 12, 13, 13, 13, 13, 13, 13, 14, 14, 15, 15, 12, 12, 12, 12, 12, 13, 13, 13, 13, 14, 14, 14, 14, 14, 15, 15, 13, 13, 13, 13, 13, 13, 13, 13, 14, 14, 14, 14, 15, 15, 14, 15, 13, 13, 13, 13, 13, 13, 13, 14, 14, 14, 14, 14, 15, 15, 15, 15], k.t16_5l = [1, 5, 7, 9, 10, 10, 11, 11, 12, 12, 12, 13, 13, 13, 14, 11, 4, 6, 8, 9, 10, 11, 11, 11, 12, 12, 12, 13, 14, 13, 14, 11, 7, 8, 9, 10, 11, 11, 12, 12, 13, 12, 13, 13, 13, 14, 14, 12, 9, 9, 10, 11, 11, 12, 12, 12, 13, 13, 14, 14, 14, 15, 15, 13, 10, 10, 11, 11, 12, 12, 13, 13, 13, 14, 14, 14, 15, 15, 15, 12, 10, 10, 11, 11, 12, 13, 13, 14, 13, 14, 14, 15, 15, 15, 16, 13, 11, 11, 11, 12, 13, 13, 13, 13, 14, 14, 14, 14, 15, 15, 16, 13, 11, 11, 12, 12, 13, 13, 13, 14, 14, 15, 15, 15, 15, 17, 17, 13, 11, 12, 12, 13, 13, 13, 14, 14, 15, 15, 15, 15, 16, 16, 16, 13, 12, 12, 12, 13, 13, 14, 14, 15, 15, 15, 15, 16, 15, 16, 15, 14, 12, 13, 12, 13, 14, 14, 14, 14, 15, 16, 16, 16, 17, 17, 16, 13, 13, 13, 13, 13, 14, 14, 15, 16, 16, 16, 16, 16, 16, 15, 16, 14, 13, 14, 14, 14, 14, 15, 15, 15, 15, 17, 16, 16, 16, 16, 18, 14, 15, 14, 14, 14, 15, 15, 16, 16, 16, 18, 17, 17, 17, 19, 17, 14, 14, 15, 13, 14, 16, 16, 15, 16, 16, 17, 18, 17, 19, 17, 16, 14, 11, 11, 11, 12, 12, 13, 13, 13, 14, 14, 14, 14, 14, 14, 14, 12], k.t16l = [1, 5, 7, 9, 10, 10, 11, 11, 12, 12, 12, 13, 13, 13, 14, 10, 4, 6, 8, 9, 10, 11, 11, 11, 12, 12, 12, 13, 14, 13, 14, 10, 7, 8, 9, 10, 11, 11, 12, 12, 13, 12, 13, 13, 13, 14, 14, 11, 9, 9, 10, 11, 11, 12, 12, 12, 13, 13, 14, 14, 14, 15, 15, 12, 10, 10, 11, 11, 12, 12, 13, 13, 13, 14, 14, 14, 15, 15, 15, 11, 10, 10, 11, 11, 12, 13, 13, 14, 13, 14, 14, 15, 15, 15, 16, 12, 11, 11, 11, 12, 13, 13, 13, 13, 14, 14, 14, 14, 15, 15, 16, 12, 11, 11, 12, 12, 13, 13, 13, 14, 14, 15, 15, 15, 15, 17, 17, 12, 11, 12, 12, 13, 13, 13, 14, 14, 15, 15, 15, 15, 16, 16, 16, 12, 12, 12, 12, 13, 13, 14, 14, 15, 15, 15, 15, 16, 15, 16, 15, 13, 12, 13, 12, 13, 14, 14, 14, 14, 15, 16, 16, 16, 17, 17, 16, 12, 13, 13, 13, 13, 14, 14, 15, 16, 16, 16, 16, 16, 16, 15, 16, 13, 13, 14, 14, 14, 14, 15, 15, 15, 15, 17, 16, 16, 16, 16, 18, 13, 15, 14, 14, 14, 15, 15, 16, 16, 16, 18, 17, 17, 17, 19, 17, 13, 14, 15, 13, 14, 16, 16, 15, 16, 16, 17, 18, 17, 19, 17, 16, 13, 10, 10, 10, 11, 11, 12, 12, 12, 13, 13, 13, 13, 13, 13, 13, 10], k.t24l = [4, 5, 7, 8, 9, 10, 10, 11, 11, 12, 12, 12, 12, 12, 13, 10, 5, 6, 7, 8, 9, 10, 10, 11, 11, 11, 12, 12, 12, 12, 12, 10, 7, 7, 8, 9, 9, 10, 10, 11, 11, 11, 11, 12, 12, 12, 13, 9, 8, 8, 9, 9, 10, 10, 10, 11, 11, 11, 11, 12, 12, 12, 12, 9, 9, 9, 9, 10, 10, 10, 10, 11, 11, 11, 12, 12, 12, 12, 13, 9, 10, 9, 10, 10, 10, 10, 11, 11, 11, 11, 12, 12, 12, 12, 12, 9, 10, 10, 10, 10, 10, 11, 11, 11, 11, 12, 12, 12, 12, 12, 13, 9, 11, 10, 10, 10, 11, 11, 11, 11, 12, 12, 12, 12, 12, 13, 13, 10, 11, 11, 11, 11, 11, 11, 11, 11, 11, 12, 12, 12, 12, 13, 13, 10, 11, 11, 11, 11, 11, 11, 11, 12, 12, 12, 12, 12, 13, 13, 13, 10, 12, 11, 11, 11, 11, 12, 12, 12, 12, 12, 12, 13, 13, 13, 13, 10, 12, 12, 11, 11, 11, 12, 12, 12, 12, 12, 12, 13, 13, 13, 13, 10, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 13, 13, 13, 13, 13, 10, 12, 12, 12, 12, 12, 12, 12, 12, 13, 13, 13, 13, 13, 13, 13, 10, 13, 12, 12, 12, 12, 12, 12, 13, 13, 13, 13, 13, 13, 13, 13, 10, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 10, 10, 10, 10, 6], k.t32l = [1, 5, 5, 7, 5, 8, 7, 9, 5, 7, 7, 9, 7, 9, 9, 10], k.t33l = [4, 5, 5, 6, 5, 6, 6, 7, 5, 6, 6, 7, 6, 7, 7, 8], k.ht = [new e(0, 0, null, null), new e(2, 0, k.t1HB, k.t1l), new e(3, 0, k.t2HB, k.t2l), new e(3, 0, k.t3HB, k.t3l), new e(0, 0, null, null), new e(4, 0, k.t5HB, k.t5l), new e(4, 0, k.t6HB, k.t6l), new e(6, 0, k.t7HB, k.t7l), new e(6, 0, k.t8HB, k.t8l), new e(6, 0, k.t9HB, k.t9l), new e(8, 0, k.t10HB, k.t10l), new e(8, 0, k.t11HB, k.t11l), new e(8, 0, k.t12HB, k.t12l), new e(16, 0, k.t13HB, k.t13l), new e(0, 0, null, k.t16_5l), new e(16, 0, k.t15HB, k.t15l), new e(1, 1, k.t16HB, k.t16l), new e(2, 3, k.t16HB, k.t16l), new e(3, 7, k.t16HB, k.t16l), new e(4, 15, k.t16HB, k.t16l), new e(6, 63, k.t16HB, k.t16l), new e(8, 255, k.t16HB, k.t16l), new e(10, 1023, k.t16HB, k.t16l), new e(13, 8191, k.t16HB, k.t16l), new e(4, 15, k.t24HB, k.t24l), new e(5, 31, k.t24HB, k.t24l), new e(6, 63, k.t24HB, k.t24l), new e(7, 127, k.t24HB, k.t24l), new e(8, 255, k.t24HB, k.t24l), new e(9, 511, k.t24HB, k.t24l), new e(11, 2047, k.t24HB, k.t24l), new e(13, 8191, k.t24HB, k.t24l), new e(0, 0, k.t32HB, k.t32l), new e(0, 0, k.t33HB, k.t33l)], k.largetbl = [65540, 327685, 458759, 589832, 655369, 655370, 720906, 720907, 786443, 786444, 786444, 851980, 851980, 851980, 917517, 655370, 262149, 393222, 524295, 589832, 655369, 720906, 720906, 720907, 786443, 786443, 786444, 851980, 917516, 851980, 917516, 655370, 458759, 524295, 589832, 655369, 720905, 720906, 786442, 786443, 851979, 786443, 851979, 851980, 851980, 917516, 917517, 720905, 589832, 589832, 655369, 720905, 720906, 786442, 786442, 786443, 851979, 851979, 917515, 917516, 917516, 983052, 983052, 786441, 655369, 655369, 720905, 720906, 786442, 786442, 851978, 851979, 851979, 917515, 917516, 917516, 983052, 983052, 983053, 720905, 655370, 655369, 720906, 720906, 786442, 851978, 851979, 917515, 851979, 917515, 917516, 983052, 983052, 983052, 1048588, 786441, 720906, 720906, 720906, 786442, 851978, 851979, 851979, 851979, 917515, 917516, 917516, 917516, 983052, 983052, 1048589, 786441, 720907, 720906, 786442, 786442, 851979, 851979, 851979, 917515, 917516, 983052, 983052, 983052, 983052, 1114125, 1114125, 786442, 720907, 786443, 786443, 851979, 851979, 851979, 917515, 917515, 983051, 983052, 983052, 983052, 1048588, 1048589, 1048589, 786442, 786443, 786443, 786443, 851979, 851979, 917515, 917515, 983052, 983052, 983052, 983052, 1048588, 983053, 1048589, 983053, 851978, 786444, 851979, 786443, 851979, 917515, 917516, 917516, 917516, 983052, 1048588, 1048588, 1048589, 1114125, 1114125, 1048589, 786442, 851980, 851980, 851979, 851979, 917515, 917516, 983052, 1048588, 1048588, 1048588, 1048588, 1048589, 1048589, 983053, 1048589, 851978, 851980, 917516, 917516, 917516, 917516, 983052, 983052, 983052, 983052, 1114124, 1048589, 1048589, 1048589, 1048589, 1179661, 851978, 983052, 917516, 917516, 917516, 983052, 983052, 1048588, 1048588, 1048589, 1179661, 1114125, 1114125, 1114125, 1245197, 1114125, 851978, 917517, 983052, 851980, 917516, 1048588, 1048588, 983052, 1048589, 1048589, 1114125, 1179661, 1114125, 1245197, 1114125, 1048589, 851978, 655369, 655369, 655369, 720905, 720905, 786441, 786441, 786441, 851977, 851977, 851977, 851978, 851978, 851978, 851978, 655366], k.table23 = [65538, 262147, 458759, 262148, 327684, 458759, 393222, 458759, 524296], k.table56 = [65539, 262148, 458758, 524296, 262148, 327684, 524294, 589831, 458757, 524294, 589831, 655368, 524295, 524295, 589832, 655369], k.bitrate_table = [[0, 8, 16, 24, 32, 40, 48, 56, 64, 80, 96, 112, 128, 144, 160, -1], [0, 32, 40, 48, 56, 64, 80, 96, 112, 128, 160, 192, 224, 256, 320, -1], [0, 8, 16, 24, 32, 40, 48, 56, 64, -1, -1, -1, -1, -1, -1, -1]], k.samplerate_table = [[22050, 24e3, 16e3, -1], [44100, 48e3, 32e3, -1], [11025, 12e3, 8e3, -1]], k.scfsi_band = [0, 6, 11, 16, 21], T.Q_MAX = 257, T.Q_MAX2 = 116, T.LARGE_BITS = 1e5, T.IXMAX_VAL = 8206;
- var F = {};
- function C() {
- var r, g;
+ F.t1HB = [1, 1, 1, 0], F.t2HB = [1, 2, 1, 3, 1, 1, 3, 2, 0], F.t3HB = [3, 2, 1, 1, 1, 1, 3, 2, 0], F.t5HB = [1, 2, 6, 5, 3, 1, 4, 4, 7, 5, 7, 1, 6, 1, 1, 0], F.t6HB = [7, 3, 5, 1, 6, 2, 3, 2, 5, 4, 4, 1, 3, 3, 2, 0], F.t7HB = [1, 2, 10, 19, 16, 10, 3, 3, 7, 10, 5, 3, 11, 4, 13, 17, 8, 4, 12, 11, 18, 15, 11, 2, 7, 6, 9, 14, 3, 1, 6, 4, 5, 3, 2, 0], F.t8HB = [3, 4, 6, 18, 12, 5, 5, 1, 2, 16, 9, 3, 7, 3, 5, 14, 7, 3, 19, 17, 15, 13, 10, 4, 13, 5, 8, 11, 5, 1, 12, 4, 4, 1, 1, 0], F.t9HB = [7, 5, 9, 14, 15, 7, 6, 4, 5, 5, 6, 7, 7, 6, 8, 8, 8, 5, 15, 6, 9, 10, 5, 1, 11, 7, 9, 6, 4, 1, 14, 4, 6, 2, 6, 0], F.t10HB = [1, 2, 10, 23, 35, 30, 12, 17, 3, 3, 8, 12, 18, 21, 12, 7, 11, 9, 15, 21, 32, 40, 19, 6, 14, 13, 22, 34, 46, 23, 18, 7, 20, 19, 33, 47, 27, 22, 9, 3, 31, 22, 41, 26, 21, 20, 5, 3, 14, 13, 10, 11, 16, 6, 5, 1, 9, 8, 7, 8, 4, 4, 2, 0], F.t11HB = [3, 4, 10, 24, 34, 33, 21, 15, 5, 3, 4, 10, 32, 17, 11, 10, 11, 7, 13, 18, 30, 31, 20, 5, 25, 11, 19, 59, 27, 18, 12, 5, 35, 33, 31, 58, 30, 16, 7, 5, 28, 26, 32, 19, 17, 15, 8, 14, 14, 12, 9, 13, 14, 9, 4, 1, 11, 4, 6, 6, 6, 3, 2, 0], F.t12HB = [9, 6, 16, 33, 41, 39, 38, 26, 7, 5, 6, 9, 23, 16, 26, 11, 17, 7, 11, 14, 21, 30, 10, 7, 17, 10, 15, 12, 18, 28, 14, 5, 32, 13, 22, 19, 18, 16, 9, 5, 40, 17, 31, 29, 17, 13, 4, 2, 27, 12, 11, 15, 10, 7, 4, 1, 27, 12, 8, 12, 6, 3, 1, 0], F.t13HB = [1, 5, 14, 21, 34, 51, 46, 71, 42, 52, 68, 52, 67, 44, 43, 19, 3, 4, 12, 19, 31, 26, 44, 33, 31, 24, 32, 24, 31, 35, 22, 14, 15, 13, 23, 36, 59, 49, 77, 65, 29, 40, 30, 40, 27, 33, 42, 16, 22, 20, 37, 61, 56, 79, 73, 64, 43, 76, 56, 37, 26, 31, 25, 14, 35, 16, 60, 57, 97, 75, 114, 91, 54, 73, 55, 41, 48, 53, 23, 24, 58, 27, 50, 96, 76, 70, 93, 84, 77, 58, 79, 29, 74, 49, 41, 17, 47, 45, 78, 74, 115, 94, 90, 79, 69, 83, 71, 50, 59, 38, 36, 15, 72, 34, 56, 95, 92, 85, 91, 90, 86, 73, 77, 65, 51, 44, 43, 42, 43, 20, 30, 44, 55, 78, 72, 87, 78, 61, 46, 54, 37, 30, 20, 16, 53, 25, 41, 37, 44, 59, 54, 81, 66, 76, 57, 54, 37, 18, 39, 11, 35, 33, 31, 57, 42, 82, 72, 80, 47, 58, 55, 21, 22, 26, 38, 22, 53, 25, 23, 38, 70, 60, 51, 36, 55, 26, 34, 23, 27, 14, 9, 7, 34, 32, 28, 39, 49, 75, 30, 52, 48, 40, 52, 28, 18, 17, 9, 5, 45, 21, 34, 64, 56, 50, 49, 45, 31, 19, 12, 15, 10, 7, 6, 3, 48, 23, 20, 39, 36, 35, 53, 21, 16, 23, 13, 10, 6, 1, 4, 2, 16, 15, 17, 27, 25, 20, 29, 11, 17, 12, 16, 8, 1, 1, 0, 1], F.t15HB = [7, 12, 18, 53, 47, 76, 124, 108, 89, 123, 108, 119, 107, 81, 122, 63, 13, 5, 16, 27, 46, 36, 61, 51, 42, 70, 52, 83, 65, 41, 59, 36, 19, 17, 15, 24, 41, 34, 59, 48, 40, 64, 50, 78, 62, 80, 56, 33, 29, 28, 25, 43, 39, 63, 55, 93, 76, 59, 93, 72, 54, 75, 50, 29, 52, 22, 42, 40, 67, 57, 95, 79, 72, 57, 89, 69, 49, 66, 46, 27, 77, 37, 35, 66, 58, 52, 91, 74, 62, 48, 79, 63, 90, 62, 40, 38, 125, 32, 60, 56, 50, 92, 78, 65, 55, 87, 71, 51, 73, 51, 70, 30, 109, 53, 49, 94, 88, 75, 66, 122, 91, 73, 56, 42, 64, 44, 21, 25, 90, 43, 41, 77, 73, 63, 56, 92, 77, 66, 47, 67, 48, 53, 36, 20, 71, 34, 67, 60, 58, 49, 88, 76, 67, 106, 71, 54, 38, 39, 23, 15, 109, 53, 51, 47, 90, 82, 58, 57, 48, 72, 57, 41, 23, 27, 62, 9, 86, 42, 40, 37, 70, 64, 52, 43, 70, 55, 42, 25, 29, 18, 11, 11, 118, 68, 30, 55, 50, 46, 74, 65, 49, 39, 24, 16, 22, 13, 14, 7, 91, 44, 39, 38, 34, 63, 52, 45, 31, 52, 28, 19, 14, 8, 9, 3, 123, 60, 58, 53, 47, 43, 32, 22, 37, 24, 17, 12, 15, 10, 2, 1, 71, 37, 34, 30, 28, 20, 17, 26, 21, 16, 10, 6, 8, 6, 2, 0], F.t16HB = [1, 5, 14, 44, 74, 63, 110, 93, 172, 149, 138, 242, 225, 195, 376, 17, 3, 4, 12, 20, 35, 62, 53, 47, 83, 75, 68, 119, 201, 107, 207, 9, 15, 13, 23, 38, 67, 58, 103, 90, 161, 72, 127, 117, 110, 209, 206, 16, 45, 21, 39, 69, 64, 114, 99, 87, 158, 140, 252, 212, 199, 387, 365, 26, 75, 36, 68, 65, 115, 101, 179, 164, 155, 264, 246, 226, 395, 382, 362, 9, 66, 30, 59, 56, 102, 185, 173, 265, 142, 253, 232, 400, 388, 378, 445, 16, 111, 54, 52, 100, 184, 178, 160, 133, 257, 244, 228, 217, 385, 366, 715, 10, 98, 48, 91, 88, 165, 157, 148, 261, 248, 407, 397, 372, 380, 889, 884, 8, 85, 84, 81, 159, 156, 143, 260, 249, 427, 401, 392, 383, 727, 713, 708, 7, 154, 76, 73, 141, 131, 256, 245, 426, 406, 394, 384, 735, 359, 710, 352, 11, 139, 129, 67, 125, 247, 233, 229, 219, 393, 743, 737, 720, 885, 882, 439, 4, 243, 120, 118, 115, 227, 223, 396, 746, 742, 736, 721, 712, 706, 223, 436, 6, 202, 224, 222, 218, 216, 389, 386, 381, 364, 888, 443, 707, 440, 437, 1728, 4, 747, 211, 210, 208, 370, 379, 734, 723, 714, 1735, 883, 877, 876, 3459, 865, 2, 377, 369, 102, 187, 726, 722, 358, 711, 709, 866, 1734, 871, 3458, 870, 434, 0, 12, 10, 7, 11, 10, 17, 11, 9, 13, 12, 10, 7, 5, 3, 1, 3], F.t24HB = [15, 13, 46, 80, 146, 262, 248, 434, 426, 669, 653, 649, 621, 517, 1032, 88, 14, 12, 21, 38, 71, 130, 122, 216, 209, 198, 327, 345, 319, 297, 279, 42, 47, 22, 41, 74, 68, 128, 120, 221, 207, 194, 182, 340, 315, 295, 541, 18, 81, 39, 75, 70, 134, 125, 116, 220, 204, 190, 178, 325, 311, 293, 271, 16, 147, 72, 69, 135, 127, 118, 112, 210, 200, 188, 352, 323, 306, 285, 540, 14, 263, 66, 129, 126, 119, 114, 214, 202, 192, 180, 341, 317, 301, 281, 262, 12, 249, 123, 121, 117, 113, 215, 206, 195, 185, 347, 330, 308, 291, 272, 520, 10, 435, 115, 111, 109, 211, 203, 196, 187, 353, 332, 313, 298, 283, 531, 381, 17, 427, 212, 208, 205, 201, 193, 186, 177, 169, 320, 303, 286, 268, 514, 377, 16, 335, 199, 197, 191, 189, 181, 174, 333, 321, 305, 289, 275, 521, 379, 371, 11, 668, 184, 183, 179, 175, 344, 331, 314, 304, 290, 277, 530, 383, 373, 366, 10, 652, 346, 171, 168, 164, 318, 309, 299, 287, 276, 263, 513, 375, 368, 362, 6, 648, 322, 316, 312, 307, 302, 292, 284, 269, 261, 512, 376, 370, 364, 359, 4, 620, 300, 296, 294, 288, 282, 273, 266, 515, 380, 374, 369, 365, 361, 357, 2, 1033, 280, 278, 274, 267, 264, 259, 382, 378, 372, 367, 363, 360, 358, 356, 0, 43, 20, 19, 17, 15, 13, 11, 9, 7, 6, 4, 7, 5, 3, 1, 3], F.t32HB = [1, 10, 8, 20, 12, 20, 16, 32, 14, 12, 24, 0, 28, 16, 24, 16], F.t33HB = [15, 28, 26, 48, 22, 40, 36, 64, 14, 24, 20, 32, 12, 16, 8, 0], F.t1l = [1, 4, 3, 5], F.t2l = [1, 4, 7, 4, 5, 7, 6, 7, 8], F.t3l = [2, 3, 7, 4, 4, 7, 6, 7, 8], F.t5l = [1, 4, 7, 8, 4, 5, 8, 9, 7, 8, 9, 10, 8, 8, 9, 10], F.t6l = [3, 4, 6, 8, 4, 4, 6, 7, 5, 6, 7, 8, 7, 7, 8, 9], F.t7l = [1, 4, 7, 9, 9, 10, 4, 6, 8, 9, 9, 10, 7, 7, 9, 10, 10, 11, 8, 9, 10, 11, 11, 11, 8, 9, 10, 11, 11, 12, 9, 10, 11, 12, 12, 12], F.t8l = [2, 4, 7, 9, 9, 10, 4, 4, 6, 10, 10, 10, 7, 6, 8, 10, 10, 11, 9, 10, 10, 11, 11, 12, 9, 9, 10, 11, 12, 12, 10, 10, 11, 11, 13, 13], F.t9l = [3, 4, 6, 7, 9, 10, 4, 5, 6, 7, 8, 10, 5, 6, 7, 8, 9, 10, 7, 7, 8, 9, 9, 10, 8, 8, 9, 9, 10, 11, 9, 9, 10, 10, 11, 11], F.t10l = [1, 4, 7, 9, 10, 10, 10, 11, 4, 6, 8, 9, 10, 11, 10, 10, 7, 8, 9, 10, 11, 12, 11, 11, 8, 9, 10, 11, 12, 12, 11, 12, 9, 10, 11, 12, 12, 12, 12, 12, 10, 11, 12, 12, 13, 13, 12, 13, 9, 10, 11, 12, 12, 12, 13, 13, 10, 10, 11, 12, 12, 13, 13, 13], F.t11l = [2, 4, 6, 8, 9, 10, 9, 10, 4, 5, 6, 8, 10, 10, 9, 10, 6, 7, 8, 9, 10, 11, 10, 10, 8, 8, 9, 11, 10, 12, 10, 11, 9, 10, 10, 11, 11, 12, 11, 12, 9, 10, 11, 12, 12, 13, 12, 13, 9, 9, 9, 10, 11, 12, 12, 12, 9, 9, 10, 11, 12, 12, 12, 12], F.t12l = [4, 4, 6, 8, 9, 10, 10, 10, 4, 5, 6, 7, 9, 9, 10, 10, 6, 6, 7, 8, 9, 10, 9, 10, 7, 7, 8, 8, 9, 10, 10, 10, 8, 8, 9, 9, 10, 10, 10, 11, 9, 9, 10, 10, 10, 11, 10, 11, 9, 9, 9, 10, 10, 11, 11, 12, 10, 10, 10, 11, 11, 11, 11, 12], F.t13l = [1, 5, 7, 8, 9, 10, 10, 11, 10, 11, 12, 12, 13, 13, 14, 14, 4, 6, 8, 9, 10, 10, 11, 11, 11, 11, 12, 12, 13, 14, 14, 14, 7, 8, 9, 10, 11, 11, 12, 12, 11, 12, 12, 13, 13, 14, 15, 15, 8, 9, 10, 11, 11, 12, 12, 12, 12, 13, 13, 13, 13, 14, 15, 15, 9, 9, 11, 11, 12, 12, 13, 13, 12, 13, 13, 14, 14, 15, 15, 16, 10, 10, 11, 12, 12, 12, 13, 13, 13, 13, 14, 13, 15, 15, 16, 16, 10, 11, 12, 12, 13, 13, 13, 13, 13, 14, 14, 14, 15, 15, 16, 16, 11, 11, 12, 13, 13, 13, 14, 14, 14, 14, 15, 15, 15, 16, 18, 18, 10, 10, 11, 12, 12, 13, 13, 14, 14, 14, 14, 15, 15, 16, 17, 17, 11, 11, 12, 12, 13, 13, 13, 15, 14, 15, 15, 16, 16, 16, 18, 17, 11, 12, 12, 13, 13, 14, 14, 15, 14, 15, 16, 15, 16, 17, 18, 19, 12, 12, 12, 13, 14, 14, 14, 14, 15, 15, 15, 16, 17, 17, 17, 18, 12, 13, 13, 14, 14, 15, 14, 15, 16, 16, 17, 17, 17, 18, 18, 18, 13, 13, 14, 15, 15, 15, 16, 16, 16, 16, 16, 17, 18, 17, 18, 18, 14, 14, 14, 15, 15, 15, 17, 16, 16, 19, 17, 17, 17, 19, 18, 18, 13, 14, 15, 16, 16, 16, 17, 16, 17, 17, 18, 18, 21, 20, 21, 18], F.t15l = [3, 5, 6, 8, 8, 9, 10, 10, 10, 11, 11, 12, 12, 12, 13, 14, 5, 5, 7, 8, 9, 9, 10, 10, 10, 11, 11, 12, 12, 12, 13, 13, 6, 7, 7, 8, 9, 9, 10, 10, 10, 11, 11, 12, 12, 13, 13, 13, 7, 8, 8, 9, 9, 10, 10, 11, 11, 11, 12, 12, 12, 13, 13, 13, 8, 8, 9, 9, 10, 10, 11, 11, 11, 11, 12, 12, 12, 13, 13, 13, 9, 9, 9, 10, 10, 10, 11, 11, 11, 11, 12, 12, 13, 13, 13, 14, 10, 9, 10, 10, 10, 11, 11, 11, 11, 12, 12, 12, 13, 13, 14, 14, 10, 10, 10, 11, 11, 11, 11, 12, 12, 12, 12, 12, 13, 13, 13, 14, 10, 10, 10, 11, 11, 11, 11, 12, 12, 12, 12, 13, 13, 14, 14, 14, 10, 10, 11, 11, 11, 11, 12, 12, 12, 13, 13, 13, 13, 14, 14, 14, 11, 11, 11, 11, 12, 12, 12, 12, 12, 13, 13, 13, 13, 14, 15, 14, 11, 11, 11, 11, 12, 12, 12, 12, 13, 13, 13, 13, 14, 14, 14, 15, 12, 12, 11, 12, 12, 12, 13, 13, 13, 13, 13, 13, 14, 14, 15, 15, 12, 12, 12, 12, 12, 13, 13, 13, 13, 14, 14, 14, 14, 14, 15, 15, 13, 13, 13, 13, 13, 13, 13, 13, 14, 14, 14, 14, 15, 15, 14, 15, 13, 13, 13, 13, 13, 13, 13, 14, 14, 14, 14, 14, 15, 15, 15, 15], F.t16_5l = [1, 5, 7, 9, 10, 10, 11, 11, 12, 12, 12, 13, 13, 13, 14, 11, 4, 6, 8, 9, 10, 11, 11, 11, 12, 12, 12, 13, 14, 13, 14, 11, 7, 8, 9, 10, 11, 11, 12, 12, 13, 12, 13, 13, 13, 14, 14, 12, 9, 9, 10, 11, 11, 12, 12, 12, 13, 13, 14, 14, 14, 15, 15, 13, 10, 10, 11, 11, 12, 12, 13, 13, 13, 14, 14, 14, 15, 15, 15, 12, 10, 10, 11, 11, 12, 13, 13, 14, 13, 14, 14, 15, 15, 15, 16, 13, 11, 11, 11, 12, 13, 13, 13, 13, 14, 14, 14, 14, 15, 15, 16, 13, 11, 11, 12, 12, 13, 13, 13, 14, 14, 15, 15, 15, 15, 17, 17, 13, 11, 12, 12, 13, 13, 13, 14, 14, 15, 15, 15, 15, 16, 16, 16, 13, 12, 12, 12, 13, 13, 14, 14, 15, 15, 15, 15, 16, 15, 16, 15, 14, 12, 13, 12, 13, 14, 14, 14, 14, 15, 16, 16, 16, 17, 17, 16, 13, 13, 13, 13, 13, 14, 14, 15, 16, 16, 16, 16, 16, 16, 15, 16, 14, 13, 14, 14, 14, 14, 15, 15, 15, 15, 17, 16, 16, 16, 16, 18, 14, 15, 14, 14, 14, 15, 15, 16, 16, 16, 18, 17, 17, 17, 19, 17, 14, 14, 15, 13, 14, 16, 16, 15, 16, 16, 17, 18, 17, 19, 17, 16, 14, 11, 11, 11, 12, 12, 13, 13, 13, 14, 14, 14, 14, 14, 14, 14, 12], F.t16l = [1, 5, 7, 9, 10, 10, 11, 11, 12, 12, 12, 13, 13, 13, 14, 10, 4, 6, 8, 9, 10, 11, 11, 11, 12, 12, 12, 13, 14, 13, 14, 10, 7, 8, 9, 10, 11, 11, 12, 12, 13, 12, 13, 13, 13, 14, 14, 11, 9, 9, 10, 11, 11, 12, 12, 12, 13, 13, 14, 14, 14, 15, 15, 12, 10, 10, 11, 11, 12, 12, 13, 13, 13, 14, 14, 14, 15, 15, 15, 11, 10, 10, 11, 11, 12, 13, 13, 14, 13, 14, 14, 15, 15, 15, 16, 12, 11, 11, 11, 12, 13, 13, 13, 13, 14, 14, 14, 14, 15, 15, 16, 12, 11, 11, 12, 12, 13, 13, 13, 14, 14, 15, 15, 15, 15, 17, 17, 12, 11, 12, 12, 13, 13, 13, 14, 14, 15, 15, 15, 15, 16, 16, 16, 12, 12, 12, 12, 13, 13, 14, 14, 15, 15, 15, 15, 16, 15, 16, 15, 13, 12, 13, 12, 13, 14, 14, 14, 14, 15, 16, 16, 16, 17, 17, 16, 12, 13, 13, 13, 13, 14, 14, 15, 16, 16, 16, 16, 16, 16, 15, 16, 13, 13, 14, 14, 14, 14, 15, 15, 15, 15, 17, 16, 16, 16, 16, 18, 13, 15, 14, 14, 14, 15, 15, 16, 16, 16, 18, 17, 17, 17, 19, 17, 13, 14, 15, 13, 14, 16, 16, 15, 16, 16, 17, 18, 17, 19, 17, 16, 13, 10, 10, 10, 11, 11, 12, 12, 12, 13, 13, 13, 13, 13, 13, 13, 10], F.t24l = [4, 5, 7, 8, 9, 10, 10, 11, 11, 12, 12, 12, 12, 12, 13, 10, 5, 6, 7, 8, 9, 10, 10, 11, 11, 11, 12, 12, 12, 12, 12, 10, 7, 7, 8, 9, 9, 10, 10, 11, 11, 11, 11, 12, 12, 12, 13, 9, 8, 8, 9, 9, 10, 10, 10, 11, 11, 11, 11, 12, 12, 12, 12, 9, 9, 9, 9, 10, 10, 10, 10, 11, 11, 11, 12, 12, 12, 12, 13, 9, 10, 9, 10, 10, 10, 10, 11, 11, 11, 11, 12, 12, 12, 12, 12, 9, 10, 10, 10, 10, 10, 11, 11, 11, 11, 12, 12, 12, 12, 12, 13, 9, 11, 10, 10, 10, 11, 11, 11, 11, 12, 12, 12, 12, 12, 13, 13, 10, 11, 11, 11, 11, 11, 11, 11, 11, 11, 12, 12, 12, 12, 13, 13, 10, 11, 11, 11, 11, 11, 11, 11, 12, 12, 12, 12, 12, 13, 13, 13, 10, 12, 11, 11, 11, 11, 12, 12, 12, 12, 12, 12, 13, 13, 13, 13, 10, 12, 12, 11, 11, 11, 12, 12, 12, 12, 12, 12, 13, 13, 13, 13, 10, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 13, 13, 13, 13, 13, 10, 12, 12, 12, 12, 12, 12, 12, 12, 13, 13, 13, 13, 13, 13, 13, 10, 13, 12, 12, 12, 12, 12, 12, 13, 13, 13, 13, 13, 13, 13, 13, 10, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 10, 10, 10, 10, 6], F.t32l = [1, 5, 5, 7, 5, 8, 7, 9, 5, 7, 7, 9, 7, 9, 9, 10], F.t33l = [4, 5, 5, 6, 5, 6, 6, 7, 5, 6, 6, 7, 6, 7, 7, 8], F.ht = [new e(0, 0, null, null), new e(2, 0, F.t1HB, F.t1l), new e(3, 0, F.t2HB, F.t2l), new e(3, 0, F.t3HB, F.t3l), new e(0, 0, null, null), new e(4, 0, F.t5HB, F.t5l), new e(4, 0, F.t6HB, F.t6l), new e(6, 0, F.t7HB, F.t7l), new e(6, 0, F.t8HB, F.t8l), new e(6, 0, F.t9HB, F.t9l), new e(8, 0, F.t10HB, F.t10l), new e(8, 0, F.t11HB, F.t11l), new e(8, 0, F.t12HB, F.t12l), new e(16, 0, F.t13HB, F.t13l), new e(0, 0, null, F.t16_5l), new e(16, 0, F.t15HB, F.t15l), new e(1, 1, F.t16HB, F.t16l), new e(2, 3, F.t16HB, F.t16l), new e(3, 7, F.t16HB, F.t16l), new e(4, 15, F.t16HB, F.t16l), new e(6, 63, F.t16HB, F.t16l), new e(8, 255, F.t16HB, F.t16l), new e(10, 1023, F.t16HB, F.t16l), new e(13, 8191, F.t16HB, F.t16l), new e(4, 15, F.t24HB, F.t24l), new e(5, 31, F.t24HB, F.t24l), new e(6, 63, F.t24HB, F.t24l), new e(7, 127, F.t24HB, F.t24l), new e(8, 255, F.t24HB, F.t24l), new e(9, 511, F.t24HB, F.t24l), new e(11, 2047, F.t24HB, F.t24l), new e(13, 8191, F.t24HB, F.t24l), new e(0, 0, F.t32HB, F.t32l), new e(0, 0, F.t33HB, F.t33l)], F.largetbl = [65540, 327685, 458759, 589832, 655369, 655370, 720906, 720907, 786443, 786444, 786444, 851980, 851980, 851980, 917517, 655370, 262149, 393222, 524295, 589832, 655369, 720906, 720906, 720907, 786443, 786443, 786444, 851980, 917516, 851980, 917516, 655370, 458759, 524295, 589832, 655369, 720905, 720906, 786442, 786443, 851979, 786443, 851979, 851980, 851980, 917516, 917517, 720905, 589832, 589832, 655369, 720905, 720906, 786442, 786442, 786443, 851979, 851979, 917515, 917516, 917516, 983052, 983052, 786441, 655369, 655369, 720905, 720906, 786442, 786442, 851978, 851979, 851979, 917515, 917516, 917516, 983052, 983052, 983053, 720905, 655370, 655369, 720906, 720906, 786442, 851978, 851979, 917515, 851979, 917515, 917516, 983052, 983052, 983052, 1048588, 786441, 720906, 720906, 720906, 786442, 851978, 851979, 851979, 851979, 917515, 917516, 917516, 917516, 983052, 983052, 1048589, 786441, 720907, 720906, 786442, 786442, 851979, 851979, 851979, 917515, 917516, 983052, 983052, 983052, 983052, 1114125, 1114125, 786442, 720907, 786443, 786443, 851979, 851979, 851979, 917515, 917515, 983051, 983052, 983052, 983052, 1048588, 1048589, 1048589, 786442, 786443, 786443, 786443, 851979, 851979, 917515, 917515, 983052, 983052, 983052, 983052, 1048588, 983053, 1048589, 983053, 851978, 786444, 851979, 786443, 851979, 917515, 917516, 917516, 917516, 983052, 1048588, 1048588, 1048589, 1114125, 1114125, 1048589, 786442, 851980, 851980, 851979, 851979, 917515, 917516, 983052, 1048588, 1048588, 1048588, 1048588, 1048589, 1048589, 983053, 1048589, 851978, 851980, 917516, 917516, 917516, 917516, 983052, 983052, 983052, 983052, 1114124, 1048589, 1048589, 1048589, 1048589, 1179661, 851978, 983052, 917516, 917516, 917516, 983052, 983052, 1048588, 1048588, 1048589, 1179661, 1114125, 1114125, 1114125, 1245197, 1114125, 851978, 917517, 983052, 851980, 917516, 1048588, 1048588, 983052, 1048589, 1048589, 1114125, 1179661, 1114125, 1245197, 1114125, 1048589, 851978, 655369, 655369, 655369, 720905, 720905, 786441, 786441, 786441, 851977, 851977, 851977, 851978, 851978, 851978, 851978, 655366], F.table23 = [65538, 262147, 458759, 262148, 327684, 458759, 393222, 458759, 524296], F.table56 = [65539, 262148, 458758, 524296, 262148, 327684, 524294, 589831, 458757, 524294, 589831, 655368, 524295, 524295, 589832, 655369], F.bitrate_table = [[0, 8, 16, 24, 32, 40, 48, 56, 64, 80, 96, 112, 128, 144, 160, -1], [0, 32, 40, 48, 56, 64, 80, 96, 112, 128, 160, 192, 224, 256, 320, -1], [0, 8, 16, 24, 32, 40, 48, 56, 64, -1, -1, -1, -1, -1, -1, -1]], F.samplerate_table = [[22050, 24e3, 16e3, -1], [44100, 48e3, 32e3, -1], [11025, 12e3, 8e3, -1]], F.scfsi_band = [0, 6, 11, 16, 21], x.Q_MAX = 257, x.Q_MAX2 = 116, x.LARGE_BITS = 1e5, x.IXMAX_VAL = 8206;
+ var z = {};
+ function w() {
+ var v, g, M;
this.rv = null, this.qupvt = null;
var w,
- s = new function () {
+ n = new function () {
this.setModules = function (e, t) {};
}();
- function S(e) {
+ function R(e) {
this.ordinal = e;
}
function o(e) {
for (var t = 0; t < e.sfbmax; t++) if (e.scalefac[t] + e.subblock_gain[e.window[t]] == 0) return !1;
return !0;
}
- function M(e, t, a, n, s) {
+ function A(e, t, a, s, n) {
var r;
switch (e) {
default:
@@ -14181,10 +13883,13 @@ src: recorder-core.js,engine/mp3.js,engine/mp3-engine.js
0 < t.over_count ? (r = a.over_SSD <= t.over_SSD, a.over_SSD == t.over_SSD && (r = a.bits < t.bits)) : r = a.max_noise < 0 && 10 * a.max_noise + a.bits <= 10 * t.max_noise + t.bits;
break;
case 0:
- r = a.over_count < t.over_count || a.over_count == t.over_count && a.over_noise < t.over_noise || a.over_count == t.over_count && N.EQ(a.over_noise, t.over_noise) && a.tot_noise < t.tot_noise;
+ r = a.over_count < t.over_count || a.over_count == t.over_count && a.over_noise < t.over_noise || a.over_count == t.over_count && q.EQ(a.over_noise, t.over_noise) && a.tot_noise < t.tot_noise;
break;
case 8:
- me();
+ a.max_noise = function (e, t) {
+ for (var a, s = 1e-37, n = 0; n < t.psymax; n++) s += (a = e[n], ee.FAST_LOG10(.368 + .632 * a * a * a));
+ return Math.max(1e-20, s);
+ }(n, s);
case 1:
r = a.max_noise < t.max_noise;
break;
@@ -14198,25 +13903,25 @@ src: recorder-core.js,engine/mp3.js,engine/mp3-engine.js
r = a.max_noise <= 0 && .2 < t.max_noise || a.max_noise <= 0 && t.max_noise < 0 && t.max_noise > a.max_noise - .2 && a.tot_noise < t.tot_noise || a.max_noise <= 0 && 0 < t.max_noise && t.max_noise > a.max_noise - .2 && a.tot_noise < t.tot_noise + t.over_noise || 0 < a.max_noise && -.05 < t.max_noise && t.max_noise > a.max_noise - .1 && a.tot_noise + a.over_noise < t.tot_noise + t.over_noise || 0 < a.max_noise && -.1 < t.max_noise && t.max_noise > a.max_noise - .15 && a.tot_noise + a.over_noise + a.over_noise < t.tot_noise + t.over_noise + t.over_noise;
break;
case 5:
- r = a.over_noise < t.over_noise || N.EQ(a.over_noise, t.over_noise) && a.tot_noise < t.tot_noise;
+ r = a.over_noise < t.over_noise || q.EQ(a.over_noise, t.over_noise) && a.tot_noise < t.tot_noise;
break;
case 6:
- r = a.over_noise < t.over_noise || N.EQ(a.over_noise, t.over_noise) && (a.max_noise < t.max_noise || N.EQ(a.max_noise, t.max_noise) && a.tot_noise <= t.tot_noise);
+ r = a.over_noise < t.over_noise || q.EQ(a.over_noise, t.over_noise) && (a.max_noise < t.max_noise || q.EQ(a.max_noise, t.max_noise) && a.tot_noise <= t.tot_noise);
break;
case 7:
r = a.over_count < t.over_count || a.over_noise < t.over_noise;
}
return 0 == t.over_count && (r = r && a.bits < t.bits), r;
}
- function y(e, t, a, n, s) {
+ function B(e, t, a, s, n) {
var r = e.internal_flags;
- !function (e, t, a, n, s) {
+ !function (e, t, a, s, n) {
var r,
i = e.internal_flags;
r = 0 == t.scalefac_scale ? 1.2968395546510096 : 1.6817928305074292;
for (var o = 0, _ = 0; _ < t.sfbmax; _++) o < a[_] && (o = a[_]);
var l = i.noise_shaping_amp;
- switch (3 == l && me(), l) {
+ switch (3 == l && (l = n ? 2 : 1), l) {
case 2:
break;
case 1:
@@ -14226,536 +13931,734 @@ src: recorder-core.js,engine/mp3.js,engine/mp3-engine.js
default:
1 < o ? o = 1 : o *= .95;
}
- for (var f = 0, _ = 0; _ < t.sfbmax; _++) {
+ var f = 0;
+ for (_ = 0; _ < t.sfbmax; _++) {
var c,
- u = t.width[_];
- if (f += u, !(a[_] < o)) {
- for (0 != (2 & i.substep_shaping) && me(), t.scalefac[_]++, c = -u; c < 0; c++) n[f + c] *= r, n[f + c] > t.xrpow_max && (t.xrpow_max = n[f + c]);
+ h = t.width[_];
+ if (f += h, !(a[_] < o)) {
+ if (0 != (2 & i.substep_shaping) && (i.pseudohalf[_] = 0 == i.pseudohalf[_] ? 1 : 0, 0 == i.pseudohalf[_] && 2 == i.noise_shaping_amp)) return;
+ for (t.scalefac[_]++, c = -h; c < 0; c++) s[f + c] *= r, s[f + c] > t.xrpow_max && (t.xrpow_max = s[f + c]);
if (2 == i.noise_shaping_amp) return;
}
}
- }(e, t, a, n);
+ }(e, t, a, s, n);
var i = o(t);
- return !(i || (i = 2 == r.mode_gr ? w.scale_bitcount(t) : w.scale_bitcount_lsf(r, t)) && (1 < r.noise_shaping && (we.fill(r.pseudohalf, 0), 0 == t.scalefac_scale ? (function (e, t) {
- for (var a = 0, n = 0; n < e.sfbmax; n++) {
- var s = e.width[n],
- r = e.scalefac[n];
- if (0 != e.preflag && (r += g.pretab[n]), a += s, 0 != (1 & r)) {
+ return !i && (!(i = 2 == r.mode_gr ? w.scale_bitcount(t) : w.scale_bitcount_lsf(r, t)) || (1 < r.noise_shaping && (ye.fill(r.pseudohalf, 0), 0 == t.scalefac_scale ? (!function (e, t) {
+ for (var a = 0, s = 0; s < e.sfbmax; s++) {
+ var n = e.width[s],
+ r = e.scalefac[s];
+ if (0 != e.preflag && (r += M.pretab[s]), a += n, 0 != (1 & r)) {
r++;
- for (var i = -s; i < 0; i++) t[a + i] *= 1.2968395546510096, t[a + i] > e.xrpow_max && (e.xrpow_max = t[a + i]);
+ for (var i = -n; i < 0; i++) t[a + i] *= 1.2968395546510096, t[a + i] > e.xrpow_max && (e.xrpow_max = t[a + i]);
}
- e.scalefac[n] = r >> 1;
+ e.scalefac[s] = r >> 1;
}
e.preflag = 0, e.scalefac_scale = 1;
- }(t, n), i = !1) : t.block_type == Ae.SHORT_TYPE && 0 < r.subblock_gain && (i = function (e, t, a) {
- var n,
- s = t.scalefac;
- for (n = 0; n < t.sfb_lmax; n++) if (16 <= s[n]) return !0;
+ }(t, s), i = !1) : t.block_type == Pe.SHORT_TYPE && 0 < r.subblock_gain && (i = function (e, t, a) {
+ var s,
+ n = t.scalefac;
+ for (s = 0; s < t.sfb_lmax; s++) if (16 <= n[s]) return !0;
for (var r = 0; r < 3; r++) {
var i = 0,
o = 0;
- for (n = t.sfb_lmax + r; n < t.sfbdivide; n += 3) i < s[n] && (i = s[n]);
- for (; n < t.sfbmax; n += 3) o < s[n] && (o = s[n]);
+ for (s = t.sfb_lmax + r; s < t.sfbdivide; s += 3) i < n[s] && (i = n[s]);
+ for (; s < t.sfbmax; s += 3) o < n[s] && (o = n[s]);
if (!(i < 16 && o < 8)) {
if (7 <= t.subblock_gain[r]) return !0;
t.subblock_gain[r]++;
var _ = e.scalefac_band.l[t.sfb_lmax];
- for (n = t.sfb_lmax + r; n < t.sfbmax; n += 3) {
- var l = t.width[n],
- f = s[n];
- if (0 <= (f -= 4 >> t.scalefac_scale)) s[n] = f, _ += 3 * l;else {
- s[n] = 0;
+ for (s = t.sfb_lmax + r; s < t.sfbmax; s += 3) {
+ var l = t.width[s],
+ f = n[s];
+ if (0 <= (f -= 4 >> t.scalefac_scale)) n[s] = f, _ += 3 * l;else {
+ n[s] = 0;
var c = 210 + (f << t.scalefac_scale + 1);
- h = g.IPOW20(c), _ += l * (r + 1);
- for (var u = -l; u < 0; u++) a[_ + u] *= h, a[_ + u] > t.xrpow_max && (t.xrpow_max = a[_ + u]);
+ u = M.IPOW20(c), _ += l * (r + 1);
+ for (var h = -l; h < 0; h++) a[_ + h] *= u, a[_ + h] > t.xrpow_max && (t.xrpow_max = a[_ + h]);
_ += l * (3 - r - 1);
}
}
- var h = g.IPOW20(202);
- _ += t.width[n] * (r + 1);
- for (var u = -t.width[n]; u < 0; u++) a[_ + u] *= h, a[_ + u] > t.xrpow_max && (t.xrpow_max = a[_ + u]);
+ var u = M.IPOW20(202);
+ for (_ += t.width[s] * (r + 1), h = -t.width[s]; h < 0; h++) a[_ + h] *= u, a[_ + h] > t.xrpow_max && (t.xrpow_max = a[_ + h]);
}
}
return !1;
- }(r, t, n) || o(t))), i || (i = 2 == r.mode_gr ? w.scale_bitcount(t) : w.scale_bitcount_lsf(r, t)), i));
+ }(r, t, s) || o(t))), i || (i = 2 == r.mode_gr ? w.scale_bitcount(t) : w.scale_bitcount_lsf(r, t)), !i));
}
- this.setModules = function (e, t, a, n) {
- r = t, this.rv = t, g = a, this.qupvt = a, w = n, s.setModules(g, w);
+ this.setModules = function (e, t, a, s) {
+ v = e, g = t, this.rv = t, M = a, this.qupvt = a, w = s, n.setModules(M, w);
+ }, this.ms_convert = function (e, t) {
+ for (var a = 0; a < 576; ++a) {
+ var s = e.tt[t][0].xr[a],
+ n = e.tt[t][1].xr[a];
+ e.tt[t][0].xr[a] = (s + n) * (.5 * ee.SQRT2), e.tt[t][1].xr[a] = (s - n) * (.5 * ee.SQRT2);
+ }
}, this.init_xrpow = function (e, t, a) {
- var n = 0,
- s = 0 | t.max_nonzero_coeff;
- if (t.xrpow_max = 0, we.fill(a, s, 576, 0), 1e-20 < (n = function (e, t, a, n) {
- for (var s = n = 0; s <= a; ++s) {
- var r = Math.abs(e.xr[s]);
- n += r, t[s] = Math.sqrt(r * Math.sqrt(r)), t[s] > e.xrpow_max && (e.xrpow_max = t[s]);
+ var s = 0,
+ n = 0 | t.max_nonzero_coeff;
+ if (t.xrpow_max = 0, ye.fill(a, n, 576, 0), 1e-20 < (s = function (e, t, a, s) {
+ for (var n = s = 0; n <= a; ++n) {
+ var r = Math.abs(e.xr[n]);
+ s += r, t[n] = Math.sqrt(r * Math.sqrt(r)), t[n] > e.xrpow_max && (e.xrpow_max = t[n]);
}
- return n;
- }(t, a, s, n))) {
+ return s;
+ }(t, a, n, s))) {
var r = 0;
0 != (2 & e.substep_shaping) && (r = 1);
for (var i = 0; i < t.psymax; i++) e.pseudohalf[i] = r;
return !0;
}
- return we.fill(t.l3_enc, 0, 576, 0), !1;
+ return ye.fill(t.l3_enc, 0, 576, 0), !1;
}, this.init_outer_loop = function (e, t) {
- t.part2_3_length = 0, t.big_values = 0, t.count1 = 0, t.global_gain = 210, t.scalefac_compress = 0, t.table_select[0] = 0, t.table_select[1] = 0, t.table_select[2] = 0, t.subblock_gain[0] = 0, t.subblock_gain[1] = 0, t.subblock_gain[2] = 0, t.subblock_gain[3] = 0, t.region0_count = 0, t.region1_count = 0, t.preflag = 0, t.scalefac_scale = 0, t.count1table_select = 0, t.part2_length = 0, t.sfb_lmax = Ae.SBPSY_l, t.sfb_smin = Ae.SBPSY_s, t.psy_lmax = e.sfb21_extra ? Ae.SBMAX_l : Ae.SBPSY_l, t.psymax = t.psy_lmax, t.sfbmax = t.sfb_lmax, t.sfbdivide = 11;
- for (var a = 0; a < Ae.SBMAX_l; a++) t.width[a] = e.scalefac_band.l[a + 1] - e.scalefac_band.l[a], t.window[a] = 3;
- if (t.block_type == Ae.SHORT_TYPE) {
- var n = de(576);
- t.sfb_smin = 0, (t.sfb_lmax = 0) != t.mixed_block_flag && me(), t.psymax = t.sfb_lmax + 3 * ((e.sfb21_extra ? Ae.SBMAX_s : Ae.SBPSY_s) - t.sfb_smin), t.sfbmax = t.sfb_lmax + 3 * (Ae.SBPSY_s - t.sfb_smin), t.sfbdivide = t.sfbmax - 18, t.psy_lmax = t.sfb_lmax;
- var s = e.scalefac_band.l[t.sfb_lmax];
- I.arraycopy(t.xr, 0, n, 0, 576);
- for (var a = t.sfb_smin; a < Ae.SBMAX_s; a++) for (var r = e.scalefac_band.s[a], i = e.scalefac_band.s[a + 1], o = 0; o < 3; o++) for (var _ = r; _ < i; _++) t.xr[s++] = n[3 * _ + o];
- for (var l = t.sfb_lmax, a = t.sfb_smin; a < Ae.SBMAX_s; a++) t.width[l] = t.width[l + 1] = t.width[l + 2] = e.scalefac_band.s[a + 1] - e.scalefac_band.s[a], t.window[l] = 0, t.window[l + 1] = 1, t.window[l + 2] = 2, l += 3;
+ t.part2_3_length = 0, t.big_values = 0, t.count1 = 0, t.global_gain = 210, t.scalefac_compress = 0, t.table_select[0] = 0, t.table_select[1] = 0, t.table_select[2] = 0, t.subblock_gain[0] = 0, t.subblock_gain[1] = 0, t.subblock_gain[2] = 0, t.subblock_gain[3] = 0, t.region0_count = 0, t.region1_count = 0, t.preflag = 0, t.scalefac_scale = 0, t.count1table_select = 0, t.part2_length = 0, t.sfb_lmax = Pe.SBPSY_l, t.sfb_smin = Pe.SBPSY_s, t.psy_lmax = e.sfb21_extra ? Pe.SBMAX_l : Pe.SBPSY_l, t.psymax = t.psy_lmax, t.sfbmax = t.sfb_lmax, t.sfbdivide = 11;
+ for (var a = 0; a < Pe.SBMAX_l; a++) t.width[a] = e.scalefac_band.l[a + 1] - e.scalefac_band.l[a], t.window[a] = 3;
+ if (t.block_type == Pe.SHORT_TYPE) {
+ var s = Be(576);
+ t.sfb_smin = 0, (t.sfb_lmax = 0) != t.mixed_block_flag && (t.sfb_smin = 3, t.sfb_lmax = 2 * e.mode_gr + 4), t.psymax = t.sfb_lmax + 3 * ((e.sfb21_extra ? Pe.SBMAX_s : Pe.SBPSY_s) - t.sfb_smin), t.sfbmax = t.sfb_lmax + 3 * (Pe.SBPSY_s - t.sfb_smin), t.sfbdivide = t.sfbmax - 18, t.psy_lmax = t.sfb_lmax;
+ var n = e.scalefac_band.l[t.sfb_lmax];
+ $.arraycopy(t.xr, 0, s, 0, 576);
+ for (a = t.sfb_smin; a < Pe.SBMAX_s; a++) for (var r = e.scalefac_band.s[a], i = e.scalefac_band.s[a + 1], o = 0; o < 3; o++) for (var _ = r; _ < i; _++) t.xr[n++] = s[3 * _ + o];
+ var l = t.sfb_lmax;
+ for (a = t.sfb_smin; a < Pe.SBMAX_s; a++) t.width[l] = t.width[l + 1] = t.width[l + 2] = e.scalefac_band.s[a + 1] - e.scalefac_band.s[a], t.window[l] = 0, t.window[l + 1] = 1, t.window[l + 2] = 2, l += 3;
}
- t.count1bits = 0, t.sfb_partition_table = g.nr_of_sfb_block[0][0], t.slen[0] = 0, t.slen[1] = 0, t.slen[2] = 0, t.slen[3] = 0, t.max_nonzero_coeff = 575, we.fill(t.scalefac, 0), function (e, t) {
+ t.count1bits = 0, t.sfb_partition_table = M.nr_of_sfb_block[0][0], t.slen[0] = 0, t.slen[1] = 0, t.slen[2] = 0, t.slen[3] = 0, t.max_nonzero_coeff = 575, ye.fill(t.scalefac, 0), function (e, t) {
var a = e.ATH,
- n = t.xr;
- if (t.block_type != Ae.SHORT_TYPE) for (var s = !1, r = Ae.PSFB21 - 1; 0 <= r && !s; r--) {
+ s = t.xr;
+ if (t.block_type != Pe.SHORT_TYPE) for (var n = !1, r = Pe.PSFB21 - 1; 0 <= r && !n; r--) {
var i = e.scalefac_band.psfb21[r],
o = e.scalefac_band.psfb21[r + 1],
- _ = g.athAdjust(a.adjust, a.psfb21[r], a.floor);
+ _ = M.athAdjust(a.adjust, a.psfb21[r], a.floor);
1e-12 < e.nsPsy.longfact[21] && (_ *= e.nsPsy.longfact[21]);
for (var l = o - 1; i <= l; l--) {
- if (!(Math.abs(n[l]) < _)) {
- s = !0;
+ if (!(Math.abs(s[l]) < _)) {
+ n = !0;
break;
}
- n[l] = 0;
+ s[l] = 0;
}
- } else for (var f = 0; f < 3; f++) for (var s = !1, r = Ae.PSFB12 - 1; 0 <= r && !s; r--) {
- var i = 3 * e.scalefac_band.s[12] + (e.scalefac_band.s[13] - e.scalefac_band.s[12]) * f + (e.scalefac_band.psfb12[r] - e.scalefac_band.psfb12[0]),
- o = i + (e.scalefac_band.psfb12[r + 1] - e.scalefac_band.psfb12[r]),
- c = g.athAdjust(a.adjust, a.psfb12[r], a.floor);
- 1e-12 < e.nsPsy.shortfact[12] && (c *= e.nsPsy.shortfact[12]);
- for (var l = o - 1; i <= l; l--) {
- if (!(Math.abs(n[l]) < c)) {
- s = !0;
+ } else for (var f = 0; f < 3; f++) for (n = !1, r = Pe.PSFB12 - 1; 0 <= r && !n; r--) {
+ o = (i = 3 * e.scalefac_band.s[12] + (e.scalefac_band.s[13] - e.scalefac_band.s[12]) * f + (e.scalefac_band.psfb12[r] - e.scalefac_band.psfb12[0])) + (e.scalefac_band.psfb12[r + 1] - e.scalefac_band.psfb12[r]);
+ var c = M.athAdjust(a.adjust, a.psfb12[r], a.floor);
+ for (1e-12 < e.nsPsy.shortfact[12] && (c *= e.nsPsy.shortfact[12]), l = o - 1; i <= l; l--) {
+ if (!(Math.abs(s[l]) < c)) {
+ n = !0;
break;
}
- n[l] = 0;
+ s[l] = 0;
}
}
}(e, t);
- }, S.BINSEARCH_NONE = new S(0), S.BINSEARCH_UP = new S(1), S.BINSEARCH_DOWN = new S(2), this.outer_loop = function (e, t, a, n, s, r) {
+ }, R.BINSEARCH_NONE = new R(0), R.BINSEARCH_UP = new R(1), R.BINSEARCH_DOWN = new R(2), this.trancate_smallspectrums = function (e, t, a, s) {
+ var n = Be(z.SFBMAX);
+ if ((0 != (4 & e.substep_shaping) || t.block_type != Pe.SHORT_TYPE) && 0 == (128 & e.substep_shaping)) {
+ M.calc_noise(t, a, n, new y(), null);
+ for (var r = 0; r < 576; r++) {
+ var i = 0;
+ 0 != t.l3_enc[r] && (i = Math.abs(t.xr[r])), s[r] = i;
+ }
+ r = 0;
+ var o = 8;
+ t.block_type == Pe.SHORT_TYPE && (o = 6);
+ do {
+ var _,
+ l,
+ f,
+ c,
+ h = t.width[o];
+ if (r += h, !(1 <= n[o] || (ye.sort(s, r - h, h), q.EQ(s[r - 1], 0)))) {
+ _ = (1 - n[o]) * a[o], c = l = 0;
+ do {
+ var u;
+ for (f = 1; c + f < h && !q.NEQ(s[c + r - h], s[c + r + f - h]); f++);
+ if (_ < (u = s[c + r - h] * s[c + r - h] * f)) {
+ 0 != c && (l = s[c + r - h - 1]);
+ break;
+ }
+ _ -= u, c += f;
+ } while (c < h);
+ if (!q.EQ(l, 0)) for (; Math.abs(t.xr[r - h]) <= l && (t.l3_enc[r - h] = 0), 0 < --h;);
+ }
+ } while (++o < t.psymax);
+ t.part2_3_length = w.noquant_count_bits(e, t, null);
+ }
+ }, this.outer_loop = function (e, t, a, s, n, r) {
var i = e.internal_flags,
- o = new B(),
- _ = de(576),
- l = de(F.SFBMAX),
- f = new x(),
+ o = new T(),
+ _ = Be(576),
+ l = Be(z.SFBMAX),
+ f = new y(),
c = new function () {
- this.global_gain = 0, this.sfb_count1 = 0, this.step = ve(39), this.noise = de(39), this.noise_log = de(39);
+ this.global_gain = 0, this.sfb_count1 = 0, this.step = Ae(39), this.noise = Be(39), this.noise_log = Be(39);
}(),
- u = 9999999,
- h = !1;
- if (function (e, t, a, n, s) {
+ h = 9999999,
+ u = !1,
+ m = !1,
+ p = 0;
+ if (function (e, t, a, s, n) {
var r,
- i = e.CurrentStep[n],
+ i = e.CurrentStep[s],
o = !1,
- _ = e.OldValue[n],
- l = S.BINSEARCH_NONE;
+ _ = e.OldValue[s],
+ l = R.BINSEARCH_NONE;
for (t.global_gain = _, a -= t.part2_length;;) {
var f;
- if (r = w.count_bits(e, s, t, null), 1 == i || r == a) break;
- a < r ? (l == S.BINSEARCH_DOWN && (o = !0), o && (i /= 2), l = S.BINSEARCH_UP, f = i) : (l == S.BINSEARCH_UP && (o = !0), o && (i /= 2), l = S.BINSEARCH_DOWN, f = -i), t.global_gain += f, t.global_gain < 0 && me(), 255 < t.global_gain && me();
+ if (r = w.count_bits(e, n, t, null), 1 == i || r == a) break;
+ a < r ? (l == R.BINSEARCH_DOWN && (o = !0), o && (i /= 2), l = R.BINSEARCH_UP, f = i) : (l == R.BINSEARCH_UP && (o = !0), o && (i /= 2), l = R.BINSEARCH_DOWN, f = -i), t.global_gain += f, t.global_gain < 0 && (o = !(t.global_gain = 0)), 255 < t.global_gain && (t.global_gain = 255, o = !0);
}
- for (; a < r && t.global_gain < 255;) t.global_gain++, r = w.count_bits(e, s, t, null);
- e.CurrentStep[n] = 4 <= _ - t.global_gain ? 4 : 2, e.OldValue[n] = t.global_gain, t.part2_3_length = r;
- }(i, t, r, s, n), 0 == i.noise_shaping) return 100;
- g.calc_noise(t, a, l, f, c), f.bits = t.part2_3_length, o.assign(t);
+ for (; a < r && t.global_gain < 255;) t.global_gain++, r = w.count_bits(e, n, t, null);
+ e.CurrentStep[s] = 4 <= _ - t.global_gain ? 4 : 2, e.OldValue[s] = t.global_gain, t.part2_3_length = r;
+ }(i, t, r, n, s), 0 == i.noise_shaping) return 100;
+ M.calc_noise(t, a, l, f, c), f.bits = t.part2_3_length, o.assign(t);
var b = 0;
- for (I.arraycopy(n, 0, _, 0, 576); !h;) {
+ for ($.arraycopy(s, 0, _, 0, 576); !u;) {
do {
- var p,
- m = new x(),
- v = 255;
- if (p = 0 != (2 & i.substep_shaping) ? 20 : 3, i.sfb21_extra && me(), !y(e, o, l, n)) break;
- 0 != o.scalefac_scale && (v = 254);
- var d = r - o.part2_length;
- if (d <= 0) break;
- for (; (o.part2_3_length = w.count_bits(i, n, o, c)) > d && o.global_gain <= v;) o.global_gain++;
- if (o.global_gain > v) break;
- if (0 == f.over_count) {
- for (; (o.part2_3_length = w.count_bits(i, n, o, c)) > u && o.global_gain <= v;) o.global_gain++;
- if (o.global_gain > v) break;
+ var v,
+ d = new y(),
+ g = 255;
+ if (v = 0 != (2 & i.substep_shaping) ? 20 : 3, i.sfb21_extra) {
+ if (1 < l[o.sfbmax]) break;
+ if (o.block_type == Pe.SHORT_TYPE && (1 < l[o.sfbmax + 1] || 1 < l[o.sfbmax + 2])) break;
}
- if (g.calc_noise(o, a, l, m, c), m.bits = o.part2_3_length, 0 != (M(t.block_type != Ae.SHORT_TYPE ? e.quant_comp : e.quant_comp_short, f, m) ? 1 : 0)) u = t.part2_3_length, f = m, t.assign(o), b = 0, I.arraycopy(n, 0, _, 0, 576);else if (0 == i.full_outer_loop) {
- if (++b > p && 0 == f.over_count) break;
- i.noise_shaping_amp, i.noise_shaping_amp;
+ if (!B(e, o, l, s, m)) break;
+ 0 != o.scalefac_scale && (g = 254);
+ var S = r - o.part2_length;
+ if (S <= 0) break;
+ for (; (o.part2_3_length = w.count_bits(i, s, o, c)) > S && o.global_gain <= g;) o.global_gain++;
+ if (o.global_gain > g) break;
+ if (0 == f.over_count) {
+ for (; (o.part2_3_length = w.count_bits(i, s, o, c)) > h && o.global_gain <= g;) o.global_gain++;
+ if (o.global_gain > g) break;
+ }
+ if (M.calc_noise(o, a, l, d, c), d.bits = o.part2_3_length, 0 != (A(t.block_type != Pe.SHORT_TYPE ? e.quant_comp : e.quant_comp_short, f, d, o, l) ? 1 : 0)) h = t.part2_3_length, f = d, t.assign(o), b = 0, $.arraycopy(s, 0, _, 0, 576);else if (0 == i.full_outer_loop) {
+ if (++b > v && 0 == f.over_count) break;
+ if (3 == i.noise_shaping_amp && m && 30 < b) break;
+ if (3 == i.noise_shaping_amp && m && 15 < o.global_gain - p) break;
}
} while (o.global_gain + o.scalefac_scale < 255);
- 3 == i.noise_shaping_amp ? me() : h = !0;
+ 3 == i.noise_shaping_amp ? m ? u = !0 : (o.assign(t), $.arraycopy(_, 0, s, 0, 576), b = 0, p = o.global_gain, m = !0) : u = !0;
}
- return e.VBR == Me.vbr_rh || e.VBR == Me.vbr_mtrh ? I.arraycopy(_, 0, n, 0, 576) : 0 != (1 & i.substep_shaping) && me(), f.over_count;
+ return e.VBR == xe.vbr_rh || e.VBR == xe.vbr_mtrh ? $.arraycopy(_, 0, s, 0, 576) : 0 != (1 & i.substep_shaping) && trancate_smallspectrums(i, t, a, s), f.over_count;
}, this.iteration_finish_one = function (e, t, a) {
- var n = e.l3_side,
- s = n.tt[t][a];
- w.best_scalefac_store(e, t, a, n), 1 == e.use_best_huffman && w.best_huffman_divide(e, s), r.ResvAdjust(e, s);
+ var s = e.l3_side,
+ n = s.tt[t][a];
+ w.best_scalefac_store(e, t, a, s), 1 == e.use_best_huffman && w.best_huffman_divide(e, n), g.ResvAdjust(e, n);
+ }, this.VBR_encode_granule = function (e, t, a, s, n, r, i) {
+ var o,
+ _ = e.internal_flags,
+ l = new T(),
+ f = Be(576),
+ c = i,
+ h = i + 1,
+ u = (i + r) / 2,
+ m = 0,
+ p = _.sfb21_extra;
+ for (ye.fill(l.l3_enc, 0); _.sfb21_extra = !(c - 42 < u) && p, outer_loop(e, t, a, s, n, u) <= 0 ? (m = 1, h = t.part2_3_length, l.assign(t), $.arraycopy(s, 0, f, 0, 576), o = (i = h - 32) - r, u = (i + r) / 2) : (o = i - (r = u + 32), u = (i + r) / 2, 0 != m && (m = 2, t.assign(l), $.arraycopy(f, 0, s, 0, 576))), 12 < o;);
+ _.sfb21_extra = p, 2 == m && $.arraycopy(l.l3_enc, 0, t.l3_enc, 0, 576);
+ }, this.get_framebits = function (e, t) {
+ var a = e.internal_flags;
+ a.bitrate_index = a.VBR_min_bitrate;
+ var s = v.getframebits(e);
+ a.bitrate_index = 1, s = v.getframebits(e);
+ for (var n = 1; n <= a.VBR_max_bitrate; n++) {
+ a.bitrate_index = n;
+ var r = new j(s);
+ t[n] = g.ResvFrameBegin(e, r), s = r.bits;
+ }
+ }, this.VBR_old_prepare = function (e, t, a, s, n, r, i, o, _) {
+ var l,
+ f = e.internal_flags,
+ c = 0,
+ h = 1,
+ u = 0;
+ f.bitrate_index = f.VBR_max_bitrate;
+ var m = g.ResvFrameBegin(e, new j(0)) / f.mode_gr;
+ get_framebits(e, r);
+ for (var p = 0; p < f.mode_gr; p++) {
+ var b = M.on_pe(e, t, o[p], m, p, 0);
+ f.mode_ext == Pe.MPG_MD_MS_LR && (ms_convert(f.l3_side, p), M.reduce_side(o[p], a[p], m, b));
+ for (var v = 0; v < f.channels_out; ++v) {
+ var d = f.l3_side.tt[p][v];
+ d.block_type != Pe.SHORT_TYPE ? (c = 1.28 / (1 + Math.exp(3.5 - t[p][v] / 300)) - .05, l = f.PSY.mask_adjust - c) : (c = 2.56 / (1 + Math.exp(3.5 - t[p][v] / 300)) - .14, l = f.PSY.mask_adjust_short - c), f.masking_lower = Math.pow(10, .1 * l), init_outer_loop(f, d), _[p][v] = M.calc_xmin(e, s[p][v], d, n[p][v]), 0 != _[p][v] && (h = 0), i[p][v] = 126, u += o[p][v];
+ }
+ }
+ for (p = 0; p < f.mode_gr; p++) for (v = 0; v < f.channels_out; v++) u > r[f.VBR_max_bitrate] && (o[p][v] *= r[f.VBR_max_bitrate], o[p][v] /= u), i[p][v] > o[p][v] && (i[p][v] = o[p][v]);
+ return h;
+ }, this.bitpressure_strategy = function (e, t, a, s) {
+ for (var n = 0; n < e.mode_gr; n++) for (var r = 0; r < e.channels_out; r++) {
+ for (var i = e.l3_side.tt[n][r], o = t[n][r], _ = 0, l = 0; l < i.psy_lmax; l++) o[_++] *= 1 + .029 * l * l / Pe.SBMAX_l / Pe.SBMAX_l;
+ if (i.block_type == Pe.SHORT_TYPE) for (l = i.sfb_smin; l < Pe.SBMAX_s; l++) o[_++] *= 1 + .029 * l * l / Pe.SBMAX_s / Pe.SBMAX_s, o[_++] *= 1 + .029 * l * l / Pe.SBMAX_s / Pe.SBMAX_s, o[_++] *= 1 + .029 * l * l / Pe.SBMAX_s / Pe.SBMAX_s;
+ s[n][r] = 0 | Math.max(a[n][r], .9 * s[n][r]);
+ }
+ }, this.VBR_new_prepare = function (e, t, a, s, n, r) {
+ var i,
+ o = e.internal_flags,
+ _ = 1,
+ l = 0,
+ f = 0;
+ if (e.free_format) {
+ o.bitrate_index = 0;
+ c = new j(l);
+ i = g.ResvFrameBegin(e, c), l = c.bits, n[0] = i;
+ } else {
+ o.bitrate_index = o.VBR_max_bitrate;
+ var c = new j(l);
+ g.ResvFrameBegin(e, c), l = c.bits, get_framebits(e, n), i = n[o.VBR_max_bitrate];
+ }
+ for (var h = 0; h < o.mode_gr; h++) {
+ M.on_pe(e, t, r[h], l, h, 0), o.mode_ext == Pe.MPG_MD_MS_LR && ms_convert(o.l3_side, h);
+ for (var u = 0; u < o.channels_out; ++u) {
+ var m = o.l3_side.tt[h][u];
+ o.masking_lower = Math.pow(10, .1 * o.PSY.mask_adjust), init_outer_loop(o, m), 0 != M.calc_xmin(e, a[h][u], m, s[h][u]) && (_ = 0), f += r[h][u];
+ }
+ }
+ for (h = 0; h < o.mode_gr; h++) for (u = 0; u < o.channels_out; u++) i < f && (r[h][u] *= i, r[h][u] /= f);
+ return _;
+ }, this.calc_target_bits = function (e, t, a, s, n, r) {
+ var i,
+ o,
+ _,
+ l,
+ f = e.internal_flags,
+ c = f.l3_side,
+ h = 0;
+ f.bitrate_index = f.VBR_max_bitrate;
+ var u = new j(h);
+ for (r[0] = g.ResvFrameBegin(e, u), h = u.bits, f.bitrate_index = 1, h = v.getframebits(e) - 8 * f.sideinfo_len, n[0] = h / (f.mode_gr * f.channels_out), h = e.VBR_mean_bitrate_kbps * e.framesize * 1e3, 0 != (1 & f.substep_shaping) && (h *= 1.09), h /= e.out_samplerate, h -= 8 * f.sideinfo_len, h /= f.mode_gr * f.channels_out, (i = .93 + .07 * (11 - e.compression_ratio) / 5.5) < .9 && (i = .9), 1 < i && (i = 1), o = 0; o < f.mode_gr; o++) {
+ var m = 0;
+ for (_ = 0; _ < f.channels_out; _++) {
+ if (s[o][_] = int(i * h), 700 < t[o][_]) {
+ var p = int((t[o][_] - 700) / 1.4),
+ b = c.tt[o][_];
+ s[o][_] = int(i * h), b.block_type == Pe.SHORT_TYPE && p < h / 2 && (p = h / 2), 3 * h / 2 < p ? p = 3 * h / 2 : p < 0 && (p = 0), s[o][_] += p;
+ }
+ s[o][_] > Z.MAX_BITS_PER_CHANNEL && (s[o][_] = Z.MAX_BITS_PER_CHANNEL), m += s[o][_];
+ }
+ if (Z.MAX_BITS_PER_GRANULE < m) for (_ = 0; _ < f.channels_out; ++_) s[o][_] *= Z.MAX_BITS_PER_GRANULE, s[o][_] /= m;
+ }
+ if (f.mode_ext == Pe.MPG_MD_MS_LR) for (o = 0; o < f.mode_gr; o++) M.reduce_side(s[o], a[o], h * f.channels_out, Z.MAX_BITS_PER_GRANULE);
+ for (o = l = 0; o < f.mode_gr; o++) for (_ = 0; _ < f.channels_out; _++) s[o][_] > Z.MAX_BITS_PER_CHANNEL && (s[o][_] = Z.MAX_BITS_PER_CHANNEL), l += s[o][_];
+ if (l > r[0]) for (o = 0; o < f.mode_gr; o++) for (_ = 0; _ < f.channels_out; _++) s[o][_] *= r[0], s[o][_] /= l;
};
}
- function L() {
+ function N() {
this.thm = new i(), this.en = new i();
}
- function Ae() {
- var k = Ae.MPG_MD_MS_LR,
- R = null,
- x = this.psy = null,
- B = null;
- this.setModules = function (e, t, a, n) {
- R = e, this.psy = t, x = t, B = n;
+ function Pe() {
+ var E = Pe.FFTOFFSET,
+ P = Pe.MPG_MD_MS_LR,
+ L = null,
+ I = this.psy = null,
+ H = null,
+ C = null;
+ this.setModules = function (e, t, a, s) {
+ L = e, this.psy = t, I = t, H = s, C = a;
};
- var T = new function () {
- var u = [-.1482523854003001, 32.308141959636465, 296.40344946382766, 883.1344870032432, 11113.947376231741, 1057.2713659324597, 305.7402417275812, 30.825928907280012, 3.8533188138216365, 59.42900443849514, 709.5899960123345, 5281.91112291017, -5829.66483675846, -817.6293103748613, -76.91656988279972, -4.594269939176596, .9063471690191471, .1960342806591213, -.15466694054279598, 34.324387823855965, 301.8067566458425, 817.599602898885, 11573.795901679885, 1181.2520595540152, 321.59731579894424, 31.232021761053772, 3.7107095756221318, 53.650946155329365, 684.167428119626, 5224.56624370173, -6366.391851890084, -908.9766368219582, -89.83068876699639, -5.411397422890401, .8206787908286602, .3901806440322567, -.16070888947830023, 36.147034243915876, 304.11815768187864, 732.7429163887613, 11989.60988270091, 1300.012278487897, 335.28490093152146, 31.48816102859945, 3.373875931311736, 47.232241542899175, 652.7371796173471, 5132.414255594984, -6909.087078780055, -1001.9990371107289, -103.62185754286375, -6.104916304710272, .7416505462720353, .5805693545089249, -.16636367662261495, 37.751650073343995, 303.01103387567713, 627.9747488785183, 12358.763425278165, 1412.2779918482834, 346.7496836825721, 31.598286663170416, 3.1598635433980946, 40.57878626349686, 616.1671130880391, 5007.833007176154, -7454.040671756168, -1095.7960341867115, -118.24411666465777, -6.818469345853504, .6681786379192989, .7653668647301797, -.1716176790982088, 39.11551877123304, 298.3413246578966, 503.5259106886539, 12679.589408408976, 1516.5821921214542, 355.9850766329023, 31.395241710249053, 2.9164211881972335, 33.79716964664243, 574.8943997801362, 4853.234992253242, -7997.57021486075, -1189.7624067269965, -133.6444792601766, -7.7202770609839915, .5993769336819237, .9427934736519954, -.17645823955292173, 40.21879108166477, 289.9982036694474, 359.3226160751053, 12950.259102786438, 1612.1013903507662, 362.85067106591504, 31.045922092242872, 2.822222032597987, 26.988862316190684, 529.8996541764288, 4671.371946949588, -8535.899136645805, -1282.5898586244496, -149.58553632943463, -8.643494270763135, .5345111359507916, 1.111140466039205, -.36174739330527045, 41.04429910497807, 277.5463268268618, 195.6386023135583, 13169.43812144731, 1697.6433561479398, 367.40983966190305, 30.557037410382826, 2.531473372857427, 20.070154905927314, 481.50208566532336, 4464.970341588308, -9065.36882077239, -1373.62841526722, -166.1660487028118, -9.58289321133207, .4729647758913199, 1.268786568327291, -.36970682634889585, 41.393213350082036, 261.2935935556502, 12.935476055240873, 13336.131683328815, 1772.508612059496, 369.76534388639965, 29.751323653701338, 2.4023193045459172, 13.304795348228817, 430.5615775526625, 4237.0568611071185, -9581.931701634761, -1461.6913552409758, -183.12733958476446, -10.718010163869403, .41421356237309503, 1.414213562373095, -.37677560326535325, 41.619486213528496, 241.05423794991074, -187.94665032361226, 13450.063605744153, 1836.153896465782, 369.4908799925761, 29.001847876923147, 2.0714759319987186, 6.779591200894186, 377.7767837205709, 3990.386575512536, -10081.709459700915, -1545.947424837898, -200.3762958015653, -11.864482073055006, .3578057213145241, 1.546020906725474, -.3829366947518991, 41.1516456456653, 216.47684307105183, -406.1569483347166, 13511.136535077321, 1887.8076599260432, 367.3025214564151, 28.136213436723654, 1.913880671464418, .3829366947518991, 323.85365704338597, 3728.1472257487526, -10561.233882199509, -1625.2025997821418, -217.62525175416, -13.015432208941645, .3033466836073424, 1.66293922460509, -.5822628872992417, 40.35639251440489, 188.20071124269245, -640.2706748618148, 13519.21490106562, 1927.6022433578062, 362.8197642637487, 26.968821921868447, 1.7463817695935329, -5.62650678237171, 269.3016715297017, 3453.386536448852, -11016.145278780888, -1698.6569643425091, -234.7658734267683, -14.16351421663124, .2504869601913055, 1.76384252869671, -.5887180101749253, 39.23429103868072, 155.76096234403798, -889.2492977967378, 13475.470561874661, 1955.0535223723712, 356.4450994756727, 25.894952980042156, 1.5695032905781554, -11.181939564328772, 214.80884394039484, 3169.1640829158237, -11443.321309975563, -1765.1588461316153, -251.68908574481912, -15.49755935939164, .198912367379658, 1.847759065022573, -.7912582233652842, 37.39369355329111, 119.699486012458, -1151.0956593239027, 13380.446257078214, 1970.3952110853447, 348.01959814116185, 24.731487364283044, 1.3850130831637748, -16.421408865300393, 161.05030052864092, 2878.3322807850063, -11838.991423510031, -1823.985884688674, -268.2854986386903, -16.81724543849939, .1483359875383474, 1.913880671464418, -.7960642926861912, 35.2322109610459, 80.01928065061526, -1424.0212633405113, 13235.794061869668, 1973.804052543835, 337.9908651258184, 23.289159354463873, 1.3934255946442087, -21.099669467133474, 108.48348407242611, 2583.700758091299, -12199.726194855148, -1874.2780658979746, -284.2467154529415, -18.11369784385905, .09849140335716425, 1.961570560806461, -.998795456205172, 32.56307803611191, 36.958364584370486, -1706.075448829146, 13043.287458812016, 1965.3831106103316, 326.43182772364605, 22.175018750622293, 1.198638339011324, -25.371248002043963, 57.53505923036915, 2288.41886619975, -12522.674544337233, -1914.8400385312243, -299.26241273417224, -19.37805630698734, .04912684976946725, 1.990369453344394, .035780907 * V.SQRT2 * .5 / 2384e-9, .017876148 * V.SQRT2 * .5 / 2384e-9, .003134727 * V.SQRT2 * .5 / 2384e-9, .002457142 * V.SQRT2 * .5 / 2384e-9, 971317e-9 * V.SQRT2 * .5 / 2384e-9, 218868e-9 * V.SQRT2 * .5 / 2384e-9, 101566e-9 * V.SQRT2 * .5 / 2384e-9, 13828e-9 * V.SQRT2 * .5 / 2384e-9, 12804.797818791945, 1945.5515939597317, 313.4244966442953, 49591e-9 / 2384e-9, 1995.1556208053692, 21458e-9 / 2384e-9, -69618e-9 / 2384e-9],
- A = [[2.382191739347913e-13, 6.423305872147834e-13, 9.400849094049688e-13, 1.122435026096556e-12, 1.183840321267481e-12, 1.122435026096556e-12, 9.40084909404969e-13, 6.423305872147839e-13, 2.382191739347918e-13, 5.456116108943412e-12, 4.878985199565852e-12, 4.240448995017367e-12, 3.559909094758252e-12, 2.858043359288075e-12, 2.156177623817898e-12, 1.475637723558783e-12, 8.371015190102974e-13, 2.599706096327376e-13, -5.456116108943412e-12, -4.878985199565852e-12, -4.240448995017367e-12, -3.559909094758252e-12, -2.858043359288076e-12, -2.156177623817898e-12, -1.475637723558783e-12, -8.371015190102975e-13, -2.599706096327376e-13, -2.382191739347923e-13, -6.423305872147843e-13, -9.400849094049696e-13, -1.122435026096556e-12, -1.183840321267481e-12, -1.122435026096556e-12, -9.400849094049694e-13, -6.42330587214784e-13, -2.382191739347918e-13], [2.382191739347913e-13, 6.423305872147834e-13, 9.400849094049688e-13, 1.122435026096556e-12, 1.183840321267481e-12, 1.122435026096556e-12, 9.400849094049688e-13, 6.423305872147841e-13, 2.382191739347918e-13, 5.456116108943413e-12, 4.878985199565852e-12, 4.240448995017367e-12, 3.559909094758253e-12, 2.858043359288075e-12, 2.156177623817898e-12, 1.475637723558782e-12, 8.371015190102975e-13, 2.599706096327376e-13, -5.461314069809755e-12, -4.921085770524055e-12, -4.343405037091838e-12, -3.732668368707687e-12, -3.093523840190885e-12, -2.430835727329465e-12, -1.734679010007751e-12, -9.74825365660928e-13, -2.797435120168326e-13, 0, 0, 0, 0, 0, 0, -2.283748241799531e-13, -4.037858874020686e-13, -2.146547464825323e-13], [.1316524975873958, .414213562373095, .7673269879789602, 1.091308501069271, 1.303225372841206, 1.56968557711749, 1.920982126971166, 2.414213562373094, 3.171594802363212, 4.510708503662055, 7.595754112725146, 22.90376554843115, .984807753012208, .6427876096865394, .3420201433256688, .9396926207859084, -.1736481776669303, -.7660444431189779, .8660254037844387, .5, -.5144957554275265, -.4717319685649723, -.3133774542039019, -.1819131996109812, -.09457419252642064, -.04096558288530405, -.01419856857247115, -.003699974673760037, .8574929257125442, .8817419973177052, .9496286491027329, .9833145924917901, .9955178160675857, .9991605581781475, .999899195244447, .9999931550702802], [0, 0, 0, 0, 0, 0, 2.283748241799531e-13, 4.037858874020686e-13, 2.146547464825323e-13, 5.461314069809755e-12, 4.921085770524055e-12, 4.343405037091838e-12, 3.732668368707687e-12, 3.093523840190885e-12, 2.430835727329466e-12, 1.734679010007751e-12, 9.74825365660928e-13, 2.797435120168326e-13, -5.456116108943413e-12, -4.878985199565852e-12, -4.240448995017367e-12, -3.559909094758253e-12, -2.858043359288075e-12, -2.156177623817898e-12, -1.475637723558782e-12, -8.371015190102975e-13, -2.599706096327376e-13, -2.382191739347913e-13, -6.423305872147834e-13, -9.400849094049688e-13, -1.122435026096556e-12, -1.183840321267481e-12, -1.122435026096556e-12, -9.400849094049688e-13, -6.423305872147841e-13, -2.382191739347918e-13]],
- k = A[Ae.SHORT_TYPE],
- S = A[Ae.SHORT_TYPE],
- R = A[Ae.SHORT_TYPE],
- x = A[Ae.SHORT_TYPE],
- B = [0, 1, 16, 17, 8, 9, 24, 25, 4, 5, 20, 21, 12, 13, 28, 29, 2, 3, 18, 19, 10, 11, 26, 27, 6, 7, 22, 23, 14, 15, 30, 31];
- function T(e, t, a) {
- for (var n, s, r, i = 10, o = t + 238 - 14 - 286, _ = -15; _ < 0; _++) {
+ var V = new function () {
+ var h = [-.1482523854003001, 32.308141959636465, 296.40344946382766, 883.1344870032432, 11113.947376231741, 1057.2713659324597, 305.7402417275812, 30.825928907280012, 3.8533188138216365, 59.42900443849514, 709.5899960123345, 5281.91112291017, -5829.66483675846, -817.6293103748613, -76.91656988279972, -4.594269939176596, .9063471690191471, .1960342806591213, -.15466694054279598, 34.324387823855965, 301.8067566458425, 817.599602898885, 11573.795901679885, 1181.2520595540152, 321.59731579894424, 31.232021761053772, 3.7107095756221318, 53.650946155329365, 684.167428119626, 5224.56624370173, -6366.391851890084, -908.9766368219582, -89.83068876699639, -5.411397422890401, .8206787908286602, .3901806440322567, -.16070888947830023, 36.147034243915876, 304.11815768187864, 732.7429163887613, 11989.60988270091, 1300.012278487897, 335.28490093152146, 31.48816102859945, 3.373875931311736, 47.232241542899175, 652.7371796173471, 5132.414255594984, -6909.087078780055, -1001.9990371107289, -103.62185754286375, -6.104916304710272, .7416505462720353, .5805693545089249, -.16636367662261495, 37.751650073343995, 303.01103387567713, 627.9747488785183, 12358.763425278165, 1412.2779918482834, 346.7496836825721, 31.598286663170416, 3.1598635433980946, 40.57878626349686, 616.1671130880391, 5007.833007176154, -7454.040671756168, -1095.7960341867115, -118.24411666465777, -6.818469345853504, .6681786379192989, .7653668647301797, -.1716176790982088, 39.11551877123304, 298.3413246578966, 503.5259106886539, 12679.589408408976, 1516.5821921214542, 355.9850766329023, 31.395241710249053, 2.9164211881972335, 33.79716964664243, 574.8943997801362, 4853.234992253242, -7997.57021486075, -1189.7624067269965, -133.6444792601766, -7.7202770609839915, .5993769336819237, .9427934736519954, -.17645823955292173, 40.21879108166477, 289.9982036694474, 359.3226160751053, 12950.259102786438, 1612.1013903507662, 362.85067106591504, 31.045922092242872, 2.822222032597987, 26.988862316190684, 529.8996541764288, 4671.371946949588, -8535.899136645805, -1282.5898586244496, -149.58553632943463, -8.643494270763135, .5345111359507916, 1.111140466039205, -.36174739330527045, 41.04429910497807, 277.5463268268618, 195.6386023135583, 13169.43812144731, 1697.6433561479398, 367.40983966190305, 30.557037410382826, 2.531473372857427, 20.070154905927314, 481.50208566532336, 4464.970341588308, -9065.36882077239, -1373.62841526722, -166.1660487028118, -9.58289321133207, .4729647758913199, 1.268786568327291, -.36970682634889585, 41.393213350082036, 261.2935935556502, 12.935476055240873, 13336.131683328815, 1772.508612059496, 369.76534388639965, 29.751323653701338, 2.4023193045459172, 13.304795348228817, 430.5615775526625, 4237.0568611071185, -9581.931701634761, -1461.6913552409758, -183.12733958476446, -10.718010163869403, .41421356237309503, 1.414213562373095, -.37677560326535325, 41.619486213528496, 241.05423794991074, -187.94665032361226, 13450.063605744153, 1836.153896465782, 369.4908799925761, 29.001847876923147, 2.0714759319987186, 6.779591200894186, 377.7767837205709, 3990.386575512536, -10081.709459700915, -1545.947424837898, -200.3762958015653, -11.864482073055006, .3578057213145241, 1.546020906725474, -.3829366947518991, 41.1516456456653, 216.47684307105183, -406.1569483347166, 13511.136535077321, 1887.8076599260432, 367.3025214564151, 28.136213436723654, 1.913880671464418, .3829366947518991, 323.85365704338597, 3728.1472257487526, -10561.233882199509, -1625.2025997821418, -217.62525175416, -13.015432208941645, .3033466836073424, 1.66293922460509, -.5822628872992417, 40.35639251440489, 188.20071124269245, -640.2706748618148, 13519.21490106562, 1927.6022433578062, 362.8197642637487, 26.968821921868447, 1.7463817695935329, -5.62650678237171, 269.3016715297017, 3453.386536448852, -11016.145278780888, -1698.6569643425091, -234.7658734267683, -14.16351421663124, .2504869601913055, 1.76384252869671, -.5887180101749253, 39.23429103868072, 155.76096234403798, -889.2492977967378, 13475.470561874661, 1955.0535223723712, 356.4450994756727, 25.894952980042156, 1.5695032905781554, -11.181939564328772, 214.80884394039484, 3169.1640829158237, -11443.321309975563, -1765.1588461316153, -251.68908574481912, -15.49755935939164, .198912367379658, 1.847759065022573, -.7912582233652842, 37.39369355329111, 119.699486012458, -1151.0956593239027, 13380.446257078214, 1970.3952110853447, 348.01959814116185, 24.731487364283044, 1.3850130831637748, -16.421408865300393, 161.05030052864092, 2878.3322807850063, -11838.991423510031, -1823.985884688674, -268.2854986386903, -16.81724543849939, .1483359875383474, 1.913880671464418, -.7960642926861912, 35.2322109610459, 80.01928065061526, -1424.0212633405113, 13235.794061869668, 1973.804052543835, 337.9908651258184, 23.289159354463873, 1.3934255946442087, -21.099669467133474, 108.48348407242611, 2583.700758091299, -12199.726194855148, -1874.2780658979746, -284.2467154529415, -18.11369784385905, .09849140335716425, 1.961570560806461, -.998795456205172, 32.56307803611191, 36.958364584370486, -1706.075448829146, 13043.287458812016, 1965.3831106103316, 326.43182772364605, 22.175018750622293, 1.198638339011324, -25.371248002043963, 57.53505923036915, 2288.41886619975, -12522.674544337233, -1914.8400385312243, -299.26241273417224, -19.37805630698734, .04912684976946725, 1.990369453344394, .035780907 * ee.SQRT2 * .5 / 2384e-9, .017876148 * ee.SQRT2 * .5 / 2384e-9, .003134727 * ee.SQRT2 * .5 / 2384e-9, .002457142 * ee.SQRT2 * .5 / 2384e-9, 971317e-9 * ee.SQRT2 * .5 / 2384e-9, 218868e-9 * ee.SQRT2 * .5 / 2384e-9, 101566e-9 * ee.SQRT2 * .5 / 2384e-9, 13828e-9 * ee.SQRT2 * .5 / 2384e-9, 12804.797818791945, 1945.5515939597317, 313.4244966442953, 49591e-9 / 2384e-9, 1995.1556208053692, 21458e-9 / 2384e-9, -69618e-9 / 2384e-9],
+ z = [[2.382191739347913e-13, 6.423305872147834e-13, 9.400849094049688e-13, 1.122435026096556e-12, 1.183840321267481e-12, 1.122435026096556e-12, 9.40084909404969e-13, 6.423305872147839e-13, 2.382191739347918e-13, 5.456116108943412e-12, 4.878985199565852e-12, 4.240448995017367e-12, 3.559909094758252e-12, 2.858043359288075e-12, 2.156177623817898e-12, 1.475637723558783e-12, 8.371015190102974e-13, 2.599706096327376e-13, -5.456116108943412e-12, -4.878985199565852e-12, -4.240448995017367e-12, -3.559909094758252e-12, -2.858043359288076e-12, -2.156177623817898e-12, -1.475637723558783e-12, -8.371015190102975e-13, -2.599706096327376e-13, -2.382191739347923e-13, -6.423305872147843e-13, -9.400849094049696e-13, -1.122435026096556e-12, -1.183840321267481e-12, -1.122435026096556e-12, -9.400849094049694e-13, -6.42330587214784e-13, -2.382191739347918e-13], [2.382191739347913e-13, 6.423305872147834e-13, 9.400849094049688e-13, 1.122435026096556e-12, 1.183840321267481e-12, 1.122435026096556e-12, 9.400849094049688e-13, 6.423305872147841e-13, 2.382191739347918e-13, 5.456116108943413e-12, 4.878985199565852e-12, 4.240448995017367e-12, 3.559909094758253e-12, 2.858043359288075e-12, 2.156177623817898e-12, 1.475637723558782e-12, 8.371015190102975e-13, 2.599706096327376e-13, -5.461314069809755e-12, -4.921085770524055e-12, -4.343405037091838e-12, -3.732668368707687e-12, -3.093523840190885e-12, -2.430835727329465e-12, -1.734679010007751e-12, -9.74825365660928e-13, -2.797435120168326e-13, 0, 0, 0, 0, 0, 0, -2.283748241799531e-13, -4.037858874020686e-13, -2.146547464825323e-13], [.1316524975873958, .414213562373095, .7673269879789602, 1.091308501069271, 1.303225372841206, 1.56968557711749, 1.920982126971166, 2.414213562373094, 3.171594802363212, 4.510708503662055, 7.595754112725146, 22.90376554843115, .984807753012208, .6427876096865394, .3420201433256688, .9396926207859084, -.1736481776669303, -.7660444431189779, .8660254037844387, .5, -.5144957554275265, -.4717319685649723, -.3133774542039019, -.1819131996109812, -.09457419252642064, -.04096558288530405, -.01419856857247115, -.003699974673760037, .8574929257125442, .8817419973177052, .9496286491027329, .9833145924917901, .9955178160675857, .9991605581781475, .999899195244447, .9999931550702802], [0, 0, 0, 0, 0, 0, 2.283748241799531e-13, 4.037858874020686e-13, 2.146547464825323e-13, 5.461314069809755e-12, 4.921085770524055e-12, 4.343405037091838e-12, 3.732668368707687e-12, 3.093523840190885e-12, 2.430835727329466e-12, 1.734679010007751e-12, 9.74825365660928e-13, 2.797435120168326e-13, -5.456116108943413e-12, -4.878985199565852e-12, -4.240448995017367e-12, -3.559909094758253e-12, -2.858043359288075e-12, -2.156177623817898e-12, -1.475637723558782e-12, -8.371015190102975e-13, -2.599706096327376e-13, -2.382191739347913e-13, -6.423305872147834e-13, -9.400849094049688e-13, -1.122435026096556e-12, -1.183840321267481e-12, -1.122435026096556e-12, -9.400849094049688e-13, -6.423305872147841e-13, -2.382191739347918e-13]],
+ Z = z[Pe.SHORT_TYPE],
+ K = z[Pe.SHORT_TYPE],
+ G = z[Pe.SHORT_TYPE],
+ U = z[Pe.SHORT_TYPE],
+ Q = [0, 1, 16, 17, 8, 9, 24, 25, 4, 5, 20, 21, 12, 13, 28, 29, 2, 3, 18, 19, 10, 11, 26, 27, 6, 7, 22, 23, 14, 15, 30, 31];
+ function W(e, t, a) {
+ for (var s, n, r, i = 10, o = t + 238 - 14 - 286, _ = -15; _ < 0; _++) {
var l, f, c;
- l = u[i + -10], f = e[o + -224] * l, c = e[t + 224] * l, l = u[i + -9], f += e[o + -160] * l, c += e[t + 160] * l, l = u[i + -8], f += e[o + -96] * l, c += e[t + 96] * l, l = u[i + -7], f += e[o + -32] * l, c += e[t + 32] * l, l = u[i + -6], f += e[o + 32] * l, c += e[t + -32] * l, l = u[i + -5], f += e[o + 96] * l, c += e[t + -96] * l, l = u[i + -4], f += e[o + 160] * l, c += e[t + -160] * l, l = u[i + -3], f += e[o + 224] * l, c += e[t + -224] * l, l = u[i + -2], f += e[t + -256] * l, c -= e[o + 256] * l, l = u[i + -1], f += e[t + -192] * l, c -= e[o + 192] * l, l = u[i + 0], f += e[t + -128] * l, c -= e[o + 128] * l, l = u[i + 1], f += e[t + -64] * l, c -= e[o + 64] * l, l = u[i + 2], f += e[t + 0] * l, c -= e[o + 0] * l, l = u[i + 3], f += e[t + 64] * l, c -= e[o + -64] * l, l = u[i + 4], f += e[t + 128] * l, c -= e[o + -128] * l, l = u[i + 5], f += e[t + 192] * l, c -= e[o + -192] * l, f *= u[i + 6], l = c - f, a[30 + 2 * _] = c + f, a[31 + 2 * _] = u[i + 7] * l, i += 18, t--, o++;
+ l = h[i + -10], f = e[o + -224] * l, c = e[t + 224] * l, l = h[i + -9], f += e[o + -160] * l, c += e[t + 160] * l, l = h[i + -8], f += e[o + -96] * l, c += e[t + 96] * l, l = h[i + -7], f += e[o + -32] * l, c += e[t + 32] * l, l = h[i + -6], f += e[o + 32] * l, c += e[t + -32] * l, l = h[i + -5], f += e[o + 96] * l, c += e[t + -96] * l, l = h[i + -4], f += e[o + 160] * l, c += e[t + -160] * l, l = h[i + -3], f += e[o + 224] * l, c += e[t + -224] * l, l = h[i + -2], f += e[t + -256] * l, c -= e[o + 256] * l, l = h[i + -1], f += e[t + -192] * l, c -= e[o + 192] * l, l = h[i + 0], f += e[t + -128] * l, c -= e[o + 128] * l, l = h[i + 1], f += e[t + -64] * l, c -= e[o + 64] * l, l = h[i + 2], f += e[t + 0] * l, c -= e[o + 0] * l, l = h[i + 3], f += e[t + 64] * l, c -= e[o + -64] * l, l = h[i + 4], f += e[t + 128] * l, c -= e[o + -128] * l, l = h[i + 5], f += e[t + 192] * l, l = (c -= e[o + -192] * l) - (f *= h[i + 6]), a[30 + 2 * _] = c + f, a[31 + 2 * _] = h[i + 7] * l, i += 18, t--, o++;
}
- c = e[t + -16] * u[i + -10], f = e[t + -32] * u[i + -2], c += (e[t + -48] - e[t + 16]) * u[i + -9], f += e[t + -96] * u[i + -1], c += (e[t + -80] + e[t + 48]) * u[i + -8], f += e[t + -160] * u[i + 0], c += (e[t + -112] - e[t + 80]) * u[i + -7], f += e[t + -224] * u[i + 1], c += (e[t + -144] + e[t + 112]) * u[i + -6], f -= e[t + 32] * u[i + 2], c += (e[t + -176] - e[t + 144]) * u[i + -5], f -= e[t + 96] * u[i + 3], c += (e[t + -208] + e[t + 176]) * u[i + -4], f -= e[t + 160] * u[i + 4], c += (e[t + -240] - e[t + 208]) * u[i + -3], f -= e[t + 224], n = f - c, s = f + c, c = a[14], f = a[15] - c, a[31] = s + c, a[30] = n + f, a[15] = n - f, a[14] = s - c, r = a[28] - a[0], a[0] += a[28], a[28] = r * u[i + -36 + 7], r = a[29] - a[1], a[1] += a[29], a[29] = r * u[i + -36 + 7], r = a[26] - a[2], a[2] += a[26], a[26] = r * u[i + -72 + 7], r = a[27] - a[3], a[3] += a[27], a[27] = r * u[i + -72 + 7], r = a[24] - a[4], a[4] += a[24], a[24] = r * u[i + -108 + 7], r = a[25] - a[5], a[5] += a[25], a[25] = r * u[i + -108 + 7], r = a[22] - a[6], a[6] += a[22], a[22] = r * V.SQRT2, r = a[23] - a[7], a[7] += a[23], a[23] = r * V.SQRT2 - a[7], a[7] -= a[6], a[22] -= a[7], a[23] -= a[22], r = a[6], a[6] = a[31] - r, a[31] = a[31] + r, r = a[7], a[7] = a[30] - r, a[30] = a[30] + r, r = a[22], a[22] = a[15] - r, a[15] = a[15] + r, r = a[23], a[23] = a[14] - r, a[14] = a[14] + r, r = a[20] - a[8], a[8] += a[20], a[20] = r * u[i + -180 + 7], r = a[21] - a[9], a[9] += a[21], a[21] = r * u[i + -180 + 7], r = a[18] - a[10], a[10] += a[18], a[18] = r * u[i + -216 + 7], r = a[19] - a[11], a[11] += a[19], a[19] = r * u[i + -216 + 7], r = a[16] - a[12], a[12] += a[16], a[16] = r * u[i + -252 + 7], r = a[17] - a[13], a[13] += a[17], a[17] = r * u[i + -252 + 7], r = -a[20] + a[24], a[20] += a[24], a[24] = r * u[i + -216 + 7], r = -a[21] + a[25], a[21] += a[25], a[25] = r * u[i + -216 + 7], r = a[4] - a[8], a[4] += a[8], a[8] = r * u[i + -216 + 7], r = a[5] - a[9], a[5] += a[9], a[9] = r * u[i + -216 + 7], r = a[0] - a[12], a[0] += a[12], a[12] = r * u[i + -72 + 7], r = a[1] - a[13], a[1] += a[13], a[13] = r * u[i + -72 + 7], r = a[16] - a[28], a[16] += a[28], a[28] = r * u[i + -72 + 7], r = -a[17] + a[29], a[17] += a[29], a[29] = r * u[i + -72 + 7], r = V.SQRT2 * (a[2] - a[10]), a[2] += a[10], a[10] = r, r = V.SQRT2 * (a[3] - a[11]), a[3] += a[11], a[11] = r, r = V.SQRT2 * (-a[18] + a[26]), a[18] += a[26], a[26] = r - a[18], r = V.SQRT2 * (-a[19] + a[27]), a[19] += a[27], a[27] = r - a[19], r = a[2], a[19] -= a[3], a[3] -= r, a[2] = a[31] - r, a[31] += r, r = a[3], a[11] -= a[19], a[18] -= r, a[3] = a[30] - r, a[30] += r, r = a[18], a[27] -= a[11], a[19] -= r, a[18] = a[15] - r, a[15] += r, r = a[19], a[10] -= r, a[19] = a[14] - r, a[14] += r, r = a[10], a[11] -= r, a[10] = a[23] - r, a[23] += r, r = a[11], a[26] -= r, a[11] = a[22] - r, a[22] += r, r = a[26], a[27] -= r, a[26] = a[7] - r, a[7] += r, r = a[27], a[27] = a[6] - r, a[6] += r, r = V.SQRT2 * (a[0] - a[4]), a[0] += a[4], a[4] = r, r = V.SQRT2 * (a[1] - a[5]), a[1] += a[5], a[5] = r, r = V.SQRT2 * (a[16] - a[20]), a[16] += a[20], a[20] = r, r = V.SQRT2 * (a[17] - a[21]), a[17] += a[21], a[21] = r, r = -V.SQRT2 * (a[8] - a[12]), a[8] += a[12], a[12] = r - a[8], r = -V.SQRT2 * (a[9] - a[13]), a[9] += a[13], a[13] = r - a[9], r = -V.SQRT2 * (a[25] - a[29]), a[25] += a[29], a[29] = r - a[25], r = -V.SQRT2 * (a[24] + a[28]), a[24] -= a[28], a[28] = r - a[24], r = a[24] - a[16], a[24] = r, r = a[20] - r, a[20] = r, r = a[28] - r, a[28] = r, r = a[25] - a[17], a[25] = r, r = a[21] - r, a[21] = r, r = a[29] - r, a[29] = r, r = a[17] - a[1], a[17] = r, r = a[9] - r, a[9] = r, r = a[25] - r, a[25] = r, r = a[5] - r, a[5] = r, r = a[21] - r, a[21] = r, r = a[13] - r, a[13] = r, r = a[29] - r, a[29] = r, r = a[1] - a[0], a[1] = r, r = a[16] - r, a[16] = r, r = a[17] - r, a[17] = r, r = a[8] - r, a[8] = r, r = a[9] - r, a[9] = r, r = a[24] - r, a[24] = r, r = a[25] - r, a[25] = r, r = a[4] - r, a[4] = r, r = a[5] - r, a[5] = r, r = a[20] - r, a[20] = r, r = a[21] - r, a[21] = r, r = a[12] - r, a[12] = r, r = a[13] - r, a[13] = r, r = a[28] - r, a[28] = r, r = a[29] - r, a[29] = r, r = a[0], a[0] += a[31], a[31] -= r, r = a[1], a[1] += a[30], a[30] -= r, r = a[16], a[16] += a[15], a[15] -= r, r = a[17], a[17] += a[14], a[14] -= r, r = a[8], a[8] += a[23], a[23] -= r, r = a[9], a[9] += a[22], a[22] -= r, r = a[24], a[24] += a[7], a[7] -= r, r = a[25], a[25] += a[6], a[6] -= r, r = a[4], a[4] += a[27], a[27] -= r, r = a[5], a[5] += a[26], a[26] -= r, r = a[20], a[20] += a[11], a[11] -= r, r = a[21], a[21] += a[10], a[10] -= r, r = a[12], a[12] += a[19], a[19] -= r, r = a[13], a[13] += a[18], a[18] -= r, r = a[28], a[28] += a[3], a[3] -= r, r = a[29], a[29] += a[2], a[2] -= r;
+ c = e[t + -16] * h[i + -10], f = e[t + -32] * h[i + -2], c += (e[t + -48] - e[t + 16]) * h[i + -9], f += e[t + -96] * h[i + -1], c += (e[t + -80] + e[t + 48]) * h[i + -8], f += e[t + -160] * h[i + 0], c += (e[t + -112] - e[t + 80]) * h[i + -7], f += e[t + -224] * h[i + 1], c += (e[t + -144] + e[t + 112]) * h[i + -6], f -= e[t + 32] * h[i + 2], c += (e[t + -176] - e[t + 144]) * h[i + -5], f -= e[t + 96] * h[i + 3], c += (e[t + -208] + e[t + 176]) * h[i + -4], f -= e[t + 160] * h[i + 4], c += (e[t + -240] - e[t + 208]) * h[i + -3], s = (f -= e[t + 224]) - c, n = f + c, c = a[14], f = a[15] - c, a[31] = n + c, a[30] = s + f, a[15] = s - f, a[14] = n - c, r = a[28] - a[0], a[0] += a[28], a[28] = r * h[i + -36 + 7], r = a[29] - a[1], a[1] += a[29], a[29] = r * h[i + -36 + 7], r = a[26] - a[2], a[2] += a[26], a[26] = r * h[i + -72 + 7], r = a[27] - a[3], a[3] += a[27], a[27] = r * h[i + -72 + 7], r = a[24] - a[4], a[4] += a[24], a[24] = r * h[i + -108 + 7], r = a[25] - a[5], a[5] += a[25], a[25] = r * h[i + -108 + 7], r = a[22] - a[6], a[6] += a[22], a[22] = r * ee.SQRT2, r = a[23] - a[7], a[7] += a[23], a[23] = r * ee.SQRT2 - a[7], a[7] -= a[6], a[22] -= a[7], a[23] -= a[22], r = a[6], a[6] = a[31] - r, a[31] = a[31] + r, r = a[7], a[7] = a[30] - r, a[30] = a[30] + r, r = a[22], a[22] = a[15] - r, a[15] = a[15] + r, r = a[23], a[23] = a[14] - r, a[14] = a[14] + r, r = a[20] - a[8], a[8] += a[20], a[20] = r * h[i + -180 + 7], r = a[21] - a[9], a[9] += a[21], a[21] = r * h[i + -180 + 7], r = a[18] - a[10], a[10] += a[18], a[18] = r * h[i + -216 + 7], r = a[19] - a[11], a[11] += a[19], a[19] = r * h[i + -216 + 7], r = a[16] - a[12], a[12] += a[16], a[16] = r * h[i + -252 + 7], r = a[17] - a[13], a[13] += a[17], a[17] = r * h[i + -252 + 7], r = -a[20] + a[24], a[20] += a[24], a[24] = r * h[i + -216 + 7], r = -a[21] + a[25], a[21] += a[25], a[25] = r * h[i + -216 + 7], r = a[4] - a[8], a[4] += a[8], a[8] = r * h[i + -216 + 7], r = a[5] - a[9], a[5] += a[9], a[9] = r * h[i + -216 + 7], r = a[0] - a[12], a[0] += a[12], a[12] = r * h[i + -72 + 7], r = a[1] - a[13], a[1] += a[13], a[13] = r * h[i + -72 + 7], r = a[16] - a[28], a[16] += a[28], a[28] = r * h[i + -72 + 7], r = -a[17] + a[29], a[17] += a[29], a[29] = r * h[i + -72 + 7], r = ee.SQRT2 * (a[2] - a[10]), a[2] += a[10], a[10] = r, r = ee.SQRT2 * (a[3] - a[11]), a[3] += a[11], a[11] = r, r = ee.SQRT2 * (-a[18] + a[26]), a[18] += a[26], a[26] = r - a[18], r = ee.SQRT2 * (-a[19] + a[27]), a[19] += a[27], a[27] = r - a[19], r = a[2], a[19] -= a[3], a[3] -= r, a[2] = a[31] - r, a[31] += r, r = a[3], a[11] -= a[19], a[18] -= r, a[3] = a[30] - r, a[30] += r, r = a[18], a[27] -= a[11], a[19] -= r, a[18] = a[15] - r, a[15] += r, r = a[19], a[10] -= r, a[19] = a[14] - r, a[14] += r, r = a[10], a[11] -= r, a[10] = a[23] - r, a[23] += r, r = a[11], a[26] -= r, a[11] = a[22] - r, a[22] += r, r = a[26], a[27] -= r, a[26] = a[7] - r, a[7] += r, r = a[27], a[27] = a[6] - r, a[6] += r, r = ee.SQRT2 * (a[0] - a[4]), a[0] += a[4], a[4] = r, r = ee.SQRT2 * (a[1] - a[5]), a[1] += a[5], a[5] = r, r = ee.SQRT2 * (a[16] - a[20]), a[16] += a[20], a[20] = r, r = ee.SQRT2 * (a[17] - a[21]), a[17] += a[21], a[21] = r, r = -ee.SQRT2 * (a[8] - a[12]), a[8] += a[12], a[12] = r - a[8], r = -ee.SQRT2 * (a[9] - a[13]), a[9] += a[13], a[13] = r - a[9], r = -ee.SQRT2 * (a[25] - a[29]), a[25] += a[29], a[29] = r - a[25], r = -ee.SQRT2 * (a[24] + a[28]), a[24] -= a[28], a[28] = r - a[24], r = a[24] - a[16], a[24] = r, r = a[20] - r, a[20] = r, r = a[28] - r, a[28] = r, r = a[25] - a[17], a[25] = r, r = a[21] - r, a[21] = r, r = a[29] - r, a[29] = r, r = a[17] - a[1], a[17] = r, r = a[9] - r, a[9] = r, r = a[25] - r, a[25] = r, r = a[5] - r, a[5] = r, r = a[21] - r, a[21] = r, r = a[13] - r, a[13] = r, r = a[29] - r, a[29] = r, r = a[1] - a[0], a[1] = r, r = a[16] - r, a[16] = r, r = a[17] - r, a[17] = r, r = a[8] - r, a[8] = r, r = a[9] - r, a[9] = r, r = a[24] - r, a[24] = r, r = a[25] - r, a[25] = r, r = a[4] - r, a[4] = r, r = a[5] - r, a[5] = r, r = a[20] - r, a[20] = r, r = a[21] - r, a[21] = r, r = a[12] - r, a[12] = r, r = a[13] - r, a[13] = r, r = a[28] - r, a[28] = r, r = a[29] - r, a[29] = r, r = a[0], a[0] += a[31], a[31] -= r, r = a[1], a[1] += a[30], a[30] -= r, r = a[16], a[16] += a[15], a[15] -= r, r = a[17], a[17] += a[14], a[14] -= r, r = a[8], a[8] += a[23], a[23] -= r, r = a[9], a[9] += a[22], a[22] -= r, r = a[24], a[24] += a[7], a[7] -= r, r = a[25], a[25] += a[6], a[6] -= r, r = a[4], a[4] += a[27], a[27] -= r, r = a[5], a[5] += a[26], a[26] -= r, r = a[20], a[20] += a[11], a[11] -= r, r = a[21], a[21] += a[10], a[10] -= r, r = a[12], a[12] += a[19], a[19] -= r, r = a[13], a[13] += a[18], a[18] -= r, r = a[28], a[28] += a[3], a[3] -= r, r = a[29], a[29] += a[2], a[2] -= r;
}
- function E(e, t) {
+ function J(e, t) {
for (var a = 0; a < 3; a++) {
- var n, s, r, i, o, _;
- i = e[t + 6] * A[Ae.SHORT_TYPE][0] - e[t + 15], n = e[t + 0] * A[Ae.SHORT_TYPE][2] - e[t + 9], s = i + n, r = i - n, i = e[t + 15] * A[Ae.SHORT_TYPE][0] + e[t + 6], n = e[t + 9] * A[Ae.SHORT_TYPE][2] + e[t + 0], o = i + n, _ = -i + n, n = 2.069978111953089e-11 * (e[t + 3] * A[Ae.SHORT_TYPE][1] - e[t + 12]), i = 2.069978111953089e-11 * (e[t + 12] * A[Ae.SHORT_TYPE][1] + e[t + 3]), e[t + 0] = 1.90752519173728e-11 * s + n, e[t + 15] = 1.90752519173728e-11 * -o + i, r = .8660254037844387 * r * 1.907525191737281e-11, o = .5 * o * 1.907525191737281e-11 + i, e[t + 3] = r - o, e[t + 6] = r + o, s = .5 * s * 1.907525191737281e-11 - n, _ = .8660254037844387 * _ * 1.907525191737281e-11, e[t + 9] = s + _, e[t + 12] = s - _, t++;
+ var s, n, r, i, o, _;
+ n = (i = e[t + 6] * z[Pe.SHORT_TYPE][0] - e[t + 15]) + (s = e[t + 0] * z[Pe.SHORT_TYPE][2] - e[t + 9]), r = i - s, o = (i = e[t + 15] * z[Pe.SHORT_TYPE][0] + e[t + 6]) + (s = e[t + 9] * z[Pe.SHORT_TYPE][2] + e[t + 0]), _ = -i + s, s = 2.069978111953089e-11 * (e[t + 3] * z[Pe.SHORT_TYPE][1] - e[t + 12]), i = 2.069978111953089e-11 * (e[t + 12] * z[Pe.SHORT_TYPE][1] + e[t + 3]), e[t + 0] = 1.90752519173728e-11 * n + s, e[t + 15] = 1.90752519173728e-11 * -o + i, r = .8660254037844387 * r * 1.907525191737281e-11, o = .5 * o * 1.907525191737281e-11 + i, e[t + 3] = r - o, e[t + 6] = r + o, n = .5 * n * 1.907525191737281e-11 - s, _ = .8660254037844387 * _ * 1.907525191737281e-11, e[t + 9] = n + _, e[t + 12] = n - _, t++;
}
}
- function C(e, t, a) {
- var n, s, r, i, o, _, l, f, c, u, h, b, p, m, v, d, g, w;
- r = a[17] - a[9], o = a[15] - a[11], _ = a[14] - a[12], l = a[0] + a[8], f = a[1] + a[7], c = a[2] + a[6], u = a[3] + a[5], e[t + 17] = l + c - u - (f - a[4]), s = (l + c - u) * S[19] + (f - a[4]), n = (r - o - _) * S[18], e[t + 5] = n + s, e[t + 6] = n - s, i = (a[16] - a[10]) * S[18], f = f * S[19] + a[4], n = r * S[12] + i + o * S[13] + _ * S[14], s = -l * S[16] + f - c * S[17] + u * S[15], e[t + 1] = n + s, e[t + 2] = n - s, n = r * S[13] - i - o * S[14] + _ * S[12], s = -l * S[17] + f - c * S[15] + u * S[16], e[t + 9] = n + s, e[t + 10] = n - s, n = r * S[14] - i + o * S[12] - _ * S[13], s = l * S[15] - f + c * S[16] - u * S[17], e[t + 13] = n + s, e[t + 14] = n - s, h = a[8] - a[0], p = a[6] - a[2], m = a[5] - a[3], v = a[17] + a[9], d = a[16] + a[10], g = a[15] + a[11], w = a[14] + a[12], e[t + 0] = v + g + w + (d + a[13]), n = (v + g + w) * S[19] - (d + a[13]), s = (h - p + m) * S[18], e[t + 11] = n + s, e[t + 12] = n - s, b = (a[7] - a[1]) * S[18], d = a[13] - d * S[19], n = v * S[15] - d + g * S[16] + w * S[17], s = h * S[14] + b + p * S[12] + m * S[13], e[t + 3] = n + s, e[t + 4] = n - s, n = -v * S[17] + d - g * S[15] - w * S[16], s = h * S[13] + b - p * S[14] - m * S[12], e[t + 7] = n + s, e[t + 8] = n - s, n = -v * S[16] + d - g * S[17] - w * S[15], s = h * S[12] - b + p * S[13] - m * S[14], e[t + 15] = n + s, e[t + 16] = n - s;
- }
this.mdct_sub48 = function (e, t, a) {
- for (var n = t, s = 286, r = 0; r < e.channels_out; r++) {
- for (var i = 0; i < e.mode_gr; i++) {
- for (var o, _ = e.l3_side.tt[i][r], l = _.xr, f = 0, c = e.sb_sample[r][1 - i], u = 0, h = 0; h < 9; h++) for (T(n, s, c[u]), T(n, s + 32, c[u + 1]), u += 2, s += 64, o = 1; o < 32; o += 2) c[u - 1][o] *= -1;
- for (o = 0; o < 32; o++, f += 18) {
- var b = _.block_type,
- p = e.sb_sample[r][i],
- m = e.sb_sample[r][1 - i];
- if (0 != _.mixed_block_flag && o < 2 && (b = 0), e.amp_filter[o] < 1e-12) we.fill(l, f + 0, f + 18, 0);else if (e.amp_filter[o] < 1 && me(), b == Ae.SHORT_TYPE) {
- for (var h = -3; h < 0; h++) {
- var v = A[Ae.SHORT_TYPE][h + 3];
- l[f + 3 * h + 9] = p[9 + h][B[o]] * v - p[8 - h][B[o]], l[f + 3 * h + 18] = p[14 - h][B[o]] * v + p[15 + h][B[o]], l[f + 3 * h + 10] = p[15 + h][B[o]] * v - p[14 - h][B[o]], l[f + 3 * h + 19] = m[2 - h][B[o]] * v + m[3 + h][B[o]], l[f + 3 * h + 11] = m[3 + h][B[o]] * v - m[2 - h][B[o]], l[f + 3 * h + 20] = m[8 - h][B[o]] * v + m[9 + h][B[o]];
+ for (var s, n, r, i, o, _, l, f, c, h, u, m, p, b, v, d, g, S, M, w, R, A = t, B = 286, k = 0; k < e.channels_out; k++) {
+ for (var y = 0; y < e.mode_gr; y++) {
+ for (var T, x = e.l3_side.tt[y][k], E = x.xr, P = 0, L = e.sb_sample[k][1 - y], I = 0, H = 0; H < 9; H++) for (W(A, B, L[I]), W(A, B + 32, L[I + 1]), I += 2, B += 64, T = 1; T < 32; T += 2) L[I - 1][T] *= -1;
+ for (T = 0; T < 32; T++, P += 18) {
+ var C = x.block_type,
+ V = e.sb_sample[k][y],
+ O = e.sb_sample[k][1 - y];
+ if (0 != x.mixed_block_flag && T < 2 && (C = 0), e.amp_filter[T] < 1e-12) ye.fill(E, P + 0, P + 18, 0);else {
+ if (e.amp_filter[T] < 1) for (H = 0; H < 18; H++) O[H][Q[T]] *= e.amp_filter[T];
+ if (C == Pe.SHORT_TYPE) {
+ for (H = -3; H < 0; H++) {
+ var N = z[Pe.SHORT_TYPE][H + 3];
+ E[P + 3 * H + 9] = V[9 + H][Q[T]] * N - V[8 - H][Q[T]], E[P + 3 * H + 18] = V[14 - H][Q[T]] * N + V[15 + H][Q[T]], E[P + 3 * H + 10] = V[15 + H][Q[T]] * N - V[14 - H][Q[T]], E[P + 3 * H + 19] = O[2 - H][Q[T]] * N + O[3 + H][Q[T]], E[P + 3 * H + 11] = O[3 + H][Q[T]] * N - O[2 - H][Q[T]], E[P + 3 * H + 20] = O[8 - H][Q[T]] * N + O[9 + H][Q[T]];
+ }
+ J(E, P);
+ } else {
+ var D = Be(18);
+ for (H = -9; H < 0; H++) {
+ var Y, X;
+ Y = z[C][H + 27] * O[H + 9][Q[T]] + z[C][H + 36] * O[8 - H][Q[T]], X = z[C][H + 9] * V[H + 9][Q[T]] - z[C][H + 18] * V[8 - H][Q[T]], D[H + 9] = Y - X * Z[3 + H + 9], D[H + 18] = Y * Z[3 + H + 9] + X;
+ }
+ s = E, n = P, R = w = M = S = g = d = v = b = p = m = u = h = c = f = l = _ = o = i = void 0, _ = (r = D)[17] - r[9], f = r[15] - r[11], c = r[14] - r[12], h = r[0] + r[8], u = r[1] + r[7], m = r[2] + r[6], p = r[3] + r[5], s[n + 17] = h + m - p - (u - r[4]), o = (h + m - p) * K[19] + (u - r[4]), i = (_ - f - c) * K[18], s[n + 5] = i + o, s[n + 6] = i - o, l = (r[16] - r[10]) * K[18], u = u * K[19] + r[4], i = _ * K[12] + l + f * K[13] + c * K[14], o = -h * K[16] + u - m * K[17] + p * K[15], s[n + 1] = i + o, s[n + 2] = i - o, i = _ * K[13] - l - f * K[14] + c * K[12], o = -h * K[17] + u - m * K[15] + p * K[16], s[n + 9] = i + o, s[n + 10] = i - o, i = _ * K[14] - l + f * K[12] - c * K[13], o = h * K[15] - u + m * K[16] - p * K[17], s[n + 13] = i + o, s[n + 14] = i - o, b = r[8] - r[0], d = r[6] - r[2], g = r[5] - r[3], S = r[17] + r[9], M = r[16] + r[10], w = r[15] + r[11], R = r[14] + r[12], s[n + 0] = S + w + R + (M + r[13]), i = (S + w + R) * K[19] - (M + r[13]), o = (b - d + g) * K[18], s[n + 11] = i + o, s[n + 12] = i - o, v = (r[7] - r[1]) * K[18], M = r[13] - M * K[19], i = S * K[15] - M + w * K[16] + R * K[17], o = b * K[14] + v + d * K[12] + g * K[13], s[n + 3] = i + o, s[n + 4] = i - o, i = -S * K[17] + M - w * K[15] - R * K[16], o = b * K[13] + v - d * K[14] - g * K[12], s[n + 7] = i + o, s[n + 8] = i - o, i = -S * K[16] + M - w * K[17] - R * K[15], o = b * K[12] - v + d * K[13] - g * K[14], s[n + 15] = i + o, s[n + 16] = i - o;
}
- E(l, f);
- } else {
- for (var d = de(18), h = -9; h < 0; h++) {
- var g, w;
- g = A[b][h + 27] * m[h + 9][B[o]] + A[b][h + 36] * m[8 - h][B[o]], w = A[b][h + 9] * p[h + 9][B[o]] - A[b][h + 18] * p[8 - h][B[o]], d[h + 9] = g - w * k[3 + h + 9], d[h + 18] = g * k[3 + h + 9] + w;
- }
- C(l, f, d);
}
- if (b != Ae.SHORT_TYPE && 0 != o) for (var h = 7; 0 <= h; --h) {
- var S, M;
- S = l[f + h] * R[20 + h] + l[f + -1 - h] * x[28 + h], M = l[f + h] * x[28 + h] - l[f + -1 - h] * R[20 + h], l[f + -1 - h] = S, l[f + h] = M;
+ if (C != Pe.SHORT_TYPE && 0 != T) for (H = 7; 0 <= H; --H) {
+ var q, F;
+ q = E[P + H] * G[20 + H] + E[P + -1 - H] * U[28 + H], F = E[P + H] * U[28 + H] - E[P + -1 - H] * G[20 + H], E[P + -1 - H] = q, E[P + H] = F;
}
}
}
- if (n = a, s = 286, 1 == e.mode_gr) for (var y = 0; y < 18; y++) I.arraycopy(e.sb_sample[r][1][y], 0, e.sb_sample[r][0][y], 0, 32);
+ if (A = a, B = 286, 1 == e.mode_gr) for (var j = 0; j < 18; j++) $.arraycopy(e.sb_sample[k][1][j], 0, e.sb_sample[k][0][j], 0, 32);
}
};
}();
- this.lame_encode_mp3_frame = function (e, t, a, n, s, r) {
+ this.lame_encode_mp3_frame = function (e, t, a, s, n, r) {
var i,
- o = E([2, 2]);
- o[0][0] = new L(), o[0][1] = new L(), o[1][0] = new L(), o[1][1] = new L();
+ o = O([2, 2]);
+ o[0][0] = new N(), o[0][1] = new N(), o[1][0] = new N(), o[1][1] = new N();
var _,
- l = E([2, 2]);
- l[0][0] = new L(), l[0][1] = new L(), l[1][0] = new L(), l[1][1] = new L();
+ l = O([2, 2]);
+ l[0][0] = new N(), l[0][1] = new N(), l[1][0] = new N(), l[1][1] = new N();
var f,
c,
- u,
- h = [null, null],
- b = e.internal_flags,
- p = ge([2, 4]),
- m = [[0, 0], [0, 0]],
- v = [[0, 0], [0, 0]];
- if (h[0] = t, h[1] = a, 0 == b.lame_encode_frame_init && function (e, t) {
+ h,
+ u = [null, null],
+ m = e.internal_flags,
+ p = ke([2, 4]),
+ b = [.5, .5],
+ v = [[0, 0], [0, 0]],
+ d = [[0, 0], [0, 0]];
+ if (u[0] = t, u[1] = a, 0 == m.lame_encode_frame_init && function (e, t) {
var a,
- n,
- s = e.internal_flags;
- if (0 == s.lame_encode_frame_init) {
+ s,
+ n = e.internal_flags;
+ if (0 == n.lame_encode_frame_init) {
var r,
i,
- o = de(2014),
- _ = de(2014);
- for (s.lame_encode_frame_init = 1, i = r = 0; r < 286 + 576 * (1 + s.mode_gr); ++r) r < 576 * s.mode_gr ? (o[r] = 0, 2 == s.channels_out && (_[r] = 0)) : (o[r] = t[0][i], 2 == s.channels_out && (_[r] = t[1][i]), ++i);
- for (n = 0; n < s.mode_gr; n++) for (a = 0; a < s.channels_out; a++) s.l3_side.tt[n][a].block_type = Ae.SHORT_TYPE;
- T.mdct_sub48(s, o, _);
+ o = Be(2014),
+ _ = Be(2014);
+ for (n.lame_encode_frame_init = 1, i = r = 0; r < 286 + 576 * (1 + n.mode_gr); ++r) r < 576 * n.mode_gr ? (o[r] = 0, 2 == n.channels_out && (_[r] = 0)) : (o[r] = t[0][i], 2 == n.channels_out && (_[r] = t[1][i]), ++i);
+ for (s = 0; s < n.mode_gr; s++) for (a = 0; a < n.channels_out; a++) n.l3_side.tt[s][a].block_type = Pe.SHORT_TYPE;
+ V.mdct_sub48(n, o, _);
}
- }(e, h), b.padding = 0, (b.slot_lag -= b.frac_SpF) < 0 && (b.slot_lag += e.out_samplerate, b.padding = 1), 0 != b.psymodel) {
- var d,
- g = [null, null],
- w = 0,
- S = ve(2);
- for (u = 0; u < b.mode_gr; u++) {
- for (c = 0; c < b.channels_out; c++) g[c] = h[c], w = 576 + 576 * u - Ae.FFTOFFSET;
- if (e.VBR == Me.vbr_mtrh || e.VBR == Me.vbr_mt ? me() : d = x.L3psycho_anal_ns(e, g, w, u, o, l, m[u], v[u], p[u], S), 0 != d) return -4;
- for (e.mode == ye.JOINT_STEREO && me(), c = 0; c < b.channels_out; c++) {
- var M = b.l3_side.tt[u][c];
- M.block_type = S[c], M.mixed_block_flag = 0;
+ }(e, u), m.padding = 0, (m.slot_lag -= m.frac_SpF) < 0 && (m.slot_lag += e.out_samplerate, m.padding = 1), 0 != m.psymodel) {
+ var g = [null, null],
+ S = 0,
+ M = Ae(2);
+ for (h = 0; h < m.mode_gr; h++) {
+ for (c = 0; c < m.channels_out; c++) g[c] = u[c], S = 576 + 576 * h - Pe.FFTOFFSET;
+ if (0 != (e.VBR == xe.vbr_mtrh || e.VBR == xe.vbr_mt ? I.L3psycho_anal_vbr(e, g, S, h, o, l, v[h], d[h], p[h], M) : I.L3psycho_anal_ns(e, g, S, h, o, l, v[h], d[h], p[h], M))) return -4;
+ for (e.mode == Ee.JOINT_STEREO && (b[h] = p[h][2] + p[h][3], 0 < b[h] && (b[h] = p[h][3] / b[h])), c = 0; c < m.channels_out; c++) {
+ var w = m.l3_side.tt[h][c];
+ w.block_type = M[c], w.mixed_block_flag = 0;
}
}
- } else me();
+ } else for (h = 0; h < m.mode_gr; h++) for (c = 0; c < m.channels_out; c++) m.l3_side.tt[h][c].block_type = Pe.NORM_TYPE, m.l3_side.tt[h][c].mixed_block_flag = 0, d[h][c] = v[h][c] = 700;
if (function (e) {
var t, a;
- if (0 == e.ATH.useAdjust) return e.ATH.adjust = 1;
- if (a = e.loudness_sq[0][0], t = e.loudness_sq[1][0], 2 == e.channels_out ? me() : (a += a, t += t), 2 == e.mode_gr && (a = Math.max(a, t)), a *= .5, .03125 < (a *= e.ATH.aaSensitivityP)) 1 <= e.ATH.adjust ? e.ATH.adjust = 1 : e.ATH.adjust < e.ATH.adjustLimit && (e.ATH.adjust = e.ATH.adjustLimit), e.ATH.adjustLimit = 1;else {
- var n = 31.98 * a + 625e-6;
- e.ATH.adjust >= n ? (e.ATH.adjust *= .075 * n + .925, e.ATH.adjust < n && (e.ATH.adjust = n)) : e.ATH.adjustLimit >= n ? e.ATH.adjust = n : e.ATH.adjust < e.ATH.adjustLimit && (e.ATH.adjust = e.ATH.adjustLimit), e.ATH.adjustLimit = n;
+ if (0 != e.ATH.useAdjust) {
+ if (a = e.loudness_sq[0][0], t = e.loudness_sq[1][0], 2 == e.channels_out ? (a += e.loudness_sq[0][1], t += e.loudness_sq[1][1]) : (a += a, t += t), 2 == e.mode_gr && (a = Math.max(a, t)), a *= .5, .03125 < (a *= e.ATH.aaSensitivityP)) 1 <= e.ATH.adjust ? e.ATH.adjust = 1 : e.ATH.adjust < e.ATH.adjustLimit && (e.ATH.adjust = e.ATH.adjustLimit), e.ATH.adjustLimit = 1;else {
+ var s = 31.98 * a + 625e-6;
+ e.ATH.adjust >= s ? (e.ATH.adjust *= .075 * s + .925, e.ATH.adjust < s && (e.ATH.adjust = s)) : e.ATH.adjustLimit >= s ? e.ATH.adjust = s : e.ATH.adjust < e.ATH.adjustLimit && (e.ATH.adjust = e.ATH.adjustLimit), e.ATH.adjustLimit = s;
+ }
+ } else e.ATH.adjust = 1;
+ }(m), V.mdct_sub48(m, u[0], u[1]), m.mode_ext = Pe.MPG_MD_LR_LR, e.force_ms) m.mode_ext = Pe.MPG_MD_MS_LR;else if (e.mode == Ee.JOINT_STEREO) {
+ var R = 0,
+ A = 0;
+ for (h = 0; h < m.mode_gr; h++) for (c = 0; c < m.channels_out; c++) R += d[h][c], A += v[h][c];
+ if (R <= 1 * A) {
+ var B = m.l3_side.tt[0],
+ k = m.l3_side.tt[m.mode_gr - 1];
+ B[0].block_type == B[1].block_type && k[0].block_type == k[1].block_type && (m.mode_ext = Pe.MPG_MD_MS_LR);
}
- }(b), T.mdct_sub48(b, h[0], h[1]), b.mode_ext = Ae.MPG_MD_LR_LR, e.force_ms ? b.mode_ext = Ae.MPG_MD_MS_LR : e.mode == ye.JOINT_STEREO && me(), b.mode_ext == k ? (_ = l, f = v) : (_ = o, f = m), e.analysis && null != b.pinfo && me(), e.VBR == Me.vbr_off || e.VBR == Me.vbr_abr) {
- var y, A;
- for (y = 0; y < 18; y++) b.nsPsy.pefirbuf[y] = b.nsPsy.pefirbuf[y + 1];
- for (u = A = 0; u < b.mode_gr; u++) for (c = 0; c < b.channels_out; c++) A += f[u][c];
- for (b.nsPsy.pefirbuf[18] = A, A = b.nsPsy.pefirbuf[9], y = 0; y < 9; y++) A += (b.nsPsy.pefirbuf[y] + b.nsPsy.pefirbuf[18 - y]) * Ae.fircoef[y];
- for (A = 3350 * b.mode_gr * b.channels_out / A, u = 0; u < b.mode_gr; u++) for (c = 0; c < b.channels_out; c++) f[u][c] *= A;
}
- return b.iteration_loop.iteration_loop(e, f, [.5, .5], _), R.format_bitstream(e), i = R.copy_buffer(b, n, s, r, 1), e.bWriteVbrTag && B.addVbrFrame(e), e.analysis && null != b.pinfo && me(), function (e) {
- var t, a;
- for (e.bitrate_stereoMode_Hist[e.bitrate_index][4]++, e.bitrate_stereoMode_Hist[15][4]++, 2 == e.channels_out && me(), t = 0; t < e.mode_gr; ++t) for (a = 0; a < e.channels_out; ++a) {
- var n = 0 | e.l3_side.tt[t][a].block_type;
- 0 != e.l3_side.tt[t][a].mixed_block_flag && (n = 4), e.bitrate_blockType_Hist[e.bitrate_index][n]++, e.bitrate_blockType_Hist[e.bitrate_index][5]++, e.bitrate_blockType_Hist[15][n]++, e.bitrate_blockType_Hist[15][5]++;
+ if (m.mode_ext == P ? (_ = l, f = d) : (_ = o, f = v), e.analysis && null != m.pinfo) for (h = 0; h < m.mode_gr; h++) for (c = 0; c < m.channels_out; c++) m.pinfo.ms_ratio[h] = m.ms_ratio[h], m.pinfo.ms_ener_ratio[h] = b[h], m.pinfo.blocktype[h][c] = m.l3_side.tt[h][c].block_type, m.pinfo.pe[h][c] = f[h][c], $.arraycopy(m.l3_side.tt[h][c].xr, 0, m.pinfo.xr[h][c], 0, 576), m.mode_ext == P && (m.pinfo.ers[h][c] = m.pinfo.ers[h][c + 2], $.arraycopy(m.pinfo.energy[h][c + 2], 0, m.pinfo.energy[h][c], 0, m.pinfo.energy[h][c].length));
+ if (e.VBR == xe.vbr_off || e.VBR == xe.vbr_abr) {
+ var y, T;
+ for (y = 0; y < 18; y++) m.nsPsy.pefirbuf[y] = m.nsPsy.pefirbuf[y + 1];
+ for (h = T = 0; h < m.mode_gr; h++) for (c = 0; c < m.channels_out; c++) T += f[h][c];
+ for (m.nsPsy.pefirbuf[18] = T, T = m.nsPsy.pefirbuf[9], y = 0; y < 9; y++) T += (m.nsPsy.pefirbuf[y] + m.nsPsy.pefirbuf[18 - y]) * Pe.fircoef[y];
+ for (T = 3350 * m.mode_gr * m.channels_out / T, h = 0; h < m.mode_gr; h++) for (c = 0; c < m.channels_out; c++) f[h][c] *= T;
+ }
+ if (m.iteration_loop.iteration_loop(e, f, b, _), L.format_bitstream(e), i = L.copy_buffer(m, s, n, r, 1), e.bWriteVbrTag && H.addVbrFrame(e), e.analysis && null != m.pinfo) {
+ for (c = 0; c < m.channels_out; c++) {
+ var x;
+ for (x = 0; x < E; x++) m.pinfo.pcmdata[c][x] = m.pinfo.pcmdata[c][x + e.framesize];
+ for (x = E; x < 1600; x++) m.pinfo.pcmdata[c][x] = u[c][x - E];
}
- }(b), i;
+ C.set_frame_pinfo(e, _);
+ }
+ return function (e) {
+ var t, a;
+ for (e.bitrate_stereoMode_Hist[e.bitrate_index][4]++, e.bitrate_stereoMode_Hist[15][4]++, 2 == e.channels_out && (e.bitrate_stereoMode_Hist[e.bitrate_index][e.mode_ext]++, e.bitrate_stereoMode_Hist[15][e.mode_ext]++), t = 0; t < e.mode_gr; ++t) for (a = 0; a < e.channels_out; ++a) {
+ var s = 0 | e.l3_side.tt[t][a].block_type;
+ 0 != e.l3_side.tt[t][a].mixed_block_flag && (s = 4), e.bitrate_blockType_Hist[e.bitrate_index][s]++, e.bitrate_blockType_Hist[e.bitrate_index][5]++, e.bitrate_blockType_Hist[15][s]++, e.bitrate_blockType_Hist[15][5]++;
+ }
+ }(m), i;
};
}
function i() {
- this.l = de(Ae.SBMAX_l), this.s = ge([Ae.SBMAX_s, 3]);
- var n = this;
+ this.l = Be(Pe.SBMAX_l), this.s = ke([Pe.SBMAX_s, 3]);
+ var s = this;
this.assign = function (e) {
- I.arraycopy(e.l, 0, n.l, 0, Ae.SBMAX_l);
- for (var t = 0; t < Ae.SBMAX_s; t++) for (var a = 0; a < 3; a++) n.s[t][a] = e.s[t][a];
+ $.arraycopy(e.l, 0, s.l, 0, Pe.SBMAX_l);
+ for (var t = 0; t < Pe.SBMAX_s; t++) for (var a = 0; a < 3; a++) s.s[t][a] = e.s[t][a];
};
}
- function j() {
+ function Z() {
var e = 40;
function t() {
- this.write_timing = 0, this.ptr = 0, this.buf = S(e);
+ this.write_timing = 0, this.ptr = 0, this.buf = A(e);
}
- this.Class_ID = 0, this.lame_encode_frame_init = 0, this.iteration_init_init = 0, this.fill_buffer_resample_init = 0, this.mfbuf = ge([2, j.MFSIZE]), this.mode_gr = 0, this.channels_in = 0, this.channels_out = 0, this.resample_ratio = 0, this.mf_samples_to_encode = 0, this.mf_size = 0, this.VBR_min_bitrate = 0, this.VBR_max_bitrate = 0, this.bitrate_index = 0, this.samplerate_index = 0, this.mode_ext = 0, this.lowpass1 = 0, this.lowpass2 = 0, this.highpass1 = 0, this.highpass2 = 0, this.noise_shaping = 0, this.noise_shaping_amp = 0, this.substep_shaping = 0, this.psymodel = 0, this.noise_shaping_stop = 0, this.subblock_gain = 0, this.use_best_huffman = 0, this.full_outer_loop = 0, this.l3_side = new function () {
- this.tt = [[null, null], [null, null]], this.main_data_begin = 0, this.private_bits = 0, this.resvDrain_pre = 0, this.resvDrain_post = 0, this.scfsi = [ve(4), ve(4)];
- for (var e = 0; e < 2; e++) for (var t = 0; t < 2; t++) this.tt[e][t] = new B();
- }(), this.ms_ratio = de(2), this.padding = 0, this.frac_SpF = 0, this.slot_lag = 0, this.tag_spec = null, this.nMusicCRC = 0, this.OldValue = ve(2), this.CurrentStep = ve(2), this.masking_lower = 0, this.bv_scf = ve(576), this.pseudohalf = ve(F.SFBMAX), this.sfb21_extra = !1, this.inbuf_old = new Array(2), this.blackfilt = new Array(2 * j.BPC + 1), this.itime = n(2), this.sideinfo_len = 0, this.sb_sample = ge([2, 2, 18, Ae.SBLIMIT]), this.amp_filter = de(32), this.header = new Array(j.MAX_HEADER_BUF), this.h_ptr = 0, this.w_ptr = 0, this.ancillary_flag = 0, this.ResvSize = 0, this.ResvMax = 0, this.scalefac_band = new r(), this.minval_l = de(Ae.CBANDS), this.minval_s = de(Ae.CBANDS), this.nb_1 = ge([4, Ae.CBANDS]), this.nb_2 = ge([4, Ae.CBANDS]), this.nb_s1 = ge([4, Ae.CBANDS]), this.nb_s2 = ge([4, Ae.CBANDS]), this.s3_ss = null, this.s3_ll = null, this.decay = 0, this.thm = new Array(4), this.en = new Array(4), this.tot_ener = de(4), this.loudness_sq = ge([2, 2]), this.loudness_sq_save = de(2), this.mld_l = de(Ae.SBMAX_l), this.mld_s = de(Ae.SBMAX_s), this.bm_l = ve(Ae.SBMAX_l), this.bo_l = ve(Ae.SBMAX_l), this.bm_s = ve(Ae.SBMAX_s), this.bo_s = ve(Ae.SBMAX_s), this.npart_l = 0, this.npart_s = 0, this.s3ind = w([Ae.CBANDS, 2]), this.s3ind_s = w([Ae.CBANDS, 2]), this.numlines_s = ve(Ae.CBANDS), this.numlines_l = ve(Ae.CBANDS), this.rnumlines_l = de(Ae.CBANDS), this.mld_cb_l = de(Ae.CBANDS), this.mld_cb_s = de(Ae.CBANDS), this.numlines_s_num1 = 0, this.numlines_l_num1 = 0, this.pe = de(4), this.ms_ratio_s_old = 0, this.ms_ratio_l_old = 0, this.ms_ener_ratio_old = 0, this.blocktype_old = ve(2), this.nsPsy = new function () {
- this.last_en_subshort = ge([4, 9]), this.lastAttacks = ve(4), this.pefirbuf = de(19), this.longfact = de(Ae.SBMAX_l), this.shortfact = de(Ae.SBMAX_s), this.attackthre = 0, this.attackthre_s = 0;
+ this.Class_ID = 0, this.lame_encode_frame_init = 0, this.iteration_init_init = 0, this.fill_buffer_resample_init = 0, this.mfbuf = ke([2, Z.MFSIZE]), this.mode_gr = 0, this.channels_in = 0, this.channels_out = 0, this.resample_ratio = 0, this.mf_samples_to_encode = 0, this.mf_size = 0, this.VBR_min_bitrate = 0, this.VBR_max_bitrate = 0, this.bitrate_index = 0, this.samplerate_index = 0, this.mode_ext = 0, this.lowpass1 = 0, this.lowpass2 = 0, this.highpass1 = 0, this.highpass2 = 0, this.noise_shaping = 0, this.noise_shaping_amp = 0, this.substep_shaping = 0, this.psymodel = 0, this.noise_shaping_stop = 0, this.subblock_gain = 0, this.use_best_huffman = 0, this.full_outer_loop = 0, this.l3_side = new function () {
+ this.tt = [[null, null], [null, null]], this.main_data_begin = 0, this.private_bits = 0, this.resvDrain_pre = 0, this.resvDrain_post = 0, this.scfsi = [Ae(4), Ae(4)];
+ for (var e = 0; e < 2; e++) for (var t = 0; t < 2; t++) this.tt[e][t] = new T();
+ }(), this.ms_ratio = Be(2), this.padding = 0, this.frac_SpF = 0, this.slot_lag = 0, this.tag_spec = null, this.nMusicCRC = 0, this.OldValue = Ae(2), this.CurrentStep = Ae(2), this.masking_lower = 0, this.bv_scf = Ae(576), this.pseudohalf = Ae(z.SFBMAX), this.sfb21_extra = !1, this.inbuf_old = new Array(2), this.blackfilt = new Array(2 * Z.BPC + 1), this.itime = s(2), this.sideinfo_len = 0, this.sb_sample = ke([2, 2, 18, Pe.SBLIMIT]), this.amp_filter = Be(32), this.header = new Array(Z.MAX_HEADER_BUF), this.h_ptr = 0, this.w_ptr = 0, this.ancillary_flag = 0, this.ResvSize = 0, this.ResvMax = 0, this.scalefac_band = new r(), this.minval_l = Be(Pe.CBANDS), this.minval_s = Be(Pe.CBANDS), this.nb_1 = ke([4, Pe.CBANDS]), this.nb_2 = ke([4, Pe.CBANDS]), this.nb_s1 = ke([4, Pe.CBANDS]), this.nb_s2 = ke([4, Pe.CBANDS]), this.s3_ss = null, this.s3_ll = null, this.decay = 0, this.thm = new Array(4), this.en = new Array(4), this.tot_ener = Be(4), this.loudness_sq = ke([2, 2]), this.loudness_sq_save = Be(2), this.mld_l = Be(Pe.SBMAX_l), this.mld_s = Be(Pe.SBMAX_s), this.bm_l = Ae(Pe.SBMAX_l), this.bo_l = Ae(Pe.SBMAX_l), this.bm_s = Ae(Pe.SBMAX_s), this.bo_s = Ae(Pe.SBMAX_s), this.npart_l = 0, this.npart_s = 0, this.s3ind = Y([Pe.CBANDS, 2]), this.s3ind_s = Y([Pe.CBANDS, 2]), this.numlines_s = Ae(Pe.CBANDS), this.numlines_l = Ae(Pe.CBANDS), this.rnumlines_l = Be(Pe.CBANDS), this.mld_cb_l = Be(Pe.CBANDS), this.mld_cb_s = Be(Pe.CBANDS), this.numlines_s_num1 = 0, this.numlines_l_num1 = 0, this.pe = Be(4), this.ms_ratio_s_old = 0, this.ms_ratio_l_old = 0, this.ms_ener_ratio_old = 0, this.blocktype_old = Ae(2), this.nsPsy = new function () {
+ this.last_en_subshort = ke([4, 9]), this.lastAttacks = Ae(4), this.pefirbuf = Be(19), this.longfact = Be(Pe.SBMAX_l), this.shortfact = Be(Pe.SBMAX_s), this.attackthre = 0, this.attackthre_s = 0;
}(), this.VBR_seek_table = new function () {
this.sum = 0, this.seen = 0, this.want = 0, this.pos = 0, this.size = 0, this.bag = null, this.nVbrNumFrames = 0, this.nBytesWritten = 0, this.TotalFrameSize = 0;
- }(), this.ATH = null, this.PSY = null, this.nogap_total = 0, this.nogap_current = 0, this.decode_on_the_fly = !0, this.findReplayGain = !0, this.findPeakSample = !0, this.PeakSample = 0, this.RadioGain = 0, this.AudiophileGain = 0, this.rgdata = null, this.noclipGainChange = 0, this.noclipScale = 0, this.bitrate_stereoMode_Hist = w([16, 5]), this.bitrate_blockType_Hist = w([16, 6]), this.pinfo = null, this.hip = null, this.in_buffer_nsamples = 0, this.in_buffer_0 = null, this.in_buffer_1 = null, this.iteration_loop = null;
+ }(), this.ATH = null, this.PSY = null, this.nogap_total = 0, this.nogap_current = 0, this.decode_on_the_fly = !0, this.findReplayGain = !0, this.findPeakSample = !0, this.PeakSample = 0, this.RadioGain = 0, this.AudiophileGain = 0, this.rgdata = null, this.noclipGainChange = 0, this.noclipScale = 0, this.bitrate_stereoMode_Hist = Y([16, 5]), this.bitrate_blockType_Hist = Y([16, 6]), this.pinfo = null, this.hip = null, this.in_buffer_nsamples = 0, this.in_buffer_0 = null, this.in_buffer_1 = null, this.iteration_loop = null;
for (var a = 0; a < this.en.length; a++) this.en[a] = new i();
- for (var a = 0; a < this.thm.length; a++) this.thm[a] = new i();
- for (var a = 0; a < this.header.length; a++) this.header[a] = new t();
+ for (a = 0; a < this.thm.length; a++) this.thm[a] = new i();
+ for (a = 0; a < this.header.length; a++) this.header[a] = new t();
}
- function X() {
- var k = new function () {
- var h = de(Ae.BLKSIZE),
- p = de(Ae.BLKSIZE_s / 2),
- x = [.9238795325112867, .3826834323650898, .9951847266721969, .0980171403295606, .9996988186962042, .02454122852291229, .9999811752826011, .006135884649154475];
- function m(e, t, a) {
- var n,
- s,
+ function G() {
+ var B = new function () {
+ var u = Be(Pe.BLKSIZE),
+ p = Be(Pe.BLKSIZE_s / 2),
+ y = [.9238795325112867, .3826834323650898, .9951847266721969, .0980171403295606, .9996988186962042, .02454122852291229, .9999811752826011, .006135884649154475];
+ function b(e, t, a) {
+ var s,
+ n,
r,
i = 0,
o = t + (a <<= 1);
- n = 4;
+ s = 4;
do {
- var _, l, f, c, u, h, b;
- for (b = n >> 1, h = (u = (c = n) << 1) + c, n = u << 1, r = (s = t) + b; S = e[s + 0] - e[s + c], w = e[s + 0] + e[s + c], k = e[s + u] - e[s + h], y = e[s + u] + e[s + h], e[s + u] = w - y, e[s + 0] = w + y, e[s + h] = S - k, e[s + c] = S + k, S = e[r + 0] - e[r + c], w = e[r + 0] + e[r + c], k = V.SQRT2 * e[r + h], y = V.SQRT2 * e[r + u], e[r + u] = w - y, e[r + 0] = w + y, e[r + h] = S - k, e[r + c] = S + k, r += n, (s += n) < o;);
- for (l = x[i + 0], _ = x[i + 1], f = 1; f < b; f++) {
- var p, m;
- p = 1 - 2 * _ * _, m = 2 * _ * l, s = t + f, r = t + c - f;
+ var _, l, f, c, h, u, m;
+ for (m = s >> 1, u = (h = (c = s) << 1) + c, s = h << 1, r = (n = t) + m; M = e[n + 0] - e[n + c], S = e[n + 0] + e[n + c], B = e[n + h] - e[n + u], R = e[n + h] + e[n + u], e[n + h] = S - R, e[n + 0] = S + R, e[n + u] = M - B, e[n + c] = M + B, M = e[r + 0] - e[r + c], S = e[r + 0] + e[r + c], B = ee.SQRT2 * e[r + u], R = ee.SQRT2 * e[r + h], e[r + h] = S - R, e[r + 0] = S + R, e[r + u] = M - B, e[r + c] = M + B, r += s, (n += s) < o;);
+ for (l = y[i + 0], _ = y[i + 1], f = 1; f < m; f++) {
+ var p, b;
+ p = 1 - 2 * _ * _, b = 2 * _ * l, n = t + f, r = t + c - f;
do {
- var v, d, g, w, S, M, y, A, k, R;
- d = m * e[s + c] - p * e[r + c], v = p * e[s + c] + m * e[r + c], S = e[s + 0] - v, w = e[s + 0] + v, M = e[r + 0] - d, g = e[r + 0] + d, d = m * e[s + h] - p * e[r + h], v = p * e[s + h] + m * e[r + h], k = e[s + u] - v, y = e[s + u] + v, R = e[r + u] - d, A = e[r + u] + d, d = _ * y - l * R, v = l * y + _ * R, e[s + u] = w - v, e[s + 0] = w + v, e[r + h] = M - d, e[r + c] = M + d, d = l * A - _ * k, v = _ * A + l * k, e[r + u] = g - v, e[r + 0] = g + v, e[s + h] = S - d, e[s + c] = S + d, r += n, s += n;
- } while (s < o);
- l = (p = l) * x[i + 0] - _ * x[i + 1], _ = p * x[i + 1] + _ * x[i + 0];
+ var v, d, g, S, M, w, R, A, B, k;
+ d = b * e[n + c] - p * e[r + c], v = p * e[n + c] + b * e[r + c], M = e[n + 0] - v, S = e[n + 0] + v, w = e[r + 0] - d, g = e[r + 0] + d, d = b * e[n + u] - p * e[r + u], v = p * e[n + u] + b * e[r + u], B = e[n + h] - v, R = e[n + h] + v, k = e[r + h] - d, A = e[r + h] + d, d = _ * R - l * k, v = l * R + _ * k, e[n + h] = S - v, e[n + 0] = S + v, e[r + u] = w - d, e[r + c] = w + d, d = l * A - _ * B, v = _ * A + l * B, e[r + h] = g - v, e[r + 0] = g + v, e[n + u] = M - d, e[n + c] = M + d, r += s, n += s;
+ } while (n < o);
+ l = (p = l) * y[i + 0] - _ * y[i + 1], _ = p * y[i + 1] + _ * y[i + 0];
}
i += 2;
- } while (n < a);
+ } while (s < a);
}
var v = [0, 128, 64, 192, 32, 160, 96, 224, 16, 144, 80, 208, 48, 176, 112, 240, 8, 136, 72, 200, 40, 168, 104, 232, 24, 152, 88, 216, 56, 184, 120, 248, 4, 132, 68, 196, 36, 164, 100, 228, 20, 148, 84, 212, 52, 180, 116, 244, 12, 140, 76, 204, 44, 172, 108, 236, 28, 156, 92, 220, 60, 188, 124, 252, 2, 130, 66, 194, 34, 162, 98, 226, 18, 146, 82, 210, 50, 178, 114, 242, 10, 138, 74, 202, 42, 170, 106, 234, 26, 154, 90, 218, 58, 186, 122, 250, 6, 134, 70, 198, 38, 166, 102, 230, 22, 150, 86, 214, 54, 182, 118, 246, 14, 142, 78, 206, 46, 174, 110, 238, 30, 158, 94, 222, 62, 190, 126, 254];
- this.fft_short = function (e, t, a, n, s) {
+ this.fft_short = function (e, t, a, s, n) {
for (var r = 0; r < 3; r++) {
- var i = Ae.BLKSIZE_s / 2,
+ var i = Pe.BLKSIZE_s / 2,
o = 65535 & 192 * (r + 1),
- _ = Ae.BLKSIZE_s / 8 - 1;
+ _ = Pe.BLKSIZE_s / 8 - 1;
do {
var l,
f,
c,
- u,
h,
- b = 255 & v[_ << 2];
- l = p[b] * n[a][s + b + o], h = p[127 - b] * n[a][s + b + o + 128], f = l - h, l += h, c = p[b + 64] * n[a][s + b + o + 64], h = p[63 - b] * n[a][s + b + o + 192], u = c - h, c += h, i -= 4, t[r][i + 0] = l + c, t[r][i + 2] = l - c, t[r][i + 1] = f + u, t[r][i + 3] = f - u, l = p[b + 1] * n[a][s + b + o + 1], h = p[126 - b] * n[a][s + b + o + 129], f = l - h, l += h, c = p[b + 65] * n[a][s + b + o + 65], h = p[62 - b] * n[a][s + b + o + 193], u = c - h, c += h, t[r][i + Ae.BLKSIZE_s / 2 + 0] = l + c, t[r][i + Ae.BLKSIZE_s / 2 + 2] = l - c, t[r][i + Ae.BLKSIZE_s / 2 + 1] = f + u, t[r][i + Ae.BLKSIZE_s / 2 + 3] = f - u;
+ u,
+ m = 255 & v[_ << 2];
+ f = (l = p[m] * s[a][n + m + o]) - (u = p[127 - m] * s[a][n + m + o + 128]), l += u, h = (c = p[m + 64] * s[a][n + m + o + 64]) - (u = p[63 - m] * s[a][n + m + o + 192]), c += u, i -= 4, t[r][i + 0] = l + c, t[r][i + 2] = l - c, t[r][i + 1] = f + h, t[r][i + 3] = f - h, f = (l = p[m + 1] * s[a][n + m + o + 1]) - (u = p[126 - m] * s[a][n + m + o + 129]), l += u, h = (c = p[m + 65] * s[a][n + m + o + 65]) - (u = p[62 - m] * s[a][n + m + o + 193]), c += u, t[r][i + Pe.BLKSIZE_s / 2 + 0] = l + c, t[r][i + Pe.BLKSIZE_s / 2 + 2] = l - c, t[r][i + Pe.BLKSIZE_s / 2 + 1] = f + h, t[r][i + Pe.BLKSIZE_s / 2 + 3] = f - h;
} while (0 <= --_);
- m(t[r], i, Ae.BLKSIZE_s / 2);
+ b(t[r], i, Pe.BLKSIZE_s / 2);
}
- }, this.fft_long = function (e, t, a, n, s) {
- var r = Ae.BLKSIZE / 8 - 1,
- i = Ae.BLKSIZE / 2;
+ }, this.fft_long = function (e, t, a, s, n) {
+ var r = Pe.BLKSIZE / 8 - 1,
+ i = Pe.BLKSIZE / 2;
do {
var o,
_,
l,
f,
c,
- u = 255 & v[r];
- o = h[u] * n[a][s + u], c = h[u + 512] * n[a][s + u + 512], _ = o - c, o += c, l = h[u + 256] * n[a][s + u + 256], c = h[u + 768] * n[a][s + u + 768], f = l - c, l += c, t[0 + (i -= 4)] = o + l, t[i + 2] = o - l, t[i + 1] = _ + f, t[i + 3] = _ - f, o = h[u + 1] * n[a][s + u + 1], c = h[u + 513] * n[a][s + u + 513], _ = o - c, o += c, l = h[u + 257] * n[a][s + u + 257], c = h[u + 769] * n[a][s + u + 769], f = l - c, l += c, t[i + Ae.BLKSIZE / 2 + 0] = o + l, t[i + Ae.BLKSIZE / 2 + 2] = o - l, t[i + Ae.BLKSIZE / 2 + 1] = _ + f, t[i + Ae.BLKSIZE / 2 + 3] = _ - f;
+ h = 255 & v[r];
+ _ = (o = u[h] * s[a][n + h]) - (c = u[h + 512] * s[a][n + h + 512]), o += c, f = (l = u[h + 256] * s[a][n + h + 256]) - (c = u[h + 768] * s[a][n + h + 768]), l += c, t[0 + (i -= 4)] = o + l, t[i + 2] = o - l, t[i + 1] = _ + f, t[i + 3] = _ - f, _ = (o = u[h + 1] * s[a][n + h + 1]) - (c = u[h + 513] * s[a][n + h + 513]), o += c, f = (l = u[h + 257] * s[a][n + h + 257]) - (c = u[h + 769] * s[a][n + h + 769]), l += c, t[i + Pe.BLKSIZE / 2 + 0] = o + l, t[i + Pe.BLKSIZE / 2 + 2] = o - l, t[i + Pe.BLKSIZE / 2 + 1] = _ + f, t[i + Pe.BLKSIZE / 2 + 3] = _ - f;
} while (0 <= --r);
- m(t, i, Ae.BLKSIZE / 2);
+ b(t, i, Pe.BLKSIZE / 2);
}, this.init_fft = function (e) {
- for (var t = 0; t < Ae.BLKSIZE; t++) h[t] = .42 - .5 * Math.cos(2 * Math.PI * (t + .5) / Ae.BLKSIZE) + .08 * Math.cos(4 * Math.PI * (t + .5) / Ae.BLKSIZE);
- for (var t = 0; t < Ae.BLKSIZE_s / 2; t++) p[t] = .5 * (1 - Math.cos(2 * Math.PI * (t + .5) / Ae.BLKSIZE_s));
+ for (var t = 0; t < Pe.BLKSIZE; t++) u[t] = .42 - .5 * Math.cos(2 * Math.PI * (t + .5) / Pe.BLKSIZE) + .08 * Math.cos(4 * Math.PI * (t + .5) / Pe.BLKSIZE);
+ for (t = 0; t < Pe.BLKSIZE_s / 2; t++) p[t] = .5 * (1 - Math.cos(2 * Math.PI * (t + .5) / Pe.BLKSIZE_s));
};
}(),
- R = 2.302585092994046,
+ k = 2.302585092994046,
+ _e = 2,
+ le = 16,
d = 2,
g = 16,
E = .34,
- v = 1 / 217621504 / (Ae.BLKSIZE / 2),
- w = .2302585093;
- function se(e, t, a, n, s, r, i, o, _, l, f) {
+ n = 1 / 217621504 / (Pe.BLKSIZE / 2),
+ fe = .3,
+ ce = 21,
+ S = .2302585093;
+ function M(e) {
+ return e;
+ }
+ function N(e, t) {
+ for (var a = 0, s = 0; s < Pe.BLKSIZE / 2; ++s) a += e[s] * t.ATH.eql_w[s];
+ return a *= n;
+ }
+ function he(e, t, a, s, n, r, i, o, _, l, f) {
var c = e.internal_flags;
- _ < 2 ? (k.fft_long(c, n[s], _, l, f), k.fft_short(c, r[i], _, l, f)) : 2 == _ && me(), t[0] = n[s + 0][0], t[0] *= t[0];
- for (var u = Ae.BLKSIZE / 2 - 1; 0 <= u; --u) {
- var h = n[s + 0][Ae.BLKSIZE / 2 - u],
- b = n[s + 0][Ae.BLKSIZE / 2 + u];
- t[Ae.BLKSIZE / 2 - u] = .5 * (h * h + b * b);
- }
- for (var p = 2; 0 <= p; --p) {
- a[p][0] = r[i + 0][p][0], a[p][0] *= a[p][0];
- for (var u = Ae.BLKSIZE_s / 2 - 1; 0 <= u; --u) {
- var h = r[i + 0][p][Ae.BLKSIZE_s / 2 - u],
- b = r[i + 0][p][Ae.BLKSIZE_s / 2 + u];
- a[p][Ae.BLKSIZE_s / 2 - u] = .5 * (h * h + b * b);
+ if (_ < 2) B.fft_long(c, s[n], _, l, f), B.fft_short(c, r[i], _, l, f);else if (2 == _) {
+ for (var h = Pe.BLKSIZE - 1; 0 <= h; --h) {
+ var u = s[n + 0][h],
+ m = s[n + 1][h];
+ s[n + 0][h] = (u + m) * ee.SQRT2 * .5, s[n + 1][h] = (u - m) * ee.SQRT2 * .5;
+ }
+ for (var p = 2; 0 <= p; --p) for (h = Pe.BLKSIZE_s - 1; 0 <= h; --h) {
+ u = r[i + 0][p][h], m = r[i + 1][p][h];
+ r[i + 0][p][h] = (u + m) * ee.SQRT2 * .5, r[i + 1][p][h] = (u - m) * ee.SQRT2 * .5;
}
}
- for (var m = 0, u = 11; u < Ae.HBLKSIZE; u++) m += t[u];
- c.tot_ener[_] = m, e.analysis && me(), 2 == e.athaa_loudapprox && _ < 2 && (c.loudness_sq[o][_] = c.loudness_sq_save[_], c.loudness_sq_save[_] = function (e, t) {
- for (var a = 0, n = 0; n < Ae.BLKSIZE / 2; ++n) a += e[n] * t.ATH.eql_w[n];
- return a *= v;
- }(t, c));
+ t[0] = M(s[n + 0][0]), t[0] *= t[0];
+ for (h = Pe.BLKSIZE / 2 - 1; 0 <= h; --h) {
+ var b = s[n + 0][Pe.BLKSIZE / 2 - h],
+ v = s[n + 0][Pe.BLKSIZE / 2 + h];
+ t[Pe.BLKSIZE / 2 - h] = M(.5 * (b * b + v * v));
+ }
+ for (p = 2; 0 <= p; --p) {
+ a[p][0] = r[i + 0][p][0], a[p][0] *= a[p][0];
+ for (h = Pe.BLKSIZE_s / 2 - 1; 0 <= h; --h) {
+ b = r[i + 0][p][Pe.BLKSIZE_s / 2 - h], v = r[i + 0][p][Pe.BLKSIZE_s / 2 + h];
+ a[p][Pe.BLKSIZE_s / 2 - h] = M(.5 * (b * b + v * v));
+ }
+ }
+ var d = 0;
+ for (h = 11; h < Pe.HBLKSIZE; h++) d += t[h];
+ if (c.tot_ener[_] = d, e.analysis) {
+ for (h = 0; h < Pe.HBLKSIZE; h++) c.pinfo.energy[o][_][h] = c.pinfo.energy_save[_][h], c.pinfo.energy_save[_][h] = t[h];
+ c.pinfo.pe[o][_] = c.pe[_];
+ }
+ 2 == e.athaa_loudapprox && _ < 2 && (c.loudness_sq[o][_] = c.loudness_sq_save[_], c.loudness_sq_save[_] = N(t, c));
}
- var x,
- B,
+ var y,
T,
- C = 8,
- I = 23,
- L = 15,
- re = [1, .79433, .63096, .63096, .63096, .63096, .63096, .25119, .11749],
- f = [3.3246 * 3.3246, 3.23837 * 3.23837, 9.9500500969, 9.0247369744, 8.1854926609, 7.0440875649, 2.46209 * 2.46209, 2.284 * 2.284, 4.4892710641, 1.96552 * 1.96552, 1.82335 * 1.82335, 1.69146 * 1.69146, 2.4621061921, 2.1508568964, 1.37074 * 1.37074, 1.31036 * 1.31036, 1.5691069696, 1.4555939904, 1.16203 * 1.16203, 1.2715945225, 1.09428 * 1.09428, 1.0659 * 1.0659, 1.0779838276, 1.0382591025, 1],
+ x,
+ P = 8,
+ L = 23,
+ I = 15,
+ ue = [1, .79433, .63096, .63096, .63096, .63096, .63096, .25119, .11749];
+ var f = [3.3246 * 3.3246, 3.23837 * 3.23837, 9.9500500969, 9.0247369744, 8.1854926609, 7.0440875649, 2.46209 * 2.46209, 2.284 * 2.284, 4.4892710641, 1.96552 * 1.96552, 1.82335 * 1.82335, 1.69146 * 1.69146, 2.4621061921, 2.1508568964, 1.37074 * 1.37074, 1.31036 * 1.31036, 1.5691069696, 1.4555939904, 1.16203 * 1.16203, 1.2715945225, 1.09428 * 1.09428, 1.0659 * 1.0659, 1.0779838276, 1.0382591025, 1],
c = [1.7782755904, 1.35879 * 1.35879, 1.38454 * 1.38454, 1.39497 * 1.39497, 1.40548 * 1.40548, 1.3537 * 1.3537, 1.6999465924, 1.22321 * 1.22321, 1.3169398564, 1],
- u = [5.5396212496, 2.29259 * 2.29259, 4.9868695969, 2.12675 * 2.12675, 2.02545 * 2.02545, 1.87894 * 1.87894, 1.74303 * 1.74303, 1.61695 * 1.61695, 2.2499700001, 1.39148 * 1.39148, 1.29083 * 1.29083, 1.19746 * 1.19746, 1.2339655056, 1.0779838276];
- function ie(e, t, a, n, s, r) {
+ h = [5.5396212496, 2.29259 * 2.29259, 4.9868695969, 2.12675 * 2.12675, 2.02545 * 2.02545, 1.87894 * 1.87894, 1.74303 * 1.74303, 1.61695 * 1.61695, 2.2499700001, 1.39148 * 1.39148, 1.29083 * 1.29083, 1.19746 * 1.19746, 1.2339655056, 1.0779838276];
+ function me(e, t, a, s, n, r) {
var i;
if (e < t) {
- if (!(t < e * B)) return e + t;
+ if (!(t < e * T)) return e + t;
i = t / e;
} else {
- if (t * B <= e) return e + t;
+ if (t * T <= e) return e + t;
i = e / t;
}
- if (e += t, n + 3 <= 6) {
- if (x <= i) return e;
- var o = 0 | V.FAST_LOG10_X(i, 16);
+ if (e += t, s + 3 <= 6) {
+ if (y <= i) return e;
+ var o = 0 | ee.FAST_LOG10_X(i, 16);
return e * c[o];
}
- var _,
- l,
- o = 0 | V.FAST_LOG10_X(i, 16);
- return t = 0 != r ? s.ATH.cb_s[a] * s.ATH.adjust : s.ATH.cb_l[a] * s.ATH.adjust, e < T * t ? t < e ? (_ = 1, o <= 13 && (_ = u[o]), l = V.FAST_LOG10_X(e / t, 10 / 15), e * ((f[o] - _) * l + _)) : 13 < o ? e : e * u[o] : e * f[o];
+ var _, l;
+ o = 0 | ee.FAST_LOG10_X(i, 16);
+ return t = 0 != r ? n.ATH.cb_s[a] * n.ATH.adjust : n.ATH.cb_l[a] * n.ATH.adjust, e < x * t ? t < e ? (_ = 1, o <= 13 && (_ = h[o]), l = ee.FAST_LOG10_X(e / t, 10 / 15), e * ((f[o] - _) * l + _)) : 13 < o ? e : e * h[o] : e * f[o];
}
- function oe(e, t, a, n, s) {
+ var r = [1.7782755904, 1.35879 * 1.35879, 1.38454 * 1.38454, 1.39497 * 1.39497, 1.40548 * 1.40548, 1.3537 * 1.3537, 1.6999465924, 1.22321 * 1.22321, 1.3169398564, 1];
+ function A(e, t, a) {
+ var s;
+ if (e < 0 && (e = 0), t < 0 && (t = 0), e <= 0) return t;
+ if (t <= 0) return e;
+ if (s = e < t ? t / e : e / t, -2 <= a && a <= 2) {
+ if (y <= s) return e + t;
+ var n = 0 | ee.FAST_LOG10_X(s, 16);
+ return (e + t) * r[n];
+ }
+ return s < T ? e + t : (e < t && (e = t), e);
+ }
+ function pe(e, t, a, s, n) {
var r,
i,
o = 0,
_ = 0;
- for (r = i = 0; r < Ae.SBMAX_s; ++i, ++r) {
+ for (r = i = 0; r < Pe.SBMAX_s; ++i, ++r) {
for (var l = e.bo_s[r], f = e.npart_s, c = l < f ? l : f; i < c;) o += t[i], _ += a[i], i++;
- if (e.en[n].s[r][s] = o, e.thm[n].s[r][s] = _, f <= i) {
+ if (e.en[s].s[r][n] = o, e.thm[s].s[r][n] = _, f <= i) {
++r;
break;
}
- var u = e.PSY.bo_s_weight[r],
- h = 1 - u;
- o = u * t[i], _ = u * a[i], e.en[n].s[r][s] += o, e.thm[n].s[r][s] += _, o = h * t[i], _ = h * a[i];
+ var h = e.PSY.bo_s_weight[r],
+ u = 1 - h;
+ o = h * t[i], _ = h * a[i], e.en[s].s[r][n] += o, e.thm[s].s[r][n] += _, o = u * t[i], _ = u * a[i];
}
- for (; r < Ae.SBMAX_s; ++r) e.en[n].s[r][s] = 0, e.thm[n].s[r][s] = 0;
+ for (; r < Pe.SBMAX_s; ++r) e.en[s].s[r][n] = 0, e.thm[s].s[r][n] = 0;
}
- function _e(e, t, a, n) {
- var s,
+ function be(e, t, a, s) {
+ var n,
r,
i = 0,
o = 0;
- for (s = r = 0; s < Ae.SBMAX_l; ++r, ++s) {
- for (var _ = e.bo_l[s], l = e.npart_l, f = _ < l ? _ : l; r < f;) i += t[r], o += a[r], r++;
- if (e.en[n].l[s] = i, e.thm[n].l[s] = o, l <= r) {
- ++s;
+ for (n = r = 0; n < Pe.SBMAX_l; ++r, ++n) {
+ for (var _ = e.bo_l[n], l = e.npart_l, f = _ < l ? _ : l; r < f;) i += t[r], o += a[r], r++;
+ if (e.en[s].l[n] = i, e.thm[s].l[n] = o, l <= r) {
+ ++n;
break;
}
- var c = e.PSY.bo_l_weight[s],
- u = 1 - c;
- i = c * t[r], o = c * a[r], e.en[n].l[s] += i, e.thm[n].l[s] += o, i = u * t[r], o = u * a[r];
+ var c = e.PSY.bo_l_weight[n],
+ h = 1 - c;
+ i = c * t[r], o = c * a[r], e.en[s].l[n] += i, e.thm[s].l[n] += o, i = h * t[r], o = h * a[r];
}
- for (; s < Ae.SBMAX_l; ++s) e.en[n].l[s] = 0, e.thm[n].l[s] = 0;
+ for (; n < Pe.SBMAX_l; ++n) e.en[s].l[n] = 0, e.thm[s].l[n] = 0;
}
- function le(e, t, a, n, s, r) {
+ function ve(e, t, a, s, n, r) {
var i,
o,
_ = e.internal_flags;
for (o = i = 0; o < _.npart_s; ++o) {
- for (var l = 0, f = 0, c = _.numlines_s[o], u = 0; u < c; ++u, ++i) {
- var h = t[r][i];
- l += h, f < h && (f = h);
+ for (var l = 0, f = 0, c = _.numlines_s[o], h = 0; h < c; ++h, ++i) {
+ var u = t[r][i];
+ l += u, f < u && (f = u);
}
a[o] = l;
}
for (i = o = 0; o < _.npart_s; o++) {
- var b = _.s3ind_s[o][0],
- p = _.s3_ss[i++] * a[b];
- for (++b; b <= _.s3ind_s[o][1];) p += _.s3_ss[i] * a[b], ++i, ++b;
- var m = d * _.nb_s1[s][o];
- if (n[o] = Math.min(p, m), _.blocktype_old[1 & s] == Ae.SHORT_TYPE) {
- var m = g * _.nb_s2[s][o],
- v = n[o];
- n[o] = Math.min(m, v);
+ var m = _.s3ind_s[o][0],
+ p = _.s3_ss[i++] * a[m];
+ for (++m; m <= _.s3ind_s[o][1];) p += _.s3_ss[i] * a[m], ++i, ++m;
+ var b = d * _.nb_s1[n][o];
+ if (s[o] = Math.min(p, b), _.blocktype_old[1 & n] == Pe.SHORT_TYPE) {
+ b = g * _.nb_s2[n][o];
+ var v = s[o];
+ s[o] = Math.min(b, v);
}
- _.nb_s2[s][o] = _.nb_s1[s][o], _.nb_s1[s][o] = p;
+ _.nb_s2[n][o] = _.nb_s1[n][o], _.nb_s1[n][o] = p;
}
- for (; o <= Ae.CBANDS; ++o) a[o] = 0, n[o] = 0;
+ for (; o <= Pe.CBANDS; ++o) a[o] = 0, s[o] = 0;
}
- function fe(e, t, a) {
+ function de(e, t, a) {
return 1 <= a ? e : a <= 0 ? t : 0 < t ? Math.pow(e / t, a) * t : 0;
}
var _ = [11.8, 13.6, 17.2, 32, 46.5, 51.3, 57.5, 67.1, 71.5, 84.6, 97.6, 130];
- function ce(e, t) {
- for (var a = 309.07, n = 0; n < Ae.SBMAX_s - 1; n++) for (var s = 0; s < 3; s++) {
- var r = e.thm.s[n][s];
+ function ge(e, t) {
+ for (var a = 309.07, s = 0; s < Pe.SBMAX_s - 1; s++) for (var n = 0; n < 3; n++) {
+ var r = e.thm.s[s][n];
if (0 < r) {
var i = r * t,
- o = e.en.s[n][s];
- i < o && (a += 1e10 * i < o ? _[n] * (10 * R) : _[n] * V.FAST_LOG10(o / i));
+ o = e.en.s[s][n];
+ i < o && (a += 1e10 * i < o ? _[s] * (10 * k) : _[s] * ee.FAST_LOG10(o / i));
}
}
return a;
}
var o = [6.8, 5.8, 5.8, 6.4, 6.5, 9.9, 12.1, 14.4, 15, 18.9, 21.6, 26.9, 34.2, 40.2, 46.8, 56.5, 60.7, 73.9, 85.7, 93.4, 126.1];
- function ue(e, t) {
- for (var a = 281.0575, n = 0; n < Ae.SBMAX_l - 1; n++) {
- var s = e.thm.l[n];
- if (0 < s) {
- var r = s * t,
- i = e.en.l[n];
- r < i && (a += 1e10 * r < i ? o[n] * (10 * R) : o[n] * V.FAST_LOG10(i / r));
+ function Se(e, t) {
+ for (var a = 281.0575, s = 0; s < Pe.SBMAX_l - 1; s++) {
+ var n = e.thm.l[s];
+ if (0 < n) {
+ var r = n * t,
+ i = e.en.l[s];
+ r < i && (a += 1e10 * r < i ? o[s] * (10 * k) : o[s] * ee.FAST_LOG10(i / r));
}
}
return a;
}
- function he(e, t, a, n, s) {
+ function Me(e, t, a, s, n) {
var r, i;
for (r = i = 0; r < e.npart_l; ++r) {
var o,
@@ -14765,495 +14668,894 @@ src: recorder-core.js,engine/mp3.js,engine/mp3-engine.js
var f = t[i];
_ += f, l < f && (l = f);
}
- a[r] = _, n[r] = l, s[r] = _ * e.rnumlines_l[r];
+ a[r] = _, s[r] = l, n[r] = _ * e.rnumlines_l[r];
}
}
- function be(e, t, a, n) {
- var s = re.length - 1,
+ function we(e, t, a, s) {
+ var n = ue.length - 1,
r = 0,
i = a[r] + a[r + 1];
- if (0 < i) {
- var o = t[r];
- o < t[r + 1] && (o = t[r + 1]);
- var _ = 0 | (i = 20 * (2 * o - i) / (i * (e.numlines_l[r] + e.numlines_l[r + 1] - 1)));
- s < _ && (_ = s), n[r] = _;
- } else n[r] = 0;
- for (r = 1; r < e.npart_l - 1; r++) if (0 < (i = a[r - 1] + a[r] + a[r + 1])) {
- var o = t[r - 1];
- o < t[r] && (o = t[r]), o < t[r + 1] && (o = t[r + 1]);
- var _ = 0 | (i = 20 * (3 * o - i) / (i * (e.numlines_l[r - 1] + e.numlines_l[r] + e.numlines_l[r + 1] - 1)));
- s < _ && (_ = s), n[r] = _;
- } else n[r] = 0;
- if (0 < (i = a[r - 1] + a[r])) {
- var o = t[r - 1];
- o < t[r] && (o = t[r]);
- var _ = 0 | (i = 20 * (2 * o - i) / (i * (e.numlines_l[r - 1] + e.numlines_l[r] - 1)));
- s < _ && (_ = s), n[r] = _;
- } else n[r] = 0;
+ 0 < i ? ((o = t[r]) < t[r + 1] && (o = t[r + 1]), n < (_ = 0 | (i = 20 * (2 * o - i) / (i * (e.numlines_l[r] + e.numlines_l[r + 1] - 1)))) && (_ = n), s[r] = _) : s[r] = 0;
+ for (r = 1; r < e.npart_l - 1; r++) {
+ var o, _;
+ if (0 < (i = a[r - 1] + a[r] + a[r + 1])) (o = t[r - 1]) < t[r] && (o = t[r]), o < t[r + 1] && (o = t[r + 1]), n < (_ = 0 | (i = 20 * (3 * o - i) / (i * (e.numlines_l[r - 1] + e.numlines_l[r] + e.numlines_l[r + 1] - 1)))) && (_ = n), s[r] = _;else s[r] = 0;
+ }
+ 0 < (i = a[r - 1] + a[r]) ? ((o = t[r - 1]) < t[r] && (o = t[r]), n < (_ = 0 | (i = 20 * (2 * o - i) / (i * (e.numlines_l[r - 1] + e.numlines_l[r] - 1)))) && (_ = n), s[r] = _) : s[r] = 0;
}
- var pe = [-1.730326e-17, -.01703172, -1.349528e-17, .0418072, -6.73278e-17, -.0876324, -3.0835e-17, .1863476, -1.104424e-16, -.627638];
- function P(e) {
+ var Re = [-1.730326e-17, -.01703172, -1.349528e-17, .0418072, -6.73278e-17, -.0876324, -3.0835e-17, .1863476, -1.104424e-16, -.627638];
+ function D(e, t, a, s, n, r, i, o) {
+ var _ = e.internal_flags;
+ if (s < 2) B.fft_long(_, i[o], s, t, a);else if (2 == s) for (var l = Pe.BLKSIZE - 1; 0 <= l; --l) {
+ var f = i[o + 0][l],
+ c = i[o + 1][l];
+ i[o + 0][l] = (f + c) * ee.SQRT2 * .5, i[o + 1][l] = (f - c) * ee.SQRT2 * .5;
+ }
+ r[0] = M(i[o + 0][0]), r[0] *= r[0];
+ for (l = Pe.BLKSIZE / 2 - 1; 0 <= l; --l) {
+ var h = i[o + 0][Pe.BLKSIZE / 2 - l],
+ u = i[o + 0][Pe.BLKSIZE / 2 + l];
+ r[Pe.BLKSIZE / 2 - l] = M(.5 * (h * h + u * u));
+ }
+ var m = 0;
+ for (l = 11; l < Pe.HBLKSIZE; l++) m += r[l];
+ if (_.tot_ener[s] = m, e.analysis) {
+ for (l = 0; l < Pe.HBLKSIZE; l++) _.pinfo.energy[n][s][l] = _.pinfo.energy_save[s][l], _.pinfo.energy_save[s][l] = r[l];
+ _.pinfo.pe[n][s] = _.pe[s];
+ }
+ }
+ function Y(e, t, a, s, n, r, i, o) {
+ var _ = e.internal_flags;
+ if (0 == n && s < 2 && B.fft_short(_, i[o], s, t, a), 2 == s) for (var l = Pe.BLKSIZE_s - 1; 0 <= l; --l) {
+ var f = i[o + 0][n][l],
+ c = i[o + 1][n][l];
+ i[o + 0][n][l] = (f + c) * ee.SQRT2 * .5, i[o + 1][n][l] = (f - c) * ee.SQRT2 * .5;
+ }
+ r[n][0] = i[o + 0][n][0], r[n][0] *= r[n][0];
+ for (l = Pe.BLKSIZE_s / 2 - 1; 0 <= l; --l) {
+ var h = i[o + 0][n][Pe.BLKSIZE_s / 2 - l],
+ u = i[o + 0][n][Pe.BLKSIZE_s / 2 + l];
+ r[n][Pe.BLKSIZE_s / 2 - l] = M(.5 * (h * h + u * u));
+ }
+ }
+ this.L3psycho_anal_ns = function (e, t, a, s, n, r, i, o, _, l) {
+ var f,
+ c,
+ h,
+ u,
+ m,
+ p,
+ b,
+ v,
+ d,
+ g,
+ S = e.internal_flags,
+ M = ke([2, Pe.BLKSIZE]),
+ w = ke([2, 3, Pe.BLKSIZE_s]),
+ R = Be(Pe.CBANDS + 1),
+ A = Be(Pe.CBANDS + 1),
+ B = Be(Pe.CBANDS + 2),
+ k = Ae(2),
+ y = Ae(2),
+ T = ke([2, 576]),
+ x = Ae(Pe.CBANDS + 2),
+ E = Ae(Pe.CBANDS + 2);
+ for (ye.fill(E, 0), f = S.channels_out, e.mode == Ee.JOINT_STEREO && (f = 4), d = e.VBR == xe.vbr_off ? 0 == S.ResvMax ? 0 : S.ResvSize / S.ResvMax * .5 : e.VBR == xe.vbr_rh || e.VBR == xe.vbr_mtrh || e.VBR == xe.vbr_mt ? .6 : 1, c = 0; c < S.channels_out; c++) {
+ var P = t[c],
+ L = a + 576 - 350 - ce + 192;
+ for (u = 0; u < 576; u++) {
+ var I, H;
+ for (I = P[L + u + 10], m = H = 0; m < (ce - 1) / 2 - 1; m += 2) I += Re[m] * (P[L + u + m] + P[L + u + ce - m]), H += Re[m + 1] * (P[L + u + m + 1] + P[L + u + ce - m - 1]);
+ T[c][u] = I + H;
+ }
+ n[s][c].en.assign(S.en[c]), n[s][c].thm.assign(S.thm[c]), 2 < f && (r[s][c].en.assign(S.en[c + 2]), r[s][c].thm.assign(S.thm[c + 2]));
+ }
+ for (c = 0; c < f; c++) {
+ var C,
+ V = Be(12),
+ O = [0, 0, 0, 0],
+ N = Be(12),
+ D = 1,
+ Y = Be(Pe.CBANDS),
+ X = Be(Pe.CBANDS),
+ q = [0, 0, 0, 0],
+ F = Be(Pe.HBLKSIZE),
+ j = ke([3, Pe.HBLKSIZE_s]);
+ for (u = 0; u < 3; u++) V[u] = S.nsPsy.last_en_subshort[c][u + 6], N[u] = V[u] / S.nsPsy.last_en_subshort[c][u + 4], O[0] += V[u];
+ if (2 == c) for (u = 0; u < 576; u++) {
+ var z, Z;
+ z = T[0][u], Z = T[1][u], T[0][u] = z + Z, T[1][u] = z - Z;
+ }
+ var K = T[1 & c],
+ G = 0;
+ for (u = 0; u < 9; u++) {
+ for (var U = G + 64, Q = 1; G < U; G++) Q < Math.abs(K[G]) && (Q = Math.abs(K[G]));
+ S.nsPsy.last_en_subshort[c][u] = V[u + 3] = Q, O[1 + u / 3] += Q, Q > V[u + 3 - 2] ? Q /= V[u + 3 - 2] : Q = V[u + 3 - 2] > 10 * Q ? V[u + 3 - 2] / (10 * Q) : 0, N[u + 3] = Q;
+ }
+ if (e.analysis) {
+ var W = N[0];
+ for (u = 1; u < 12; u++) W < N[u] && (W = N[u]);
+ S.pinfo.ers[s][c] = S.pinfo.ers_save[c], S.pinfo.ers_save[c] = W;
+ }
+ for (C = 3 == c ? S.nsPsy.attackthre_s : S.nsPsy.attackthre, u = 0; u < 12; u++) 0 == q[u / 3] && N[u] > C && (q[u / 3] = u % 3 + 1);
+ for (u = 1; u < 4; u++) {
+ (O[u - 1] > O[u] ? O[u - 1] / O[u] : O[u] / O[u - 1]) < 1.7 && (q[u] = 0, 1 == u && (q[0] = 0));
+ }
+ for (0 != q[0] && 0 != S.nsPsy.lastAttacks[c] && (q[0] = 0), 3 != S.nsPsy.lastAttacks[c] && q[0] + q[1] + q[2] + q[3] == 0 || ((D = 0) != q[1] && 0 != q[0] && (q[1] = 0), 0 != q[2] && 0 != q[1] && (q[2] = 0), 0 != q[3] && 0 != q[2] && (q[3] = 0)), c < 2 ? y[c] = D : 0 == D && (y[0] = y[1] = 0), _[c] = S.tot_ener[c], he(e, F, j, M, 1 & c, w, 1 & c, s, c, t, a), Me(S, F, R, Y, X), we(S, Y, X, x), v = 0; v < 3; v++) {
+ var J, $;
+ for (ve(e, j, A, B, c, v), pe(S, A, B, c, v), b = 0; b < Pe.SBMAX_s; b++) {
+ if ($ = S.thm[c].s[b][v], $ *= .8, 2 <= q[v] || 1 == q[v + 1]) {
+ var ee = 0 != v ? v - 1 : 2;
+ Q = de(S.thm[c].s[b][ee], $, .6 * d);
+ $ = Math.min($, Q);
+ }
+ if (1 == q[v]) {
+ ee = 0 != v ? v - 1 : 2, Q = de(S.thm[c].s[b][ee], $, fe * d);
+ $ = Math.min($, Q);
+ } else if (0 != v && 3 == q[v - 1] || 0 == v && 3 == S.nsPsy.lastAttacks[c]) {
+ ee = 2 != v ? v + 1 : 0, Q = de(S.thm[c].s[b][ee], $, fe * d);
+ $ = Math.min($, Q);
+ }
+ J = V[3 * v + 3] + V[3 * v + 4] + V[3 * v + 5], 6 * V[3 * v + 5] < J && ($ *= .5, 6 * V[3 * v + 4] < J && ($ *= .5)), S.thm[c].s[b][v] = $;
+ }
+ }
+ for (S.nsPsy.lastAttacks[c] = q[2], h = p = 0; h < S.npart_l; h++) {
+ for (var te = S.s3ind[h][0], ae = R[te] * ue[x[te]], se = S.s3_ll[p++] * ae; ++te <= S.s3ind[h][1];) ae = R[te] * ue[x[te]], se = me(se, S.s3_ll[p++] * ae, te, te - h, S, 0);
+ se *= .158489319246111, S.blocktype_old[1 & c] == Pe.SHORT_TYPE ? B[h] = se : B[h] = de(Math.min(se, Math.min(_e * S.nb_1[c][h], le * S.nb_2[c][h])), se, d), S.nb_2[c][h] = S.nb_1[c][h], S.nb_1[c][h] = se;
+ }
+ for (; h <= Pe.CBANDS; ++h) R[h] = 0, B[h] = 0;
+ be(S, R, B, c);
+ }
+ (e.mode != Ee.STEREO && e.mode != Ee.JOINT_STEREO || 0 < e.interChRatio && function (e, t) {
+ var a = e.internal_flags;
+ if (1 < a.channels_out) {
+ for (var s = 0; s < Pe.SBMAX_l; s++) {
+ var n = a.thm[0].l[s],
+ r = a.thm[1].l[s];
+ a.thm[0].l[s] += r * t, a.thm[1].l[s] += n * t;
+ }
+ for (s = 0; s < Pe.SBMAX_s; s++) for (var i = 0; i < 3; i++) n = a.thm[0].s[s][i], r = a.thm[1].s[s][i], a.thm[0].s[s][i] += r * t, a.thm[1].s[s][i] += n * t;
+ }
+ }(e, e.interChRatio), e.mode == Ee.JOINT_STEREO) && (!function (e) {
+ for (var t = 0; t < Pe.SBMAX_l; t++) if (!(e.thm[0].l[t] > 1.58 * e.thm[1].l[t] || e.thm[1].l[t] > 1.58 * e.thm[0].l[t])) {
+ var a = e.mld_l[t] * e.en[3].l[t],
+ s = Math.max(e.thm[2].l[t], Math.min(e.thm[3].l[t], a));
+ a = e.mld_l[t] * e.en[2].l[t];
+ var n = Math.max(e.thm[3].l[t], Math.min(e.thm[2].l[t], a));
+ e.thm[2].l[t] = s, e.thm[3].l[t] = n;
+ }
+ for (t = 0; t < Pe.SBMAX_s; t++) for (var r = 0; r < 3; r++) e.thm[0].s[t][r] > 1.58 * e.thm[1].s[t][r] || e.thm[1].s[t][r] > 1.58 * e.thm[0].s[t][r] || (a = e.mld_s[t] * e.en[3].s[t][r], s = Math.max(e.thm[2].s[t][r], Math.min(e.thm[3].s[t][r], a)), a = e.mld_s[t] * e.en[2].s[t][r], n = Math.max(e.thm[3].s[t][r], Math.min(e.thm[2].s[t][r], a)), e.thm[2].s[t][r] = s, e.thm[3].s[t][r] = n);
+ }(S), g = e.msfix, 0 < Math.abs(g) && function (e, t, a) {
+ var s = t,
+ n = Math.pow(10, a);
+ t *= 2, s *= 2;
+ for (var r = 0; r < Pe.SBMAX_l; r++) f = e.ATH.cb_l[e.bm_l[r]] * n, (o = Math.min(Math.max(e.thm[0].l[r], f), Math.max(e.thm[1].l[r], f))) * t < (_ = Math.max(e.thm[2].l[r], f)) + (l = Math.max(e.thm[3].l[r], f)) && (_ *= c = o * s / (_ + l), l *= c), e.thm[2].l[r] = Math.min(_, e.thm[2].l[r]), e.thm[3].l[r] = Math.min(l, e.thm[3].l[r]);
+ for (n *= Pe.BLKSIZE_s / Pe.BLKSIZE, r = 0; r < Pe.SBMAX_s; r++) for (var i = 0; i < 3; i++) {
+ var o, _, l, f, c;
+ f = e.ATH.cb_s[e.bm_s[r]] * n, (o = Math.min(Math.max(e.thm[0].s[r][i], f), Math.max(e.thm[1].s[r][i], f))) * t < (_ = Math.max(e.thm[2].s[r][i], f)) + (l = Math.max(e.thm[3].s[r][i], f)) && (_ *= c = o * t / (_ + l), l *= c), e.thm[2].s[r][i] = Math.min(e.thm[2].s[r][i], _), e.thm[3].s[r][i] = Math.min(e.thm[3].s[r][i], l);
+ }
+ }(S, g, e.ATHlower * S.ATH.adjust));
+ for (function (e, t, a, s) {
+ var n = e.internal_flags;
+ e.short_blocks != Te.short_block_coupled || 0 != t[0] && 0 != t[1] || (t[0] = t[1] = 0);
+ for (var r = 0; r < n.channels_out; r++) s[r] = Pe.NORM_TYPE, e.short_blocks == Te.short_block_dispensed && (t[r] = 1), e.short_blocks == Te.short_block_forced && (t[r] = 0), 0 != t[r] ? n.blocktype_old[r] == Pe.SHORT_TYPE && (s[r] = Pe.STOP_TYPE) : (s[r] = Pe.SHORT_TYPE, n.blocktype_old[r] == Pe.NORM_TYPE && (n.blocktype_old[r] = Pe.START_TYPE), n.blocktype_old[r] == Pe.STOP_TYPE && (n.blocktype_old[r] = Pe.SHORT_TYPE)), a[r] = n.blocktype_old[r], n.blocktype_old[r] = s[r];
+ }(e, y, l, k), c = 0; c < f; c++) {
+ var ne,
+ re,
+ ie,
+ oe = 0;
+ 1 < c ? (ne = o, oe = -2, re = Pe.NORM_TYPE, l[0] != Pe.SHORT_TYPE && l[1] != Pe.SHORT_TYPE || (re = Pe.SHORT_TYPE), ie = r[s][c - 2]) : (ne = i, oe = 0, re = l[c], ie = n[s][c]), ne[oe + c] = re == Pe.SHORT_TYPE ? ge(ie, S.masking_lower) : Se(ie, S.masking_lower), e.analysis && (S.pinfo.pe[s][c] = ne[oe + c]);
+ }
+ return 0;
+ };
+ var X = [-1.730326e-17, -.01703172, -1.349528e-17, .0418072, -6.73278e-17, -.0876324, -3.0835e-17, .1863476, -1.104424e-16, -.627638];
+ function q(e, t, a) {
+ if (0 == a) for (var s = 0; s < e.npart_s; s++) e.nb_s2[t][s] = e.nb_s1[t][s], e.nb_s1[t][s] = 0;
+ }
+ function F(e, t) {
+ for (var a = 0; a < e.npart_l; a++) e.nb_2[t][a] = e.nb_1[t][a], e.nb_1[t][a] = 0;
+ }
+ function j(e, t, a, s, n, r) {
+ var i,
+ o,
+ _,
+ l = e.internal_flags,
+ f = new float[Pe.CBANDS](),
+ c = Be(Pe.CBANDS),
+ h = new int[Pe.CBANDS]();
+ for (_ = o = 0; _ < l.npart_s; ++_) {
+ var u = 0,
+ m = 0,
+ p = l.numlines_s[_];
+ for (i = 0; i < p; ++i, ++o) {
+ var b = t[r][o];
+ u += b, m < b && (m = b);
+ }
+ a[_] = u, f[_] = m, c[_] = u / p;
+ }
+ for (; _ < Pe.CBANDS; ++_) f[_] = 0, c[_] = 0;
+ for (function (e, t, a, s) {
+ var n = ue.length - 1,
+ r = 0,
+ i = a[r] + a[r + 1];
+ for (0 < i ? ((o = t[r]) < t[r + 1] && (o = t[r + 1]), n < (_ = 0 | (i = 20 * (2 * o - i) / (i * (e.numlines_s[r] + e.numlines_s[r + 1] - 1)))) && (_ = n), s[r] = _) : s[r] = 0, r = 1; r < e.npart_s - 1; r++) {
+ var o, _;
+ 0 < (i = a[r - 1] + a[r] + a[r + 1]) ? ((o = t[r - 1]) < t[r] && (o = t[r]), o < t[r + 1] && (o = t[r + 1]), n < (_ = 0 | (i = 20 * (3 * o - i) / (i * (e.numlines_s[r - 1] + e.numlines_s[r] + e.numlines_s[r + 1] - 1)))) && (_ = n), s[r] = _) : s[r] = 0;
+ }
+ 0 < (i = a[r - 1] + a[r]) ? ((o = t[r - 1]) < t[r] && (o = t[r]), n < (_ = 0 | (i = 20 * (2 * o - i) / (i * (e.numlines_s[r - 1] + e.numlines_s[r] - 1)))) && (_ = n), s[r] = _) : s[r] = 0;
+ }(l, f, c, h), o = _ = 0; _ < l.npart_s; _++) {
+ var v,
+ d,
+ g,
+ S,
+ M,
+ w = l.s3ind_s[_][0],
+ R = l.s3ind_s[_][1];
+ for (v = h[w], d = 1, S = l.s3_ss[o] * a[w] * ue[h[w]], ++o, ++w; w <= R;) v += h[w], d += 1, S = A(S, g = l.s3_ss[o] * a[w] * ue[h[w]], w - _), ++o, ++w;
+ S *= M = .5 * ue[v = (1 + 2 * v) / (2 * d)], s[_] = S, l.nb_s2[n][_] = l.nb_s1[n][_], l.nb_s1[n][_] = S, g = f[_], g *= l.minval_s[_], g *= M, s[_] > g && (s[_] = g), 1 < l.masking_lower && (s[_] *= l.masking_lower), s[_] > a[_] && (s[_] = a[_]), l.masking_lower < 1 && (s[_] *= l.masking_lower);
+ }
+ for (; _ < Pe.CBANDS; ++_) a[_] = 0, s[_] = 0;
+ }
+ function z(e, t, a, s, n) {
+ var r,
+ i = Be(Pe.CBANDS),
+ o = Be(Pe.CBANDS),
+ _ = Ae(Pe.CBANDS + 2);
+ Me(e, t, a, i, o), we(e, i, o, _);
+ var l = 0;
+ for (r = 0; r < e.npart_l; r++) {
+ var f,
+ c,
+ h,
+ u = e.s3ind[r][0],
+ m = e.s3ind[r][1],
+ p = 0,
+ b = 0;
+ for (p = _[u], b += 1, c = e.s3_ll[l] * a[u] * ue[_[u]], ++l, ++u; u <= m;) p += _[u], b += 1, c = A(c, f = e.s3_ll[l] * a[u] * ue[_[u]], u - r), ++l, ++u;
+ if (c *= h = .5 * ue[p = (1 + 2 * p) / (2 * b)], e.blocktype_old[1 & n] == Pe.SHORT_TYPE) {
+ var v = _e * e.nb_1[n][r];
+ s[r] = 0 < v ? Math.min(c, v) : Math.min(c, a[r] * fe);
+ } else {
+ var d = le * e.nb_2[n][r],
+ g = _e * e.nb_1[n][r];
+ d <= 0 && (d = c), g <= 0 && (g = c), v = e.blocktype_old[1 & n] == Pe.NORM_TYPE ? Math.min(g, d) : g, s[r] = Math.min(c, v);
+ }
+ e.nb_2[n][r] = e.nb_1[n][r], e.nb_1[n][r] = c, f = i[r], f *= e.minval_l[r], f *= h, s[r] > f && (s[r] = f), 1 < e.masking_lower && (s[r] *= e.masking_lower), s[r] > a[r] && (s[r] = a[r]), e.masking_lower < 1 && (s[r] *= e.masking_lower);
+ }
+ for (; r < Pe.CBANDS; ++r) a[r] = 0, s[r] = 0;
+ }
+ function Z(e, t, a, s, n, r, i) {
+ for (var o, _, l = 2 * r, f = 0 < r ? Math.pow(10, n) : 1, c = 0; c < i; ++c) {
+ var h = e[2][c],
+ u = e[3][c],
+ m = t[0][c],
+ p = t[1][c],
+ b = t[2][c],
+ v = t[3][c];
+ if (m <= 1.58 * p && p <= 1.58 * m) {
+ var d = a[c] * u,
+ g = a[c] * h;
+ _ = Math.max(b, Math.min(v, d)), o = Math.max(v, Math.min(b, g));
+ } else _ = b, o = v;
+ if (0 < r) {
+ var S,
+ M,
+ w = s[c] * f;
+ if (S = Math.min(Math.max(m, w), Math.max(p, w)), 0 < (M = (b = Math.max(_, w)) + (v = Math.max(o, w))) && S * l < M) {
+ var R = S * l / M;
+ b *= R, v *= R;
+ }
+ _ = Math.min(b, _), o = Math.min(v, o);
+ }
+ h < _ && (_ = h), u < o && (o = u), t[2][c] = _, t[3][c] = o;
+ }
+ }
+ function w(e, t) {
+ var a;
+ return (a = 0 <= e ? 27 * -e : e * t) <= -72 ? 0 : Math.exp(a * S);
+ }
+ function R(e) {
+ var t,
+ a,
+ s = 0;
+ for (s = 0; 1e-20 < w(s, e); s -= 1);
+ for (n = s, r = 0; 1e-12 < Math.abs(r - n);) 0 < w(s = (r + n) / 2, e) ? r = s : n = s;
+ t = n;
+ var n, r;
+ s = 0;
+ for (s = 0; 1e-20 < w(s, e); s += 1);
+ for (n = 0, r = s; 1e-12 < Math.abs(r - n);) 0 < w(s = (r + n) / 2, e) ? n = s : r = s;
+ a = r;
+ var i,
+ o = 0;
+ for (i = 0; i <= 1e3; ++i) {
+ o += w(s = t + i * (a - t) / 1e3, e);
+ }
+ return 1001 / (o * (a - t));
+ }
+ function H(e) {
return e < 0 && (e = 0), e *= .001, 13 * Math.atan(.76 * e) + 3.5 * Math.atan(e * e / 56.25);
}
- function H(e, t, a, n, s, r, i, o, _, l, f, c) {
- var u,
- h = de(Ae.CBANDS + 1),
- b = o / (15 < c ? 1152 : 384),
- p = ve(Ae.HBLKSIZE);
+ function C(e, t, a, s, n, r, i, o, _, l, f, c) {
+ var h,
+ u = Be(Pe.CBANDS + 1),
+ m = o / (15 < c ? 1152 : 384),
+ p = Ae(Pe.HBLKSIZE);
o /= _;
- var m = 0,
+ var b = 0,
v = 0;
- for (u = 0; u < Ae.CBANDS; u++) {
+ for (h = 0; h < Pe.CBANDS; h++) {
var d;
- for (x = P(o * m), h[u] = o * m, d = m; P(o * d) - x < E && d <= _ / 2; d++);
- for (e[u] = d - m, v = u + 1; m < d;) p[m++] = u;
- if (_ / 2 < m) {
- m = _ / 2, ++u;
+ for (y = H(o * b), u[h] = o * b, d = b; H(o * d) - y < E && d <= _ / 2; d++);
+ for (e[h] = d - b, v = h + 1; b < d;) p[b++] = h;
+ if (_ / 2 < b) {
+ b = _ / 2, ++h;
break;
}
}
- h[u] = o * m;
+ u[h] = o * b;
for (var g = 0; g < c; g++) {
- var w, S, M, y, A;
- M = l[g], y = l[g + 1], (w = 0 | Math.floor(.5 + f * (M - .5))) < 0 && (w = 0), S = 0 | Math.floor(.5 + f * (y - .5)), _ / 2 < S && (S = _ / 2), a[g] = (p[w] + p[S]) / 2, t[g] = p[S];
- var k = b * y;
- i[g] = (k - h[t[g]]) / (h[t[g] + 1] - h[t[g]]), i[g] < 0 ? i[g] = 0 : 1 < i[g] && (i[g] = 1), A = P(o * l[g] * f), A = Math.min(A, 15.5) / 15.5, r[g] = Math.pow(10, 1.25 * (1 - Math.cos(Math.PI * A)) - 2.5);
+ var S, M, w, R, A;
+ w = l[g], R = l[g + 1], (S = 0 | Math.floor(.5 + f * (w - .5))) < 0 && (S = 0), _ / 2 < (M = 0 | Math.floor(.5 + f * (R - .5))) && (M = _ / 2), a[g] = (p[S] + p[M]) / 2, t[g] = p[M];
+ var B = m * R;
+ i[g] = (B - u[t[g]]) / (u[t[g] + 1] - u[t[g]]), i[g] < 0 ? i[g] = 0 : 1 < i[g] && (i[g] = 1), A = H(o * l[g] * f), A = Math.min(A, 15.5) / 15.5, r[g] = Math.pow(10, 1.25 * (1 - Math.cos(Math.PI * A)) - 2.5);
}
- for (var R = m = 0; R < v; R++) {
- var x,
- B,
- T = e[R];
- x = P(o * m), B = P(o * (m + T - 1)), n[R] = .5 * (x + B), x = P(o * (m - .5)), B = P(o * (m + T - .5)), s[R] = B - x, m += T;
+ for (var k = b = 0; k < v; k++) {
+ var y,
+ T,
+ x = e[k];
+ y = H(o * b), T = H(o * (b + x - 1)), s[k] = .5 * (y + T), y = H(o * (b - .5)), T = H(o * (b + x - .5)), n[k] = T - y, b += x;
}
return v;
}
- function O(e, t, a, n, s, r) {
+ function V(e, t, a, s, n, r) {
var i,
o,
_,
l,
f,
c,
- u = ge([Ae.CBANDS, Ae.CBANDS]),
- h = 0;
- if (r) for (var b = 0; b < t; b++) for (i = 0; i < t; i++) {
- var p = (o = a[b] - a[i], c = f = l = _ = void 0, _ = o, l = .5 <= (_ *= 0 <= _ ? 3 : 1.5) && _ <= 2.5 ? 8 * ((c = _ - .5) * c - 2 * c) : 0, ((f = 15.811389 + 7.5 * (_ += .474) - 17.5 * Math.sqrt(1 + _ * _)) <= -60 ? 0 : (_ = Math.exp((l + f) * w), _ /= .6609193)) * n[i]);
- u[b][i] = p * s[b];
- } else me();
- for (var b = 0; b < t; b++) {
- for (i = 0; i < t && !(0 < u[b][i]); i++);
- for (e[b][0] = i, i = t - 1; 0 < i && !(0 < u[b][i]); i--);
- e[b][1] = i, h += e[b][1] - e[b][0] + 1;
+ h = ke([Pe.CBANDS, Pe.CBANDS]),
+ u = 0;
+ if (r) for (var m = 0; m < t; m++) for (i = 0; i < t; i++) {
+ var p = (o = a[m] - a[i], c = f = l = _ = void 0, _ = o, l = .5 <= (_ *= 0 <= _ ? 3 : 1.5) && _ <= 2.5 ? 8 * ((c = _ - .5) * c - 2 * c) : 0, ((f = 15.811389 + 7.5 * (_ += .474) - 17.5 * Math.sqrt(1 + _ * _)) <= -60 ? 0 : (_ = Math.exp((l + f) * S), _ /= .6609193)) * s[i]);
+ h[m][i] = p * n[m];
+ } else for (i = 0; i < t; i++) {
+ var b = 15 + Math.min(21 / a[i], 12),
+ v = R(b);
+ for (m = 0; m < t; m++) {
+ p = v * w(a[m] - a[i], b) * s[i];
+ h[m][i] = p * n[m];
+ }
}
- for (var m = de(h), v = 0, b = 0; b < t; b++) for (i = e[b][0]; i <= e[b][1]; i++) m[v++] = u[b][i];
- return m;
+ for (m = 0; m < t; m++) {
+ for (i = 0; i < t && !(0 < h[m][i]); i++);
+ for (e[m][0] = i, i = t - 1; 0 < i && !(0 < h[m][i]); i--);
+ e[m][1] = i, u += e[m][1] - e[m][0] + 1;
+ }
+ var d = Be(u),
+ g = 0;
+ for (m = 0; m < t; m++) for (i = e[m][0]; i <= e[m][1]; i++) d[g++] = h[m][i];
+ return d;
}
- function N(e) {
- var t = P(e);
+ function O(e) {
+ var t = H(e);
return t = Math.min(t, 15.5) / 15.5, Math.pow(10, 1.25 * (1 - Math.cos(Math.PI * t)) - 2.5);
}
- function n(e, t) {
- e < -.3 && (e = 3410), e /= 1e3, e = Math.max(.1, e);
- var a = 3.64 * Math.pow(e, -.8) - 6.8 * Math.exp(-.6 * Math.pow(e - 3.4, 2)) + 6 * Math.exp(-.15 * Math.pow(e - 8.7, 2)) + .001 * (.6 + .04 * t) * Math.pow(e, 4);
- return a;
+ function s(e, t) {
+ return e < -.3 && (e = 3410), e /= 1e3, e = Math.max(.1, e), 3.64 * Math.pow(e, -.8) - 6.8 * Math.exp(-.6 * Math.pow(e - 3.4, 2)) + 6 * Math.exp(-.15 * Math.pow(e - 8.7, 2)) + .001 * (.6 + .04 * t) * Math.pow(e, 4);
}
- this.L3psycho_anal_ns = function (e, t, a, n, s, r, i, o, _, l) {
+ this.L3psycho_anal_vbr = function (e, t, a, s, n, r, i, o, _, l) {
var f,
c,
- u,
h,
- b,
- p,
+ u,
m,
- v,
- d,
- g = e.internal_flags,
- w = ge([2, Ae.BLKSIZE]),
- S = ge([2, 3, Ae.BLKSIZE_s]),
- M = de(Ae.CBANDS + 1),
- y = de(Ae.CBANDS + 1),
- A = de(Ae.CBANDS + 2),
- k = ve(2),
- R = ve(2),
- x = ge([2, 576]),
- B = ve(Ae.CBANDS + 2),
- T = ve(Ae.CBANDS + 2);
- for (we.fill(T, 0), f = g.channels_out, e.mode == ye.JOINT_STEREO && (f = 4), d = e.VBR == Me.vbr_off ? 0 == g.ResvMax ? 0 : g.ResvSize / g.ResvMax * .5 : e.VBR == Me.vbr_rh || e.VBR == Me.vbr_mtrh || e.VBR == Me.vbr_mt ? .6 : 1, c = 0; c < g.channels_out; c++) {
- var E = t[c],
- C = a + 576 - 350 - 21 + 192;
- for (h = 0; h < 576; h++) {
- var I, L;
- for (I = E[C + h + 10], b = L = 0; b < 9; b += 2) I += pe[b] * (E[C + h + b] + E[C + h + 21 - b]), L += pe[b + 1] * (E[C + h + b + 1] + E[C + h + 21 - b - 1]);
- x[c][h] = I + L;
- }
- s[n][c].en.assign(g.en[c]), s[n][c].thm.assign(g.thm[c]), 2 < f && me();
- }
- for (c = 0; c < f; c++) {
- var P,
- H = de(12),
- O = [0, 0, 0, 0],
- N = de(12),
- V = 1,
- D = de(Ae.CBANDS),
- F = de(Ae.CBANDS),
- j = [0, 0, 0, 0],
- X = de(Ae.HBLKSIZE),
- Y = ge([3, Ae.HBLKSIZE_s]);
- for (h = 0; h < 3; h++) H[h] = g.nsPsy.last_en_subshort[c][h + 6], N[h] = H[h] / g.nsPsy.last_en_subshort[c][h + 4], O[0] += H[h];
- 2 == c && me();
- var z = x[1 & c],
- q = 0;
- for (h = 0; h < 9; h++) {
- for (var G = q + 64, U = 1; q < G; q++) U < Math.abs(z[q]) && (U = Math.abs(z[q]));
- g.nsPsy.last_en_subshort[c][h] = H[h + 3] = U, O[1 + h / 3] += U, U > H[h + 3 - 2] ? U /= H[h + 3 - 2] : U = H[h + 3 - 2] > 10 * U ? H[h + 3 - 2] / (10 * U) : 0, N[h + 3] = U;
- }
- for (e.analysis && me(), P = 3 == c ? g.nsPsy.attackthre_s : g.nsPsy.attackthre, h = 0; h < 12; h++) 0 == j[h / 3] && N[h] > P && (j[h / 3] = h % 3 + 1);
- for (h = 1; h < 4; h++) (O[h - 1] > O[h] ? O[h - 1] / O[h] : O[h] / O[h - 1]) < 1.7 && (j[h] = 0, 1 == h && (j[0] = 0));
- for (0 != j[0] && 0 != g.nsPsy.lastAttacks[c] && (j[0] = 0), 3 != g.nsPsy.lastAttacks[c] && j[0] + j[1] + j[2] + j[3] == 0 || ((V = 0) != j[1] && 0 != j[0] && (j[1] = 0), 0 != j[2] && 0 != j[1] && (j[2] = 0), 0 != j[3] && 0 != j[2] && (j[3] = 0)), c < 2 ? R[c] = V : me(), _[c] = g.tot_ener[c], se(e, X, Y, w, 1 & c, S, 1 & c, n, c, t, a), he(g, X, M, D, F), be(g, D, F, B), v = 0; v < 3; v++) {
- var K, Z;
- for (le(e, Y, y, A, c, v), oe(g, y, A, c, v), m = 0; m < Ae.SBMAX_s; m++) {
- if (Z = g.thm[c].s[m][v], Z *= .8, 2 <= j[v] || 1 == j[v + 1]) {
- var W = 0 != v ? v - 1 : 2,
- U = fe(g.thm[c].s[m][W], Z, .6 * d);
- Z = Math.min(Z, U);
- }
- if (1 == j[v]) {
- var W = 0 != v ? v - 1 : 2,
- U = fe(g.thm[c].s[m][W], Z, .3 * d);
- Z = Math.min(Z, U);
- } else if (0 != v && 3 == j[v - 1] || 0 == v && 3 == g.nsPsy.lastAttacks[c]) {
- var W = 2 != v ? v + 1 : 0,
- U = fe(g.thm[c].s[m][W], Z, .3 * d);
- Z = Math.min(Z, U);
- }
- K = H[3 * v + 3] + H[3 * v + 4] + H[3 * v + 5], 6 * H[3 * v + 5] < K && (Z *= .5, 6 * H[3 * v + 4] < K && (Z *= .5)), g.thm[c].s[m][v] = Z;
+ p = e.internal_flags,
+ b = Be(Pe.HBLKSIZE),
+ v = ke([3, Pe.HBLKSIZE_s]),
+ d = ke([2, Pe.BLKSIZE]),
+ g = ke([2, 3, Pe.BLKSIZE_s]),
+ S = ke([4, Pe.CBANDS]),
+ M = ke([4, Pe.CBANDS]),
+ w = ke([4, 3]),
+ R = [[0, 0, 0, 0], [0, 0, 0, 0], [0, 0, 0, 0], [0, 0, 0, 0]],
+ A = Ae(2),
+ B = e.mode == Ee.JOINT_STEREO ? 4 : p.channels_out;
+ !function (e, t, a, s, n, r, i, o, _, l) {
+ for (var f = ke([2, 576]), c = e.internal_flags, h = c.channels_out, u = e.mode == Ee.JOINT_STEREO ? 4 : h, m = 0; m < h; m++) {
+ firbuf = t[m];
+ for (var p = a + 576 - 350 - ce + 192, b = 0; b < 576; b++) {
+ var v, d;
+ v = firbuf[p + b + 10];
+ for (var g = d = 0; g < (ce - 1) / 2 - 1; g += 2) v += X[g] * (firbuf[p + b + g] + firbuf[p + b + ce - g]), d += X[g + 1] * (firbuf[p + b + g + 1] + firbuf[p + b + ce - g - 1]);
+ f[m][b] = v + d;
}
+ n[s][m].en.assign(c.en[m]), n[s][m].thm.assign(c.thm[m]), 2 < u && (r[s][m].en.assign(c.en[m + 2]), r[s][m].thm.assign(c.thm[m + 2]));
}
- for (g.nsPsy.lastAttacks[c] = j[2], u = p = 0; u < g.npart_l; u++) {
- for (var Q = g.s3ind[u][0], $ = M[Q] * re[B[Q]], J = g.s3_ll[p++] * $; ++Q <= g.s3ind[u][1];) $ = M[Q] * re[B[Q]], J = ie(J, g.s3_ll[p++] * $, Q, Q - u, g, 0);
- J *= .158489319246111, g.blocktype_old[1 & c] == Ae.SHORT_TYPE ? A[u] = J : A[u] = fe(Math.min(J, Math.min(2 * g.nb_1[c][u], 16 * g.nb_2[c][u])), J, d), g.nb_2[c][u] = g.nb_1[c][u], g.nb_1[c][u] = J;
+ for (m = 0; m < u; m++) {
+ var S = Be(12),
+ M = Be(12),
+ w = [0, 0, 0, 0],
+ R = f[1 & m],
+ A = 0,
+ B = 3 == m ? c.nsPsy.attackthre_s : c.nsPsy.attackthre,
+ k = 1;
+ if (2 == m) for (b = 0, g = 576; 0 < g; ++b, --g) {
+ var y = f[0][b],
+ T = f[1][b];
+ f[0][b] = y + T, f[1][b] = y - T;
+ }
+ for (b = 0; b < 3; b++) M[b] = c.nsPsy.last_en_subshort[m][b + 6], S[b] = M[b] / c.nsPsy.last_en_subshort[m][b + 4], w[0] += M[b];
+ for (b = 0; b < 9; b++) {
+ for (var x = A + 64, E = 1; A < x; A++) E < Math.abs(R[A]) && (E = Math.abs(R[A]));
+ c.nsPsy.last_en_subshort[m][b] = M[b + 3] = E, w[1 + b / 3] += E, E > M[b + 3 - 2] ? E /= M[b + 3 - 2] : E = M[b + 3 - 2] > 10 * E ? M[b + 3 - 2] / (10 * E) : 0, S[b + 3] = E;
+ }
+ for (b = 0; b < 3; ++b) {
+ var P = M[3 * b + 3] + M[3 * b + 4] + M[3 * b + 5],
+ L = 1;
+ 6 * M[3 * b + 5] < P && (L *= .5, 6 * M[3 * b + 4] < P && (L *= .5)), o[m][b] = L;
+ }
+ if (e.analysis) {
+ var I = S[0];
+ for (b = 1; b < 12; b++) I < S[b] && (I = S[b]);
+ c.pinfo.ers[s][m] = c.pinfo.ers_save[m], c.pinfo.ers_save[m] = I;
+ }
+ for (b = 0; b < 12; b++) 0 == _[m][b / 3] && S[b] > B && (_[m][b / 3] = b % 3 + 1);
+ for (b = 1; b < 4; b++) {
+ var H = w[b - 1],
+ C = w[b];
+ Math.max(H, C) < 4e4 && H < 1.7 * C && C < 1.7 * H && (1 == b && _[m][0] <= _[m][b] && (_[m][0] = 0), _[m][b] = 0);
+ }
+ _[m][0] <= c.nsPsy.lastAttacks[m] && (_[m][0] = 0), 3 != c.nsPsy.lastAttacks[m] && _[m][0] + _[m][1] + _[m][2] + _[m][3] == 0 || ((k = 0) != _[m][1] && 0 != _[m][0] && (_[m][1] = 0), 0 != _[m][2] && 0 != _[m][1] && (_[m][2] = 0), 0 != _[m][3] && 0 != _[m][2] && (_[m][3] = 0)), m < 2 ? l[m] = k : 0 == k && (l[0] = l[1] = 0), i[m] = c.tot_ener[m];
}
- for (; u <= Ae.CBANDS; ++u) M[u] = 0, A[u] = 0;
- _e(g, M, A, c);
+ }(e, t, a, s, n, r, _, w, R, A), function (e, t) {
+ var a = e.internal_flags;
+ e.short_blocks != Te.short_block_coupled || 0 != t[0] && 0 != t[1] || (t[0] = t[1] = 0);
+ for (var s = 0; s < a.channels_out; s++) e.short_blocks == Te.short_block_dispensed && (t[s] = 1), e.short_blocks == Te.short_block_forced && (t[s] = 0);
+ }(e, A);
+ for (var k = 0; k < B; k++) {
+ D(e, t, a, k, s, b, d, T = 1 & k), c = s, h = k, u = b, m = void 0, m = (f = e).internal_flags, 2 == f.athaa_loudapprox && h < 2 && (m.loudness_sq[c][h] = m.loudness_sq_save[h], m.loudness_sq_save[h] = N(u, m)), 0 != A[T] ? z(p, b, S[k], M[k], k) : F(p, k);
}
- for (e.mode != ye.STEREO && e.mode != ye.JOINT_STEREO || me(), e.mode == ye.JOINT_STEREO && me(), function (e, t, a, n) {
- var s = e.internal_flags;
- e.short_blocks != Se.short_block_coupled || 0 != t[0] && 0 != t[1] || (t[0] = t[1] = 0);
- for (var r = 0; r < s.channels_out; r++) n[r] = Ae.NORM_TYPE, e.short_blocks == Se.short_block_dispensed && (t[r] = 1), e.short_blocks == Se.short_block_forced && (t[r] = 0), 0 != t[r] ? s.blocktype_old[r] == Ae.SHORT_TYPE && (n[r] = Ae.STOP_TYPE) : (n[r] = Ae.SHORT_TYPE, s.blocktype_old[r] == Ae.NORM_TYPE && (s.blocktype_old[r] = Ae.START_TYPE), s.blocktype_old[r] == Ae.STOP_TYPE && (s.blocktype_old[r] = Ae.SHORT_TYPE)), a[r] = s.blocktype_old[r], s.blocktype_old[r] = n[r];
- }(e, R, l, k), c = 0; c < f; c++) {
- var ee,
- te,
- ae,
- ne = 0;
- 1 < c ? me() : (ee = i, ne = 0, te = l[c], ae = s[n][c]), ee[ne + c] = te == Ae.SHORT_TYPE ? ce(ae, g.masking_lower) : ue(ae, g.masking_lower), e.analysis && (g.pinfo.pe[n][c] = ee[ne + c]);
+ A[0] + A[1] == 2 && e.mode == Ee.JOINT_STEREO && Z(S, M, p.mld_cb_l, p.ATH.cb_l, e.ATHlower * p.ATH.adjust, e.msfix, p.npart_l);
+ for (k = 0; k < B; k++) {
+ 0 != A[T = 1 & k] && be(p, S[k], M[k], k);
+ }
+ for (var y = 0; y < 3; y++) {
+ for (k = 0; k < B; ++k) {
+ 0 != A[T = 1 & k] ? q(p, k, y) : (Y(e, t, a, k, y, v, g, T), j(e, v, S[k], M[k], k, y));
+ }
+ A[0] + A[1] == 0 && e.mode == Ee.JOINT_STEREO && Z(S, M, p.mld_cb_s, p.ATH.cb_s, e.ATHlower * p.ATH.adjust, e.msfix, p.npart_s);
+ for (k = 0; k < B; ++k) {
+ 0 == A[T = 1 & k] && pe(p, S[k], M[k], k, y);
+ }
+ }
+ for (k = 0; k < B; k++) {
+ var T;
+ if (0 == A[T = 1 & k]) for (var x = 0; x < Pe.SBMAX_s; x++) {
+ var E = Be(3);
+ for (y = 0; y < 3; y++) {
+ var P = p.thm[k].s[x][y];
+ if (P *= .8, 2 <= R[k][y] || 1 == R[k][y + 1]) {
+ var L = 0 != y ? y - 1 : 2,
+ I = de(p.thm[k].s[x][L], P, .36);
+ P = Math.min(P, I);
+ } else if (1 == R[k][y]) {
+ L = 0 != y ? y - 1 : 2, I = de(p.thm[k].s[x][L], P, .6 * fe);
+ P = Math.min(P, I);
+ } else if (0 != y && 3 == R[k][y - 1] || 0 == y && 3 == p.nsPsy.lastAttacks[k]) {
+ L = 2 != y ? y + 1 : 0, I = de(p.thm[k].s[x][L], P, .6 * fe);
+ P = Math.min(P, I);
+ }
+ P *= w[k][y], E[y] = P;
+ }
+ for (y = 0; y < 3; y++) p.thm[k].s[x][y] = E[y];
+ }
+ }
+ for (k = 0; k < B; k++) p.nsPsy.lastAttacks[k] = R[k][2];
+ !function (e, t, a) {
+ for (var s = e.internal_flags, n = 0; n < s.channels_out; n++) {
+ var r = Pe.NORM_TYPE;
+ 0 != t[n] ? s.blocktype_old[n] == Pe.SHORT_TYPE && (r = Pe.STOP_TYPE) : (r = Pe.SHORT_TYPE, s.blocktype_old[n] == Pe.NORM_TYPE && (s.blocktype_old[n] = Pe.START_TYPE), s.blocktype_old[n] == Pe.STOP_TYPE && (s.blocktype_old[n] = Pe.SHORT_TYPE)), a[n] = s.blocktype_old[n], s.blocktype_old[n] = r;
+ }
+ }(e, A, l);
+ for (k = 0; k < B; k++) {
+ var H, C, V, O;
+ 1 < k ? (H = o, C = -2, V = Pe.NORM_TYPE, l[0] != Pe.SHORT_TYPE && l[1] != Pe.SHORT_TYPE || (V = Pe.SHORT_TYPE), O = r[s][k - 2]) : (H = i, C = 0, V = l[k], O = n[s][k]), H[C + k] = V == Pe.SHORT_TYPE ? ge(O, p.masking_lower) : Se(O, p.masking_lower), e.analysis && (p.pinfo.pe[s][k] = H[C + k]);
}
return 0;
}, this.psymodel_init = function (e) {
var t,
a = e.internal_flags,
- n = !0,
- s = 13,
+ s = !0,
+ n = 13,
r = 0,
i = 0,
o = -8.25,
_ = -4.5,
- l = de(Ae.CBANDS),
- f = de(Ae.CBANDS),
- c = de(Ae.CBANDS),
- u = e.out_samplerate;
+ l = Be(Pe.CBANDS),
+ f = Be(Pe.CBANDS),
+ c = Be(Pe.CBANDS),
+ h = e.out_samplerate;
switch (e.experimentalZ) {
default:
case 0:
- n = !0;
+ s = !0;
break;
case 1:
- n = e.VBR != Me.vbr_mtrh && e.VBR != Me.vbr_mt;
+ s = e.VBR != xe.vbr_mtrh && e.VBR != xe.vbr_mt;
break;
case 2:
- n = !1;
+ s = !1;
break;
case 3:
- s = 8, r = -1.75, i = -.0125, o = -8.25, _ = -2.25;
+ n = 8, r = -1.75, i = -.0125, o = -8.25, _ = -2.25;
}
- for (a.ms_ener_ratio_old = .25, a.blocktype_old[0] = a.blocktype_old[1] = Ae.NORM_TYPE, t = 0; t < 4; ++t) {
- for (var h = 0; h < Ae.CBANDS; ++h) a.nb_1[t][h] = 1e20, a.nb_2[t][h] = 1e20, a.nb_s1[t][h] = a.nb_s2[t][h] = 1;
- for (var b = 0; b < Ae.SBMAX_l; b++) a.en[t].l[b] = 1e20, a.thm[t].l[b] = 1e20;
- for (var h = 0; h < 3; ++h) {
- for (var b = 0; b < Ae.SBMAX_s; b++) a.en[t].s[b][h] = 1e20, a.thm[t].s[b][h] = 1e20;
+ for (a.ms_ener_ratio_old = .25, a.blocktype_old[0] = a.blocktype_old[1] = Pe.NORM_TYPE, t = 0; t < 4; ++t) {
+ for (var u = 0; u < Pe.CBANDS; ++u) a.nb_1[t][u] = 1e20, a.nb_2[t][u] = 1e20, a.nb_s1[t][u] = a.nb_s2[t][u] = 1;
+ for (var m = 0; m < Pe.SBMAX_l; m++) a.en[t].l[m] = 1e20, a.thm[t].l[m] = 1e20;
+ for (u = 0; u < 3; ++u) {
+ for (m = 0; m < Pe.SBMAX_s; m++) a.en[t].s[m][u] = 1e20, a.thm[t].s[m][u] = 1e20;
a.nsPsy.lastAttacks[t] = 0;
}
- for (var h = 0; h < 9; h++) a.nsPsy.last_en_subshort[t][h] = 10;
+ for (u = 0; u < 9; u++) a.nsPsy.last_en_subshort[t][u] = 10;
}
- for (a.loudness_sq_save[0] = a.loudness_sq_save[1] = 0, a.npart_l = H(a.numlines_l, a.bo_l, a.bm_l, l, f, a.mld_l, a.PSY.bo_l_weight, u, Ae.BLKSIZE, a.scalefac_band.l, Ae.BLKSIZE / 1152, Ae.SBMAX_l), t = 0; t < a.npart_l; t++) {
+ for (a.loudness_sq_save[0] = a.loudness_sq_save[1] = 0, a.npart_l = C(a.numlines_l, a.bo_l, a.bm_l, l, f, a.mld_l, a.PSY.bo_l_weight, h, Pe.BLKSIZE, a.scalefac_band.l, Pe.BLKSIZE / 1152, Pe.SBMAX_l), t = 0; t < a.npart_l; t++) {
var p = r;
- l[t] >= s && (p = i * (l[t] - s) / (24 - s) + r * (24 - l[t]) / (24 - s)), c[t] = Math.pow(10, p / 10), 0 < a.numlines_l[t] ? a.rnumlines_l[t] = 1 / a.numlines_l[t] : a.rnumlines_l[t] = 0;
+ l[t] >= n && (p = i * (l[t] - n) / (24 - n) + r * (24 - l[t]) / (24 - n)), c[t] = Math.pow(10, p / 10), 0 < a.numlines_l[t] ? a.rnumlines_l[t] = 1 / a.numlines_l[t] : a.rnumlines_l[t] = 0;
}
- a.s3_ll = O(a.s3ind, a.npart_l, l, f, c, n);
- var m,
- h = 0;
+ a.s3_ll = V(a.s3ind, a.npart_l, l, f, c, s);
+ var b;
+ u = 0;
for (t = 0; t < a.npart_l; t++) {
- g = D.MAX_VALUE;
- for (var v = 0; v < a.numlines_l[t]; v++, h++) {
- var d = u * h / (1e3 * Ae.BLKSIZE);
- w = this.ATHformula(1e3 * d, e) - 20, w = Math.pow(10, .1 * w), (w *= a.numlines_l[t]) < g && (g = w);
+ g = K.MAX_VALUE;
+ for (var v = 0; v < a.numlines_l[t]; v++, u++) {
+ var d = h * u / (1e3 * Pe.BLKSIZE);
+ S = this.ATHformula(1e3 * d, e) - 20, S = Math.pow(10, .1 * S), (S *= a.numlines_l[t]) < g && (g = S);
}
a.ATH.cb_l[t] = g, 6 < (g = 20 * l[t] / 10 - 20) && (g = 100), g < -15 && (g = -15), g -= 8, a.minval_l[t] = Math.pow(10, g / 10) * a.numlines_l[t];
}
- for (a.npart_s = H(a.numlines_s, a.bo_s, a.bm_s, l, f, a.mld_s, a.PSY.bo_s_weight, u, Ae.BLKSIZE_s, a.scalefac_band.s, Ae.BLKSIZE_s / 384, Ae.SBMAX_s), t = h = 0; t < a.npart_s; t++) {
- var g,
- p = o;
- l[t] >= s && (p = _ * (l[t] - s) / (24 - s) + o * (24 - l[t]) / (24 - s)), c[t] = Math.pow(10, p / 10), g = D.MAX_VALUE;
- for (var v = 0; v < a.numlines_s[t]; v++, h++) {
- var w,
- d = u * h / (1e3 * Ae.BLKSIZE_s);
- w = this.ATHformula(1e3 * d, e) - 20, w = Math.pow(10, .1 * w), (w *= a.numlines_s[t]) < g && (g = w);
+ for (a.npart_s = C(a.numlines_s, a.bo_s, a.bm_s, l, f, a.mld_s, a.PSY.bo_s_weight, h, Pe.BLKSIZE_s, a.scalefac_band.s, Pe.BLKSIZE_s / 384, Pe.SBMAX_s), t = u = 0; t < a.npart_s; t++) {
+ var g;
+ p = o;
+ l[t] >= n && (p = _ * (l[t] - n) / (24 - n) + o * (24 - l[t]) / (24 - n)), c[t] = Math.pow(10, p / 10), g = K.MAX_VALUE;
+ for (v = 0; v < a.numlines_s[t]; v++, u++) {
+ var S;
+ d = h * u / (1e3 * Pe.BLKSIZE_s);
+ S = this.ATHformula(1e3 * d, e) - 20, S = Math.pow(10, .1 * S), (S *= a.numlines_s[t]) < g && (g = S);
}
a.ATH.cb_s[t] = g, g = 7 * l[t] / 12 - 7, 12 < l[t] && (g *= 1 + 3.1 * Math.log(1 + g)), l[t] < 12 && (g *= 1 + 2.3 * Math.log(1 - g)), g < -15 && (g = -15), g -= 8, a.minval_s[t] = Math.pow(10, g / 10) * a.numlines_s[t];
}
- a.s3_ss = O(a.s3ind_s, a.npart_s, l, f, c, n), x = Math.pow(10, (C + 1) / 16), B = Math.pow(10, (I + 1) / 16), T = Math.pow(10, L / 10), k.init_fft(a), a.decay = Math.exp(-1 * R / (.01 * u / 192)), m = 3.5, 0 != (2 & e.exp_nspsytune) && (m = 1), 0 < Math.abs(e.msfix) && (m = e.msfix), e.msfix = m;
- for (var S = 0; S < a.npart_l; S++) a.s3ind[S][1] > a.npart_l - 1 && (a.s3ind[S][1] = a.npart_l - 1);
- var M = 576 * a.mode_gr / u;
- if (a.ATH.decay = Math.pow(10, -1.2 * M), a.ATH.adjust = .01, -(a.ATH.adjustLimit = 1) != e.ATHtype) {
- var y = e.out_samplerate / Ae.BLKSIZE,
+ a.s3_ss = V(a.s3ind_s, a.npart_s, l, f, c, s), y = Math.pow(10, (P + 1) / 16), T = Math.pow(10, (L + 1) / 16), x = Math.pow(10, I / 10), B.init_fft(a), a.decay = Math.exp(-1 * k / (.01 * h / 192)), b = 3.5, 0 != (2 & e.exp_nspsytune) && (b = 1), 0 < Math.abs(e.msfix) && (b = e.msfix), e.msfix = b;
+ for (var M = 0; M < a.npart_l; M++) a.s3ind[M][1] > a.npart_l - 1 && (a.s3ind[M][1] = a.npart_l - 1);
+ var w = 576 * a.mode_gr / h;
+ if (a.ATH.decay = Math.pow(10, -1.2 * w), a.ATH.adjust = .01, -(a.ATH.adjustLimit = 1) != e.ATHtype) {
+ var R = e.out_samplerate / Pe.BLKSIZE,
A = 0;
- for (t = d = 0; t < Ae.BLKSIZE / 2; ++t) d += y, a.ATH.eql_w[t] = 1 / Math.pow(10, this.ATHformula(d, e) / 10), A += a.ATH.eql_w[t];
- for (A = 1 / A, t = Ae.BLKSIZE / 2; 0 <= --t;) a.ATH.eql_w[t] *= A;
+ for (t = d = 0; t < Pe.BLKSIZE / 2; ++t) d += R, a.ATH.eql_w[t] = 1 / Math.pow(10, this.ATHformula(d, e) / 10), A += a.ATH.eql_w[t];
+ for (A = 1 / A, t = Pe.BLKSIZE / 2; 0 <= --t;) a.ATH.eql_w[t] *= A;
}
- for (var S = h = 0; S < a.npart_s; ++S) for (t = 0; t < a.numlines_s[S]; ++t) ++h;
- for (var S = h = 0; S < a.npart_l; ++S) for (t = 0; t < a.numlines_l[S]; ++t) ++h;
- for (t = h = 0; t < a.npart_l; t++) {
- var d = u * (h + a.numlines_l[t] / 2) / (1 * Ae.BLKSIZE);
- a.mld_cb_l[t] = N(d), h += a.numlines_l[t];
+ for (M = u = 0; M < a.npart_s; ++M) for (t = 0; t < a.numlines_s[M]; ++t) ++u;
+ for (M = u = 0; M < a.npart_l; ++M) for (t = 0; t < a.numlines_l[M]; ++t) ++u;
+ for (t = u = 0; t < a.npart_l; t++) {
+ d = h * (u + a.numlines_l[t] / 2) / (1 * Pe.BLKSIZE);
+ a.mld_cb_l[t] = O(d), u += a.numlines_l[t];
}
- for (; t < Ae.CBANDS; ++t) a.mld_cb_l[t] = 1;
- for (t = h = 0; t < a.npart_s; t++) {
- var d = u * (h + a.numlines_s[t] / 2) / (1 * Ae.BLKSIZE_s);
- a.mld_cb_s[t] = N(d), h += a.numlines_s[t];
+ for (; t < Pe.CBANDS; ++t) a.mld_cb_l[t] = 1;
+ for (t = u = 0; t < a.npart_s; t++) {
+ d = h * (u + a.numlines_s[t] / 2) / (1 * Pe.BLKSIZE_s);
+ a.mld_cb_s[t] = O(d), u += a.numlines_s[t];
}
- for (; t < Ae.CBANDS; ++t) a.mld_cb_s[t] = 1;
+ for (; t < Pe.CBANDS; ++t) a.mld_cb_s[t] = 1;
return 0;
}, this.ATHformula = function (e, t) {
var a;
switch (t.ATHtype) {
case 0:
- a = n(e, 9);
+ a = s(e, 9);
break;
case 1:
- a = n(e, -1);
+ a = s(e, -1);
break;
case 2:
- a = n(e, 0);
+ a = s(e, 0);
break;
case 3:
- a = n(e, 1) + 6;
+ a = s(e, 1) + 6;
break;
case 4:
- a = n(e, t.ATHcurve);
+ a = s(e, t.ATHcurve);
break;
default:
- a = n(e, 0);
+ a = s(e, 0);
}
return a;
};
}
- function Y() {
- var T,
- E,
- u,
- h,
- b,
- C = this;
- Y.V9 = 410, Y.V8 = 420, Y.V7 = 430, Y.V6 = 440, Y.V5 = 450, Y.V4 = 460, Y.V3 = 470, Y.V2 = 480, Y.V1 = 490, Y.V0 = 500, Y.R3MIX = 1e3, Y.STANDARD = 1001, Y.EXTREME = 1002, Y.INSANE = 1003, Y.STANDARD_FAST = 1004, Y.EXTREME_FAST = 1005, Y.MEDIUM = 1006, Y.MEDIUM_FAST = 1007, Y.LAME_MAXMP3BUFFER = 147456;
- var p,
- m,
- v = new X();
- function d() {
+ function U() {
+ var o = this;
+ U.V9 = 410, U.V8 = 420, U.V7 = 430, U.V6 = 440, U.V5 = 450, U.V4 = 460, U.V3 = 470, U.V2 = 480, U.V1 = 490, U.V0 = 500, U.R3MIX = 1e3, U.STANDARD = 1001, U.EXTREME = 1002, U.INSANE = 1003, U.STANDARD_FAST = 1004, U.EXTREME_FAST = 1005, U.MEDIUM = 1006, U.MEDIUM_FAST = 1007;
+ var w, R, g, S, M;
+ U.LAME_MAXMP3BUFFER = 147456;
+ var A,
+ B,
+ k,
+ y = new G();
+ function T() {
this.lowerlimit = 0;
}
- function s(e, t) {
+ function n(e, t) {
this.lowpass = t;
}
- this.enc = new Ae(), this.setModules = function (e, t, a, n, s, r, i, o, _) {
- T = e, E = t, u = a, h = n, b = s, p = r, m = o, this.enc.setModules(E, v, h, p);
+ this.enc = new Pe(), this.setModules = function (e, t, a, s, n, r, i, o, _) {
+ w = e, R = t, g = a, S = s, M = n, A = r, B = o, k = _, this.enc.setModules(R, y, S, A);
};
- var I = 4294479419;
- function g(e, t) {
- var a = [new s(8, 2e3), new s(16, 3700), new s(24, 3900), new s(32, 5500), new s(40, 7e3), new s(48, 7500), new s(56, 1e4), new s(64, 11e3), new s(80, 13500), new s(96, 15100), new s(112, 15600), new s(128, 17e3), new s(160, 17500), new s(192, 18600), new s(224, 19400), new s(256, 19700), new s(320, 20500)],
- n = C.nearestBitrateFullIndex(t);
- e.lowerlimit = a[n].lowpass;
+ var x = 4294479419;
+ function E(e) {
+ return 1 < e ? 0 : e <= 0 ? 1 : Math.cos(Math.PI / 2 * e);
}
- function L(e) {
- var t = Ae.BLKSIZE + e.framesize - Ae.FFTOFFSET;
+ function P(e, t) {
+ switch (e) {
+ case 44100:
+ return t.version = 1, 0;
+ case 48e3:
+ return t.version = 1;
+ case 32e3:
+ return t.version = 1, 2;
+ case 22050:
+ return t.version = 0;
+ case 24e3:
+ return t.version = 0, 1;
+ case 16e3:
+ return t.version = 0, 2;
+ case 11025:
+ return t.version = 0;
+ case 12e3:
+ return t.version = 0, 1;
+ case 8e3:
+ return t.version = 0, 2;
+ default:
+ return t.version = 0, -1;
+ }
+ }
+ function L(e, t, a) {
+ a < 16e3 && (t = 2);
+ for (var s = F.bitrate_table[t][1], n = 2; n <= 14; n++) 0 < F.bitrate_table[t][n] && Math.abs(F.bitrate_table[t][n] - e) < Math.abs(s - e) && (s = F.bitrate_table[t][n]);
+ return s;
+ }
+ function I(e, t, a) {
+ a < 16e3 && (t = 2);
+ for (var s = 0; s <= 14; s++) if (0 < F.bitrate_table[t][s] && F.bitrate_table[t][s] == e) return s;
+ return -1;
+ }
+ function H(e, t) {
+ var a = [new n(8, 2e3), new n(16, 3700), new n(24, 3900), new n(32, 5500), new n(40, 7e3), new n(48, 7500), new n(56, 1e4), new n(64, 11e3), new n(80, 13500), new n(96, 15100), new n(112, 15600), new n(128, 17e3), new n(160, 17500), new n(192, 18600), new n(224, 19400), new n(256, 19700), new n(320, 20500)],
+ s = o.nearestBitrateFullIndex(t);
+ e.lowerlimit = a[s].lowpass;
+ }
+ function C(e) {
+ var t = Pe.BLKSIZE + e.framesize - Pe.FFTOFFSET;
return t = Math.max(t, 512 + e.framesize - 32);
}
- function P() {
+ function V(e, t, a, s, n, r) {
+ var i = o.enc.lame_encode_mp3_frame(e, t, a, s, n, r);
+ return e.frameNum++, i;
+ }
+ function O() {
this.n_in = 0, this.n_out = 0;
}
- function H(e, t, a, n, s, r) {
+ function f() {
+ this.num_used = 0;
+ }
+ function N(e, t, a) {
+ var s = Math.PI * t;
+ (e /= a) < 0 && (e = 0), 1 < e && (e = 1);
+ var n = e - .5,
+ r = .42 - .5 * Math.cos(2 * e * Math.PI) + .08 * Math.cos(4 * e * Math.PI);
+ return Math.abs(n) < 1e-9 ? s / Math.PI : r * Math.sin(a * s * n) / (Math.PI * a * n);
+ }
+ function c(e, t, a, s, n, r, i, o, _) {
+ var l,
+ f,
+ c = e.internal_flags,
+ h = 0,
+ u = e.out_samplerate / function e(t, a) {
+ return 0 != a ? e(a, t % a) : t;
+ }(e.out_samplerate, e.in_samplerate);
+ Z.BPC < u && (u = Z.BPC);
+ var m = Math.abs(c.resample_ratio - Math.floor(.5 + c.resample_ratio)) < 1e-4 ? 1 : 0,
+ p = 1 / c.resample_ratio;
+ 1 < p && (p = 1);
+ var b = 31;
+ 0 == b % 2 && --b;
+ var v = (b += m) + 1;
+ if (0 == c.fill_buffer_resample_init) {
+ for (c.inbuf_old[0] = Be(v), c.inbuf_old[1] = Be(v), l = 0; l <= 2 * u; ++l) c.blackfilt[l] = Be(v);
+ for (c.itime[0] = 0, h = c.itime[1] = 0; h <= 2 * u; h++) {
+ var d = 0,
+ g = (h - u) / (2 * u);
+ for (l = 0; l <= b; l++) d += c.blackfilt[h][l] = N(l - g, p, b);
+ for (l = 0; l <= b; l++) c.blackfilt[h][l] /= d;
+ }
+ c.fill_buffer_resample_init = 1;
+ }
+ var S = c.inbuf_old[_];
+ for (f = 0; f < s; f++) {
+ var M, w;
+ if (M = f * c.resample_ratio, i <= b + (h = 0 | Math.floor(M - c.itime[_])) - b / 2) break;
+ g = M - c.itime[_] - (h + b % 2 * .5);
+ w = 0 | Math.floor(2 * g * u + u + .5);
+ var R = 0;
+ for (l = 0; l <= b; ++l) {
+ var A = l + h - b / 2;
+ R += (A < 0 ? S[v + A] : n[r + A]) * c.blackfilt[w][l];
+ }
+ t[a + f] = R;
+ }
+ if (o.num_used = Math.min(i, b + h - b / 2), c.itime[_] += o.num_used - f * c.resample_ratio, o.num_used >= v) for (l = 0; l < v; l++) S[l] = n[r + o.num_used + l - v];else {
+ var B = v - o.num_used;
+ for (l = 0; l < B; ++l) S[l] = S[l + o.num_used];
+ for (h = 0; l < v; ++l, ++h) S[l] = n[r + h];
+ }
+ return f;
+ }
+ function D(e, t, a, s, n, r) {
var i = e.internal_flags;
- if (i.resample_ratio < .9999 || 1.0001 < i.resample_ratio) me();else {
- r.n_out = Math.min(e.framesize, s), r.n_in = r.n_out;
- for (var o = 0; o < r.n_out; ++o) t[0][i.mf_size + o] = a[0][n + o], 2 == i.channels_out && (t[1][i.mf_size + o] = a[1][n + o]);
+ if (i.resample_ratio < .9999 || 1.0001 < i.resample_ratio) for (var o = 0; o < i.channels_out; o++) {
+ var _ = new f();
+ r.n_out = c(e, t[o], i.mf_size, e.framesize, a[o], s, n, _, o), r.n_in = _.num_used;
+ } else {
+ r.n_out = Math.min(e.framesize, n), r.n_in = r.n_out;
+ for (var l = 0; l < r.n_out; ++l) t[0][i.mf_size + l] = a[0][s + l], 2 == i.channels_out && (t[1][i.mf_size + l] = a[1][s + l]);
}
}
this.lame_init = function () {
var e,
t,
a = new function () {
- this.class_id = 0, this.num_samples = 0, this.num_channels = 0, this.in_samplerate = 0, this.out_samplerate = 0, this.scale = 0, this.scale_left = 0, this.scale_right = 0, this.analysis = !1, this.bWriteVbrTag = !1, this.decode_only = !1, this.quality = 0, this.mode = ye.STEREO, this.force_ms = !1, this.free_format = !1, this.findReplayGain = !1, this.decode_on_the_fly = !1, this.write_id3tag_automatic = !1, this.brate = 0, this.compression_ratio = 0, this.copyright = 0, this.original = 0, this.extension = 0, this.emphasis = 0, this.error_protection = 0, this.strict_ISO = !1, this.disable_reservoir = !1, this.quant_comp = 0, this.quant_comp_short = 0, this.experimentalY = !1, this.experimentalZ = 0, this.exp_nspsytune = 0, this.preset = 0, this.VBR = null, this.VBR_q_frac = 0, this.VBR_q = 0, this.VBR_mean_bitrate_kbps = 0, this.VBR_min_bitrate_kbps = 0, this.VBR_max_bitrate_kbps = 0, this.VBR_hard_min = 0, this.lowpassfreq = 0, this.highpassfreq = 0, this.lowpasswidth = 0, this.highpasswidth = 0, this.maskingadjust = 0, this.maskingadjust_short = 0, this.ATHonly = !1, this.ATHshort = !1, this.noATH = !1, this.ATHtype = 0, this.ATHcurve = 0, this.ATHlower = 0, this.athaa_type = 0, this.athaa_loudapprox = 0, this.athaa_sensitivity = 0, this.short_blocks = null, this.useTemporal = !1, this.interChRatio = 0, this.msfix = 0, this.tune = !1, this.tune_value_a = 0, this.version = 0, this.encoder_delay = 0, this.encoder_padding = 0, this.framesize = 0, this.frameNum = 0, this.lame_allocated_gfp = 0, this.internal_flags = null;
- }(),
- n = ((e = a).class_id = I, t = e.internal_flags = new j(), e.mode = ye.NOT_SET, e.original = 1, e.in_samplerate = 44100, e.num_channels = 2, e.num_samples = -1, e.bWriteVbrTag = !0, e.quality = -1, e.short_blocks = null, t.subblock_gain = -1, e.lowpassfreq = 0, e.highpassfreq = 0, e.lowpasswidth = -1, e.highpasswidth = -1, e.VBR = Me.vbr_off, e.VBR_q = 4, e.ATHcurve = -1, e.VBR_mean_bitrate_kbps = 128, e.VBR_min_bitrate_kbps = 0, e.VBR_max_bitrate_kbps = 0, e.VBR_hard_min = 0, t.VBR_min_bitrate = 1, t.VBR_max_bitrate = 13, e.quant_comp = -1, e.quant_comp_short = -1, e.msfix = -1, t.resample_ratio = 1, t.OldValue[0] = 180, t.OldValue[1] = 180, t.CurrentStep[0] = 4, t.CurrentStep[1] = 4, t.masking_lower = 1, t.nsPsy.attackthre = -1, t.nsPsy.attackthre_s = -1, e.scale = -1, e.athaa_type = -1, e.ATHtype = -1, e.athaa_loudapprox = -1, e.athaa_sensitivity = 0, e.useTemporal = null, e.interChRatio = -1, t.mf_samples_to_encode = Ae.ENCDELAY + Ae.POSTDELAY, e.encoder_padding = 0, t.mf_size = Ae.ENCDELAY - Ae.MDCTDELAY, e.findReplayGain = !1, e.decode_on_the_fly = !1, t.decode_on_the_fly = !1, t.findReplayGain = !1, t.findPeakSample = !1, t.RadioGain = 0, t.AudiophileGain = 0, t.noclipGainChange = 0, t.noclipScale = -1, e.preset = 0, e.write_id3tag_automatic = !0, 0);
- return 0 != n ? null : (a.lame_allocated_gfp = 1, a);
+ this.class_id = 0, this.num_samples = 0, this.num_channels = 0, this.in_samplerate = 0, this.out_samplerate = 0, this.scale = 0, this.scale_left = 0, this.scale_right = 0, this.analysis = !1, this.bWriteVbrTag = !1, this.decode_only = !1, this.quality = 0, this.mode = Ee.STEREO, this.force_ms = !1, this.free_format = !1, this.findReplayGain = !1, this.decode_on_the_fly = !1, this.write_id3tag_automatic = !1, this.brate = 0, this.compression_ratio = 0, this.copyright = 0, this.original = 0, this.extension = 0, this.emphasis = 0, this.error_protection = 0, this.strict_ISO = !1, this.disable_reservoir = !1, this.quant_comp = 0, this.quant_comp_short = 0, this.experimentalY = !1, this.experimentalZ = 0, this.exp_nspsytune = 0, this.preset = 0, this.VBR = null, this.VBR_q_frac = 0, this.VBR_q = 0, this.VBR_mean_bitrate_kbps = 0, this.VBR_min_bitrate_kbps = 0, this.VBR_max_bitrate_kbps = 0, this.VBR_hard_min = 0, this.lowpassfreq = 0, this.highpassfreq = 0, this.lowpasswidth = 0, this.highpasswidth = 0, this.maskingadjust = 0, this.maskingadjust_short = 0, this.ATHonly = !1, this.ATHshort = !1, this.noATH = !1, this.ATHtype = 0, this.ATHcurve = 0, this.ATHlower = 0, this.athaa_type = 0, this.athaa_loudapprox = 0, this.athaa_sensitivity = 0, this.short_blocks = null, this.useTemporal = !1, this.interChRatio = 0, this.msfix = 0, this.tune = !1, this.tune_value_a = 0, this.version = 0, this.encoder_delay = 0, this.encoder_padding = 0, this.framesize = 0, this.frameNum = 0, this.lame_allocated_gfp = 0, this.internal_flags = null;
+ }();
+ return 0 != ((e = a).class_id = x, t = e.internal_flags = new Z(), e.mode = Ee.NOT_SET, e.original = 1, e.in_samplerate = 44100, e.num_channels = 2, e.num_samples = -1, e.bWriteVbrTag = !0, e.quality = -1, e.short_blocks = null, t.subblock_gain = -1, e.lowpassfreq = 0, e.highpassfreq = 0, e.lowpasswidth = -1, e.highpasswidth = -1, e.VBR = xe.vbr_off, e.VBR_q = 4, e.ATHcurve = -1, e.VBR_mean_bitrate_kbps = 128, e.VBR_min_bitrate_kbps = 0, e.VBR_max_bitrate_kbps = 0, e.VBR_hard_min = 0, t.VBR_min_bitrate = 1, t.VBR_max_bitrate = 13, e.quant_comp = -1, e.quant_comp_short = -1, e.msfix = -1, t.resample_ratio = 1, t.OldValue[0] = 180, t.OldValue[1] = 180, t.CurrentStep[0] = 4, t.CurrentStep[1] = 4, t.masking_lower = 1, t.nsPsy.attackthre = -1, t.nsPsy.attackthre_s = -1, e.scale = -1, e.athaa_type = -1, e.ATHtype = -1, e.athaa_loudapprox = -1, e.athaa_sensitivity = 0, e.useTemporal = null, e.interChRatio = -1, t.mf_samples_to_encode = Pe.ENCDELAY + Pe.POSTDELAY, e.encoder_padding = 0, t.mf_size = Pe.ENCDELAY - Pe.MDCTDELAY, e.findReplayGain = !1, e.decode_on_the_fly = !1, t.decode_on_the_fly = !1, t.findReplayGain = !1, t.findPeakSample = !1, t.RadioGain = 0, t.AudiophileGain = 0, t.noclipGainChange = 0, t.noclipScale = -1, e.preset = 0, e.write_id3tag_automatic = !0, 0) ? null : (a.lame_allocated_gfp = 1, a);
}, this.nearestBitrateFullIndex = function (e) {
var t = [8, 16, 24, 32, 40, 48, 56, 64, 80, 96, 112, 128, 160, 192, 224, 256, 320],
a = 0,
- n = 0,
s = 0,
+ n = 0,
r = 0;
- r = t[16], n = t[s = 16], a = 16;
+ r = t[16], s = t[n = 16], a = 16;
for (var i = 0; i < 16; i++) if (Math.max(e, t[i + 1]) != e) {
- r = t[i + 1], s = i + 1, n = t[i], a = i;
+ r = t[i + 1], n = i + 1, s = t[i], a = i;
break;
}
- return e - n < r - e ? a : s;
+ return e - s < r - e ? a : n;
}, this.lame_init_params = function (e) {
var t,
a,
+ s,
n = e.internal_flags;
if (n.Class_ID = 0, null == n.ATH && (n.ATH = new function () {
- this.useAdjust = 0, this.aaSensitivityP = 0, this.adjust = 0, this.adjustLimit = 0, this.decay = 0, this.floor = 0, this.l = de(Ae.SBMAX_l), this.s = de(Ae.SBMAX_s), this.psfb21 = de(Ae.PSFB21), this.psfb12 = de(Ae.PSFB12), this.cb_l = de(Ae.CBANDS), this.cb_s = de(Ae.CBANDS), this.eql_w = de(Ae.BLKSIZE / 2);
+ this.useAdjust = 0, this.aaSensitivityP = 0, this.adjust = 0, this.adjustLimit = 0, this.decay = 0, this.floor = 0, this.l = Be(Pe.SBMAX_l), this.s = Be(Pe.SBMAX_s), this.psfb21 = Be(Pe.PSFB21), this.psfb12 = Be(Pe.PSFB12), this.cb_l = Be(Pe.CBANDS), this.cb_s = Be(Pe.CBANDS), this.eql_w = Be(Pe.BLKSIZE / 2);
}()), null == n.PSY && (n.PSY = new function () {
- this.mask_adjust = 0, this.mask_adjust_short = 0, this.bo_l_weight = de(Ae.SBMAX_l), this.bo_s_weight = de(Ae.SBMAX_s);
- }()), null == n.rgdata && (n.rgdata = new function () {}()), n.channels_in = e.num_channels, 1 == n.channels_in && (e.mode = ye.MONO), n.channels_out = e.mode == ye.MONO ? 1 : 2, n.mode_ext = Ae.MPG_MD_MS_LR, e.mode == ye.MONO && (e.force_ms = !1), e.VBR == Me.vbr_off && 128 != e.VBR_mean_bitrate_kbps && 0 == e.brate && (e.brate = e.VBR_mean_bitrate_kbps), e.VBR == Me.vbr_off || e.VBR == Me.vbr_mtrh || e.VBR == Me.vbr_mt || (e.free_format = !1), e.VBR == Me.vbr_off && 0 == e.brate && me(), e.VBR == Me.vbr_off && 0 < e.compression_ratio && me(), 0 != e.out_samplerate && (e.out_samplerate < 16e3 ? (e.VBR_mean_bitrate_kbps = Math.max(e.VBR_mean_bitrate_kbps, 8), e.VBR_mean_bitrate_kbps = Math.min(e.VBR_mean_bitrate_kbps, 64)) : e.out_samplerate < 32e3 ? (e.VBR_mean_bitrate_kbps = Math.max(e.VBR_mean_bitrate_kbps, 8), e.VBR_mean_bitrate_kbps = Math.min(e.VBR_mean_bitrate_kbps, 160)) : (e.VBR_mean_bitrate_kbps = Math.max(e.VBR_mean_bitrate_kbps, 32), e.VBR_mean_bitrate_kbps = Math.min(e.VBR_mean_bitrate_kbps, 320))), 0 == e.lowpassfreq) {
- var s = 16e3;
+ this.mask_adjust = 0, this.mask_adjust_short = 0, this.bo_l_weight = Be(Pe.SBMAX_l), this.bo_s_weight = Be(Pe.SBMAX_s);
+ }()), null == n.rgdata && (n.rgdata = new function () {}()), n.channels_in = e.num_channels, 1 == n.channels_in && (e.mode = Ee.MONO), n.channels_out = e.mode == Ee.MONO ? 1 : 2, n.mode_ext = Pe.MPG_MD_MS_LR, e.mode == Ee.MONO && (e.force_ms = !1), e.VBR == xe.vbr_off && 128 != e.VBR_mean_bitrate_kbps && 0 == e.brate && (e.brate = e.VBR_mean_bitrate_kbps), e.VBR == xe.vbr_off || e.VBR == xe.vbr_mtrh || e.VBR == xe.vbr_mt || (e.free_format = !1), e.VBR == xe.vbr_off && 0 == e.brate && q.EQ(e.compression_ratio, 0) && (e.compression_ratio = 11.025), e.VBR == xe.vbr_off && 0 < e.compression_ratio && (0 == e.out_samplerate && (e.out_samplerate = map2MP3Frequency(int(.97 * e.in_samplerate))), e.brate = 0 | 16 * e.out_samplerate * n.channels_out / (1e3 * e.compression_ratio), n.samplerate_index = P(e.out_samplerate, e), e.free_format || (e.brate = L(e.brate, e.version, e.out_samplerate))), 0 != e.out_samplerate && (e.out_samplerate < 16e3 ? (e.VBR_mean_bitrate_kbps = Math.max(e.VBR_mean_bitrate_kbps, 8), e.VBR_mean_bitrate_kbps = Math.min(e.VBR_mean_bitrate_kbps, 64)) : e.out_samplerate < 32e3 ? (e.VBR_mean_bitrate_kbps = Math.max(e.VBR_mean_bitrate_kbps, 8), e.VBR_mean_bitrate_kbps = Math.min(e.VBR_mean_bitrate_kbps, 160)) : (e.VBR_mean_bitrate_kbps = Math.max(e.VBR_mean_bitrate_kbps, 32), e.VBR_mean_bitrate_kbps = Math.min(e.VBR_mean_bitrate_kbps, 320))), 0 == e.lowpassfreq) {
+ var r = 16e3;
switch (e.VBR) {
- case Me.vbr_off:
- var r = new d();
- g(r, e.brate), s = r.lowerlimit;
+ case xe.vbr_off:
+ H(i = new T(), e.brate), r = i.lowerlimit;
break;
- case Me.vbr_abr:
- var r = new d();
- g(r, e.VBR_mean_bitrate_kbps), s = r.lowerlimit;
+ case xe.vbr_abr:
+ var i;
+ H(i = new T(), e.VBR_mean_bitrate_kbps), r = i.lowerlimit;
+ break;
+ case xe.vbr_rh:
+ var o = [19500, 19e3, 18600, 18e3, 17500, 16e3, 15600, 14900, 12500, 1e4, 3950];
+ if (0 <= e.VBR_q && e.VBR_q <= 9) {
+ var _ = o[e.VBR_q],
+ l = o[e.VBR_q + 1],
+ f = e.VBR_q_frac;
+ r = linear_int(_, l, f);
+ } else r = 19500;
break;
- case Me.vbr_rh:
- me();
default:
- me();
+ o = [19500, 19e3, 18500, 18e3, 17500, 16500, 15500, 14500, 12500, 9500, 3950];
+ if (0 <= e.VBR_q && e.VBR_q <= 9) {
+ _ = o[e.VBR_q], l = o[e.VBR_q + 1], f = e.VBR_q_frac;
+ r = linear_int(_, l, f);
+ } else r = 19500;
}
- e.mode != ye.MONO || e.VBR != Me.vbr_off && e.VBR != Me.vbr_abr || (s *= 1.5), e.lowpassfreq = 0 | s;
+ e.mode != Ee.MONO || e.VBR != xe.vbr_off && e.VBR != xe.vbr_abr || (r *= 1.5), e.lowpassfreq = 0 | r;
}
- switch (0 == e.out_samplerate && me(), e.lowpassfreq = Math.min(20500, e.lowpassfreq), e.lowpassfreq = Math.min(e.out_samplerate / 2, e.lowpassfreq), e.VBR == Me.vbr_off && (e.compression_ratio = 16 * e.out_samplerate * n.channels_out / (1e3 * e.brate)), e.VBR == Me.vbr_abr && me(), e.bWriteVbrTag || (e.findReplayGain = !1, e.decode_on_the_fly = !1, n.findPeakSample = !1), n.findReplayGain = e.findReplayGain, n.decode_on_the_fly = e.decode_on_the_fly, n.decode_on_the_fly && (n.findPeakSample = !0), n.findReplayGain && me(), n.decode_on_the_fly && !e.decode_only && me(), n.mode_gr = e.out_samplerate <= 24e3 ? 1 : 2, e.framesize = 576 * n.mode_gr, e.encoder_delay = Ae.ENCDELAY, n.resample_ratio = e.in_samplerate / e.out_samplerate, e.VBR) {
- case Me.vbr_mt:
- case Me.vbr_rh:
- case Me.vbr_mtrh:
+ if (0 == e.out_samplerate && (2 * e.lowpassfreq > e.in_samplerate && (e.lowpassfreq = e.in_samplerate / 2), e.out_samplerate = (t = 0 | e.lowpassfreq, a = e.in_samplerate, s = 44100, 48e3 <= a ? s = 48e3 : 44100 <= a ? s = 44100 : 32e3 <= a ? s = 32e3 : 24e3 <= a ? s = 24e3 : 22050 <= a ? s = 22050 : 16e3 <= a ? s = 16e3 : 12e3 <= a ? s = 12e3 : 11025 <= a ? s = 11025 : 8e3 <= a && (s = 8e3), -1 == t ? s : (t <= 15960 && (s = 44100), t <= 15250 && (s = 32e3), t <= 11220 && (s = 24e3), t <= 9970 && (s = 22050), t <= 7230 && (s = 16e3), t <= 5420 && (s = 12e3), t <= 4510 && (s = 11025), t <= 3970 && (s = 8e3), a < s ? 44100 < a ? 48e3 : 32e3 < a ? 44100 : 24e3 < a ? 32e3 : 22050 < a ? 24e3 : 16e3 < a ? 22050 : 12e3 < a ? 16e3 : 11025 < a ? 12e3 : 8e3 < a ? 11025 : 8e3 : s))), e.lowpassfreq = Math.min(20500, e.lowpassfreq), e.lowpassfreq = Math.min(e.out_samplerate / 2, e.lowpassfreq), e.VBR == xe.vbr_off && (e.compression_ratio = 16 * e.out_samplerate * n.channels_out / (1e3 * e.brate)), e.VBR == xe.vbr_abr && (e.compression_ratio = 16 * e.out_samplerate * n.channels_out / (1e3 * e.VBR_mean_bitrate_kbps)), e.bWriteVbrTag || (e.findReplayGain = !1, e.decode_on_the_fly = !1, n.findPeakSample = !1), n.findReplayGain = e.findReplayGain, n.decode_on_the_fly = e.decode_on_the_fly, n.decode_on_the_fly && (n.findPeakSample = !0), n.findReplayGain && w.InitGainAnalysis(n.rgdata, e.out_samplerate) == X.INIT_GAIN_ANALYSIS_ERROR) return e.internal_flags = null, -6;
+ switch (n.decode_on_the_fly && !e.decode_only && (null != n.hip && k.hip_decode_exit(n.hip), n.hip = k.hip_decode_init()), n.mode_gr = e.out_samplerate <= 24e3 ? 1 : 2, e.framesize = 576 * n.mode_gr, e.encoder_delay = Pe.ENCDELAY, n.resample_ratio = e.in_samplerate / e.out_samplerate, e.VBR) {
+ case xe.vbr_mt:
+ case xe.vbr_rh:
+ case xe.vbr_mtrh:
e.compression_ratio = [5.7, 6.5, 7.3, 8.2, 10, 11.9, 13, 14, 15, 16.5][e.VBR_q];
break;
- case Me.vbr_abr:
+ case xe.vbr_abr:
e.compression_ratio = 16 * e.out_samplerate * n.channels_out / (1e3 * e.VBR_mean_bitrate_kbps);
break;
default:
e.compression_ratio = 16 * e.out_samplerate * n.channels_out / (1e3 * e.brate);
}
- e.mode == ye.NOT_SET && (e.mode = ye.JOINT_STEREO), 0 < e.highpassfreq ? me() : (n.highpass1 = 0, n.highpass2 = 0), 0 < e.lowpassfreq ? (n.lowpass2 = 2 * e.lowpassfreq, 0 <= e.lowpasswidth ? me() : n.lowpass1 = 2 * e.lowpassfreq, n.lowpass1 /= e.out_samplerate, n.lowpass2 /= e.out_samplerate) : me(), function (e) {
- var t,
- a = e.internal_flags,
- n = 32;
- if (0 < a.lowpass1) {
- for (var s = 999, r = 0; r <= 31; r++) {
- var i = r / 31;
- i >= a.lowpass2 && (n = Math.min(n, r)), a.lowpass1 < i && i < a.lowpass2 && (s = Math.min(s, r));
- }
- a.lowpass1 = 999 == s ? (n - .75) / 31 : (s - .75) / 31, a.lowpass2 = n / 31;
+ if (e.mode == Ee.NOT_SET && (e.mode = Ee.JOINT_STEREO), 0 < e.highpassfreq ? (n.highpass1 = 2 * e.highpassfreq, 0 <= e.highpasswidth ? n.highpass2 = 2 * (e.highpassfreq + e.highpasswidth) : n.highpass2 = 2 * e.highpassfreq, n.highpass1 /= e.out_samplerate, n.highpass2 /= e.out_samplerate) : (n.highpass1 = 0, n.highpass2 = 0), 0 < e.lowpassfreq ? (n.lowpass2 = 2 * e.lowpassfreq, 0 <= e.lowpasswidth ? (n.lowpass1 = 2 * (e.lowpassfreq - e.lowpasswidth), n.lowpass1 < 0 && (n.lowpass1 = 0)) : n.lowpass1 = 2 * e.lowpassfreq, n.lowpass1 /= e.out_samplerate, n.lowpass2 /= e.out_samplerate) : (n.lowpass1 = 0, n.lowpass2 = 0), function (e) {
+ var t = e.internal_flags,
+ a = 32,
+ s = -1;
+ if (0 < t.lowpass1) {
+ for (var n = 999, r = 0; r <= 31; r++) (l = r / 31) >= t.lowpass2 && (a = Math.min(a, r)), t.lowpass1 < l && l < t.lowpass2 && (n = Math.min(n, r));
+ t.lowpass1 = 999 == n ? (a - .75) / 31 : (n - .75) / 31, t.lowpass2 = a / 31;
}
- 0 < a.highpass2 && me(), 0 < a.highpass2 && me();
- for (var r = 0; r < 32; r++) {
+ if (0 < t.highpass2 && t.highpass2 < .75 / 31 * .9 && (t.highpass1 = 0, t.highpass2 = 0, $.err.println("Warning: highpass filter disabled. highpass frequency too small\n")), 0 < t.highpass2) {
+ var i = -1;
+ for (r = 0; r <= 31; r++) (l = r / 31) <= t.highpass1 && (s = Math.max(s, r)), t.highpass1 < l && l < t.highpass2 && (i = Math.max(i, r));
+ t.highpass1 = s / 31, t.highpass2 = -1 == i ? (s + .75) / 31 : (i + .75) / 31;
+ }
+ for (r = 0; r < 32; r++) {
var o,
_,
- i = r / 31;
- a.highpass2 > a.highpass1 ? me() : o = 1, _ = a.lowpass2 > a.lowpass1 ? 1 < (t = (i - a.lowpass1) / (a.lowpass2 - a.lowpass1 + 1e-20)) ? 0 : t <= 0 ? 1 : Math.cos(Math.PI / 2 * t) : 1, a.amp_filter[r] = o * _;
+ l = r / 31;
+ o = t.highpass2 > t.highpass1 ? E((t.highpass2 - l) / (t.highpass2 - t.highpass1 + 1e-20)) : 1, _ = t.lowpass2 > t.lowpass1 ? E((l - t.lowpass1) / (t.lowpass2 - t.lowpass1 + 1e-20)) : 1, t.amp_filter[r] = o * _;
}
- }(e), n.samplerate_index = function (e, t) {
- switch (e) {
- case 44100:
- return t.version = 1, 0;
- case 48e3:
- return t.version = 1;
- case 32e3:
- return t.version = 1, 2;
- case 22050:
- return t.version = 0;
- case 24e3:
- return t.version = 0, 1;
- case 16e3:
- return t.version = 0, 2;
- case 11025:
- return t.version = 0;
- case 12e3:
- return t.version = 0, 1;
- case 8e3:
- return t.version = 0, 2;
- default:
- return t.version = 0, -1;
- }
- }(e.out_samplerate, e), n.samplerate_index < 0 && me(), e.VBR == Me.vbr_off ? e.free_format ? n.bitrate_index = 0 : (e.brate = function (e, t, a) {
- a < 16e3 && (t = 2);
- for (var n = k.bitrate_table[t][1], s = 2; s <= 14; s++) 0 < k.bitrate_table[t][s] && Math.abs(k.bitrate_table[t][s] - e) < Math.abs(n - e) && (n = k.bitrate_table[t][s]);
- return n;
- }(e.brate, e.version, e.out_samplerate), n.bitrate_index = function (e, t, a) {
- a < 16e3 && (t = 2);
- for (var n = 0; n <= 14; n++) if (0 < k.bitrate_table[t][n] && k.bitrate_table[t][n] == e) return n;
- return -1;
- }(e.brate, e.version, e.out_samplerate), n.bitrate_index <= 0 && me()) : n.bitrate_index = 1, e.analysis && (e.bWriteVbrTag = !1), null != n.pinfo && (e.bWriteVbrTag = !1), E.init_bit_stream_w(n);
- for (var i, o = n.samplerate_index + 3 * e.version + 6 * (e.out_samplerate < 16e3 ? 1 : 0), _ = 0; _ < Ae.SBMAX_l + 1; _++) n.scalefac_band.l[_] = h.sfBandIndex[o].l[_];
- for (var _ = 0; _ < Ae.PSFB21 + 1; _++) {
- var l = (n.scalefac_band.l[22] - n.scalefac_band.l[21]) / Ae.PSFB21,
- f = n.scalefac_band.l[21] + _ * l;
- n.scalefac_band.psfb21[_] = f;
+ }(e), n.samplerate_index = P(e.out_samplerate, e), n.samplerate_index < 0) return e.internal_flags = null, -1;
+ if (e.VBR == xe.vbr_off) {
+ if (e.free_format) n.bitrate_index = 0;else if (e.brate = L(e.brate, e.version, e.out_samplerate), n.bitrate_index = I(e.brate, e.version, e.out_samplerate), n.bitrate_index <= 0) return e.internal_flags = null, -1;
+ } else n.bitrate_index = 1;
+ e.analysis && (e.bWriteVbrTag = !1), null != n.pinfo && (e.bWriteVbrTag = !1), R.init_bit_stream_w(n);
+ for (var c, h, u, m = n.samplerate_index + 3 * e.version + 6 * (e.out_samplerate < 16e3 ? 1 : 0), p = 0; p < Pe.SBMAX_l + 1; p++) n.scalefac_band.l[p] = S.sfBandIndex[m].l[p];
+ for (p = 0; p < Pe.PSFB21 + 1; p++) {
+ var b = (n.scalefac_band.l[22] - n.scalefac_band.l[21]) / Pe.PSFB21,
+ v = n.scalefac_band.l[21] + p * b;
+ n.scalefac_band.psfb21[p] = v;
}
- n.scalefac_band.psfb21[Ae.PSFB21] = 576;
- for (var _ = 0; _ < Ae.SBMAX_s + 1; _++) n.scalefac_band.s[_] = h.sfBandIndex[o].s[_];
- for (var _ = 0; _ < Ae.PSFB12 + 1; _++) {
- var l = (n.scalefac_band.s[13] - n.scalefac_band.s[12]) / Ae.PSFB12,
- f = n.scalefac_band.s[12] + _ * l;
- n.scalefac_band.psfb12[_] = f;
+ n.scalefac_band.psfb21[Pe.PSFB21] = 576;
+ for (p = 0; p < Pe.SBMAX_s + 1; p++) n.scalefac_band.s[p] = S.sfBandIndex[m].s[p];
+ for (p = 0; p < Pe.PSFB12 + 1; p++) {
+ b = (n.scalefac_band.s[13] - n.scalefac_band.s[12]) / Pe.PSFB12, v = n.scalefac_band.s[12] + p * b;
+ n.scalefac_band.psfb12[p] = v;
}
- for (n.scalefac_band.psfb12[Ae.PSFB12] = 192, 1 == e.version ? n.sideinfo_len = 1 == n.channels_out ? 21 : 36 : n.sideinfo_len = 1 == n.channels_out ? 13 : 21, e.error_protection && (n.sideinfo_len += 2), a = void 0, a = (t = e).internal_flags, t.frameNum = 0, t.write_id3tag_automatic && m.id3tag_write_v2(t), a.bitrate_stereoMode_Hist = w([16, 5]), a.bitrate_blockType_Hist = w([16, 6]), a.PeakSample = 0, t.bWriteVbrTag && p.InitVbrTag(t), n.Class_ID = I, i = 0; i < 19; i++) n.nsPsy.pefirbuf[i] = 700 * n.mode_gr * n.channels_out;
+ for (n.scalefac_band.psfb12[Pe.PSFB12] = 192, 1 == e.version ? n.sideinfo_len = 1 == n.channels_out ? 21 : 36 : n.sideinfo_len = 1 == n.channels_out ? 13 : 21, e.error_protection && (n.sideinfo_len += 2), h = (c = e).internal_flags, c.frameNum = 0, c.write_id3tag_automatic && B.id3tag_write_v2(c), h.bitrate_stereoMode_Hist = Y([16, 5]), h.bitrate_blockType_Hist = Y([16, 6]), h.PeakSample = 0, c.bWriteVbrTag && A.InitVbrTag(c), n.Class_ID = x, u = 0; u < 19; u++) n.nsPsy.pefirbuf[u] = 700 * n.mode_gr * n.channels_out;
switch (-1 == e.ATHtype && (e.ATHtype = 4), e.VBR) {
- case Me.vbr_mt:
- e.VBR = Me.vbr_mtrh;
- case Me.vbr_mtrh:
- null == e.useTemporal && (e.useTemporal = !1), u.apply_preset(e, 500 - 10 * e.VBR_q, 0), e.quality < 0 && (e.quality = LAME_DEFAULT_QUALITY), e.quality < 5 && (e.quality = 0), 5 < e.quality && (e.quality = 5), n.PSY.mask_adjust = e.maskingadjust, n.PSY.mask_adjust_short = e.maskingadjust_short, e.experimentalY ? n.sfb21_extra = !1 : n.sfb21_extra = 44e3 < e.out_samplerate, n.iteration_loop = new VBRNewIterationLoop(b);
+ case xe.vbr_mt:
+ e.VBR = xe.vbr_mtrh;
+ case xe.vbr_mtrh:
+ null == e.useTemporal && (e.useTemporal = !1), g.apply_preset(e, 500 - 10 * e.VBR_q, 0), e.quality < 0 && (e.quality = LAME_DEFAULT_QUALITY), e.quality < 5 && (e.quality = 0), 5 < e.quality && (e.quality = 5), n.PSY.mask_adjust = e.maskingadjust, n.PSY.mask_adjust_short = e.maskingadjust_short, e.experimentalY ? n.sfb21_extra = !1 : n.sfb21_extra = 44e3 < e.out_samplerate, n.iteration_loop = new VBRNewIterationLoop(M);
break;
- case Me.vbr_rh:
- u.apply_preset(e, 500 - 10 * e.VBR_q, 0), n.PSY.mask_adjust = e.maskingadjust, n.PSY.mask_adjust_short = e.maskingadjust_short, e.experimentalY ? n.sfb21_extra = !1 : n.sfb21_extra = 44e3 < e.out_samplerate, 6 < e.quality && (e.quality = 6), e.quality < 0 && (e.quality = LAME_DEFAULT_QUALITY), n.iteration_loop = new VBROldIterationLoop(b);
+ case xe.vbr_rh:
+ g.apply_preset(e, 500 - 10 * e.VBR_q, 0), n.PSY.mask_adjust = e.maskingadjust, n.PSY.mask_adjust_short = e.maskingadjust_short, e.experimentalY ? n.sfb21_extra = !1 : n.sfb21_extra = 44e3 < e.out_samplerate, 6 < e.quality && (e.quality = 6), e.quality < 0 && (e.quality = LAME_DEFAULT_QUALITY), n.iteration_loop = new VBROldIterationLoop(M);
break;
default:
- var c;
- n.sfb21_extra = !1, e.quality < 0 && (e.quality = LAME_DEFAULT_QUALITY), (c = e.VBR) == Me.vbr_off && (e.VBR_mean_bitrate_kbps = e.brate), u.apply_preset(e, e.VBR_mean_bitrate_kbps, 0), e.VBR = c, n.PSY.mask_adjust = e.maskingadjust, n.PSY.mask_adjust_short = e.maskingadjust_short, c == Me.vbr_off ? n.iteration_loop = new function (e) {
+ var d;
+ n.sfb21_extra = !1, e.quality < 0 && (e.quality = LAME_DEFAULT_QUALITY), (d = e.VBR) == xe.vbr_off && (e.VBR_mean_bitrate_kbps = e.brate), g.apply_preset(e, e.VBR_mean_bitrate_kbps, 0), e.VBR = d, n.PSY.mask_adjust = e.maskingadjust, n.PSY.mask_adjust_short = e.maskingadjust_short, n.iteration_loop = d == xe.vbr_off ? new function (e) {
var t = e;
- this.quantize = t, this.iteration_loop = function (e, t, a, n) {
- var s = e.internal_flags,
- r = de(F.SFBMAX),
- i = de(576),
- o = ve(2),
- _ = 0,
- l = s.l3_side,
- f = new R(_);
- this.quantize.rv.ResvFrameBegin(e, f), _ = f.bits;
- for (var c = 0; c < s.mode_gr; c++) {
- this.quantize.qupvt.on_pe(e, t, o, _, c, c), s.mode_ext == Ae.MPG_MD_MS_LR && me();
- for (var u = 0; u < s.channels_out; u++) {
- var h,
- b,
- p = l.tt[c][u];
- p.block_type != Ae.SHORT_TYPE ? (h = 0, b = s.PSY.mask_adjust - h) : (h = 0, b = s.PSY.mask_adjust_short - h), s.masking_lower = Math.pow(10, .1 * b), this.quantize.init_outer_loop(s, p), this.quantize.init_xrpow(s, p, i) && (this.quantize.qupvt.calc_xmin(e, n[c][u], p, r), this.quantize.outer_loop(e, p, r, i, u, o[u])), this.quantize.iteration_finish_one(s, c, u);
+ this.quantize = t, this.iteration_loop = function (e, t, a, s) {
+ var n,
+ r = e.internal_flags,
+ i = Be(z.SFBMAX),
+ o = Be(576),
+ _ = Ae(2),
+ l = 0,
+ f = r.l3_side,
+ c = new j(l);
+ this.quantize.rv.ResvFrameBegin(e, c), l = c.bits;
+ for (var h = 0; h < r.mode_gr; h++) {
+ n = this.quantize.qupvt.on_pe(e, t, _, l, h, h), r.mode_ext == Pe.MPG_MD_MS_LR && (this.quantize.ms_convert(r.l3_side, h), this.quantize.qupvt.reduce_side(_, a[h], l, n));
+ for (var u = 0; u < r.channels_out; u++) {
+ var m,
+ p,
+ b = f.tt[h][u];
+ b.block_type != Pe.SHORT_TYPE ? (m = 0, p = r.PSY.mask_adjust - m) : (m = 0, p = r.PSY.mask_adjust_short - m), r.masking_lower = Math.pow(10, .1 * p), this.quantize.init_outer_loop(r, b), this.quantize.init_xrpow(r, b, o) && (this.quantize.qupvt.calc_xmin(e, s[h][u], b, i), this.quantize.outer_loop(e, b, i, o, u, _[u])), this.quantize.iteration_finish_one(r, h, u);
}
}
- this.quantize.rv.ResvFrameEnd(s, _);
+ this.quantize.rv.ResvFrameEnd(r, l);
};
- }(b) : me();
+ }(M) : new ABRIterationLoop(M);
}
- return e.VBR != Me.vbr_off && me(), e.tune && me(), function (e) {
+ if (e.VBR != xe.vbr_off) {
+ if (n.VBR_min_bitrate = 1, n.VBR_max_bitrate = 14, e.out_samplerate < 16e3 && (n.VBR_max_bitrate = 8), 0 != e.VBR_min_bitrate_kbps && (e.VBR_min_bitrate_kbps = L(e.VBR_min_bitrate_kbps, e.version, e.out_samplerate), n.VBR_min_bitrate = I(e.VBR_min_bitrate_kbps, e.version, e.out_samplerate), n.VBR_min_bitrate < 0)) return -1;
+ if (0 != e.VBR_max_bitrate_kbps && (e.VBR_max_bitrate_kbps = L(e.VBR_max_bitrate_kbps, e.version, e.out_samplerate), n.VBR_max_bitrate = I(e.VBR_max_bitrate_kbps, e.version, e.out_samplerate), n.VBR_max_bitrate < 0)) return -1;
+ e.VBR_min_bitrate_kbps = F.bitrate_table[e.version][n.VBR_min_bitrate], e.VBR_max_bitrate_kbps = F.bitrate_table[e.version][n.VBR_max_bitrate], e.VBR_mean_bitrate_kbps = Math.min(F.bitrate_table[e.version][n.VBR_max_bitrate], e.VBR_mean_bitrate_kbps), e.VBR_mean_bitrate_kbps = Math.max(F.bitrate_table[e.version][n.VBR_min_bitrate], e.VBR_mean_bitrate_kbps);
+ }
+ return e.tune && (n.PSY.mask_adjust += e.tune_value_a, n.PSY.mask_adjust_short += e.tune_value_a), function (e) {
var t = e.internal_flags;
switch (e.quality) {
default:
@@ -15282,229 +15584,252 @@ src: recorder-core.js,engine/mp3.js,engine/mp3-engine.js
case 0:
t.psymodel = 1, 0 == t.noise_shaping && (t.noise_shaping = 1), 0 == t.substep_shaping && (t.substep_shaping = 2), t.noise_shaping_amp = 2, -(t.noise_shaping_stop = 1) == t.subblock_gain && (t.subblock_gain = 1), t.use_best_huffman = 1, t.full_outer_loop = 0;
}
- }(e), e.athaa_type < 0 ? n.ATH.useAdjust = 3 : n.ATH.useAdjust = e.athaa_type, n.ATH.aaSensitivityP = Math.pow(10, e.athaa_sensitivity / -10), null == e.short_blocks && (e.short_blocks = Se.short_block_allowed), e.short_blocks != Se.short_block_allowed || e.mode != ye.JOINT_STEREO && e.mode != ye.STEREO || (e.short_blocks = Se.short_block_coupled), e.quant_comp < 0 && (e.quant_comp = 1), e.quant_comp_short < 0 && (e.quant_comp_short = 0), e.msfix < 0 && (e.msfix = 0), e.exp_nspsytune = 1 | e.exp_nspsytune, e.internal_flags.nsPsy.attackthre < 0 && (e.internal_flags.nsPsy.attackthre = X.NSATTACKTHRE), e.internal_flags.nsPsy.attackthre_s < 0 && (e.internal_flags.nsPsy.attackthre_s = X.NSATTACKTHRE_S), e.scale < 0 && (e.scale = 1), e.ATHtype < 0 && (e.ATHtype = 4), e.ATHcurve < 0 && (e.ATHcurve = 4), e.athaa_loudapprox < 0 && (e.athaa_loudapprox = 2), e.interChRatio < 0 && (e.interChRatio = 0), null == e.useTemporal && (e.useTemporal = !0), n.slot_lag = n.frac_SpF = 0, e.VBR == Me.vbr_off && (n.slot_lag = n.frac_SpF = 72e3 * (e.version + 1) * e.brate % e.out_samplerate | 0), h.iteration_init(e), v.psymodel_init(e), 0;
- }, this.lame_encode_flush = function (e, t, a, n) {
- var s,
+ }(e), e.athaa_type < 0 ? n.ATH.useAdjust = 3 : n.ATH.useAdjust = e.athaa_type, n.ATH.aaSensitivityP = Math.pow(10, e.athaa_sensitivity / -10), null == e.short_blocks && (e.short_blocks = Te.short_block_allowed), e.short_blocks != Te.short_block_allowed || e.mode != Ee.JOINT_STEREO && e.mode != Ee.STEREO || (e.short_blocks = Te.short_block_coupled), e.quant_comp < 0 && (e.quant_comp = 1), e.quant_comp_short < 0 && (e.quant_comp_short = 0), e.msfix < 0 && (e.msfix = 0), e.exp_nspsytune = 1 | e.exp_nspsytune, e.internal_flags.nsPsy.attackthre < 0 && (e.internal_flags.nsPsy.attackthre = G.NSATTACKTHRE), e.internal_flags.nsPsy.attackthre_s < 0 && (e.internal_flags.nsPsy.attackthre_s = G.NSATTACKTHRE_S), e.scale < 0 && (e.scale = 1), e.ATHtype < 0 && (e.ATHtype = 4), e.ATHcurve < 0 && (e.ATHcurve = 4), e.athaa_loudapprox < 0 && (e.athaa_loudapprox = 2), e.interChRatio < 0 && (e.interChRatio = 0), null == e.useTemporal && (e.useTemporal = !0), n.slot_lag = n.frac_SpF = 0, e.VBR == xe.vbr_off && (n.slot_lag = n.frac_SpF = 72e3 * (e.version + 1) * e.brate % e.out_samplerate | 0), S.iteration_init(e), y.psymodel_init(e), 0;
+ }, this.lame_encode_flush = function (e, t, a, s) {
+ var n,
r,
i,
o,
_ = e.internal_flags,
- l = M([2, 1152]),
+ l = p([2, 1152]),
f = 0,
- c = _.mf_samples_to_encode - Ae.POSTDELAY,
- u = L(e);
+ c = _.mf_samples_to_encode - Pe.POSTDELAY,
+ h = C(e);
if (_.mf_samples_to_encode < 1) return 0;
- for (s = 0, e.in_samplerate != e.out_samplerate && me(), (i = e.framesize - c % e.framesize) < 576 && (i += e.framesize), e.encoder_padding = i, o = (c + i) / e.framesize; 0 < o && 0 <= f;) {
- var h = u - _.mf_size,
- b = e.frameNum;
- h *= e.in_samplerate, 1152 < (h /= e.out_samplerate) && (h = 1152), h < 1 && (h = 1), r = n - s, 0 == n && (r = 0), f = this.lame_encode_buffer(e, l[0], l[1], h, t, a, r), a += f, s += f, o -= b != e.frameNum ? 1 : 0;
+ for (n = 0, e.in_samplerate != e.out_samplerate && (c += 16 * e.out_samplerate / e.in_samplerate), (i = e.framesize - c % e.framesize) < 576 && (i += e.framesize), o = (c + (e.encoder_padding = i)) / e.framesize; 0 < o && 0 <= f;) {
+ var u = h - _.mf_size,
+ m = e.frameNum;
+ u *= e.in_samplerate, 1152 < (u /= e.out_samplerate) && (u = 1152), u < 1 && (u = 1), r = s - n, 0 == s && (r = 0), a += f = this.lame_encode_buffer(e, l[0], l[1], u, t, a, r), n += f, o -= m != e.frameNum ? 1 : 0;
}
- return _.mf_samples_to_encode = 0, f < 0 ? f : (r = n - s, 0 == n && (r = 0), E.flush_bitstream(e), (f = E.copy_buffer(_, t, a, r, 1)) < 0 ? f : (a += f, r = n - (s += f), 0 == n && (r = 0), e.write_id3tag_automatic && me(), s));
- }, this.lame_encode_buffer = function (e, t, a, n, s, r, i) {
+ if (f < (_.mf_samples_to_encode = 0)) return f;
+ if (r = s - n, 0 == s && (r = 0), R.flush_bitstream(e), (f = R.copy_buffer(_, t, a, r, 1)) < 0) return f;
+ if (a += f, r = s - (n += f), 0 == s && (r = 0), e.write_id3tag_automatic) {
+ if (B.id3tag_write_v1(e), (f = R.copy_buffer(_, t, a, r, 0)) < 0) return f;
+ n += f;
+ }
+ return n;
+ }, this.lame_encode_buffer = function (e, t, a, s, n, r, i) {
var o,
_,
l = e.internal_flags,
f = [null, null];
- if (l.Class_ID != I) return -3;
- if (0 == n) return 0;
- _ = n, (null == (o = l).in_buffer_0 || o.in_buffer_nsamples < _) && (o.in_buffer_0 = de(_), o.in_buffer_1 = de(_), o.in_buffer_nsamples = _), f[0] = l.in_buffer_0, f[1] = l.in_buffer_1;
- for (var c = 0; c < n; c++) f[0][c] = t[c], 1 < l.channels_in && (f[1][c] = a[c]);
- return function (e, t, a, n, s, r, i) {
+ if (l.Class_ID != x) return -3;
+ if (0 == s) return 0;
+ _ = s, (null == (o = l).in_buffer_0 || o.in_buffer_nsamples < _) && (o.in_buffer_0 = Be(_), o.in_buffer_1 = Be(_), o.in_buffer_nsamples = _), f[0] = l.in_buffer_0, f[1] = l.in_buffer_1;
+ for (var c = 0; c < s; c++) f[0][c] = t[c], 1 < l.channels_in && (f[1][c] = a[c]);
+ return function (e, t, a, s, n, r, i) {
var o,
_,
l,
f,
c,
- u = e.internal_flags,
- h = 0,
- b = [null, null],
+ h = e.internal_flags,
+ u = 0,
+ m = [null, null],
p = [null, null];
- if (u.Class_ID != I) return -3;
- if (0 == n) return 0;
- if ((c = E.copy_buffer(u, s, r, i, 0)) < 0) return c;
- if (r += c, h += c, p[0] = t, p[1] = a, N.NEQ(e.scale, 0) && N.NEQ(e.scale, 1)) for (_ = 0; _ < n; ++_) p[0][_] *= e.scale, 2 == u.channels_out && (p[1][_] *= e.scale);
- if (N.NEQ(e.scale_left, 0) && N.NEQ(e.scale_left, 1)) for (_ = 0; _ < n; ++_) p[0][_] *= e.scale_left;
- if (N.NEQ(e.scale_right, 0) && N.NEQ(e.scale_right, 1)) for (_ = 0; _ < n; ++_) p[1][_] *= e.scale_right;
- 2 == e.num_channels && 1 == u.channels_out && me(), f = L(e), b[0] = u.mfbuf[0], b[1] = u.mfbuf[1];
- for (var m, v, d, g, w, S, M, y = 0; 0 < n;) {
- var A = [null, null],
- k = 0,
- R = 0;
- A[0] = p[0], A[1] = p[1];
- var x = new P();
- if (H(e, b, A, y, n, x), k = x.n_in, R = x.n_out, u.findReplayGain && !u.decode_on_the_fly && T.AnalyzeSamples(u.rgdata, b[0], u.mf_size, b[1], u.mf_size, R, u.channels_out) == O.GAIN_ANALYSIS_ERROR) return -6;
- if (n -= k, y += k, u.channels_out, u.mf_size += R, u.mf_samples_to_encode < 1 && me(), u.mf_samples_to_encode += R, u.mf_size >= f) {
- var B = i - h;
- if (0 == i && (B = 0), m = e, v = b[0], d = b[1], g = s, w = r, S = B, M = C.enc.lame_encode_mp3_frame(m, v, d, g, w, S), m.frameNum++, (o = M) < 0) return o;
- for (r += o, h += o, u.mf_size -= e.framesize, u.mf_samples_to_encode -= e.framesize, l = 0; l < u.channels_out; l++) for (_ = 0; _ < u.mf_size; _++) b[l][_] = b[l][_ + e.framesize];
+ if (h.Class_ID != x) return -3;
+ if (0 == s) return 0;
+ if ((c = R.copy_buffer(h, n, r, i, 0)) < 0) return c;
+ if (r += c, u += c, p[0] = t, p[1] = a, q.NEQ(e.scale, 0) && q.NEQ(e.scale, 1)) for (_ = 0; _ < s; ++_) p[0][_] *= e.scale, 2 == h.channels_out && (p[1][_] *= e.scale);
+ if (q.NEQ(e.scale_left, 0) && q.NEQ(e.scale_left, 1)) for (_ = 0; _ < s; ++_) p[0][_] *= e.scale_left;
+ if (q.NEQ(e.scale_right, 0) && q.NEQ(e.scale_right, 1)) for (_ = 0; _ < s; ++_) p[1][_] *= e.scale_right;
+ if (2 == e.num_channels && 1 == h.channels_out) for (_ = 0; _ < s; ++_) p[0][_] = .5 * (p[0][_] + p[1][_]), p[1][_] = 0;
+ f = C(e), m[0] = h.mfbuf[0], m[1] = h.mfbuf[1];
+ var b = 0;
+ for (; 0 < s;) {
+ var v = [null, null],
+ d = 0,
+ g = 0;
+ v[0] = p[0], v[1] = p[1];
+ var S = new O();
+ if (D(e, m, v, b, s, S), d = S.n_in, g = S.n_out, h.findReplayGain && !h.decode_on_the_fly && w.AnalyzeSamples(h.rgdata, m[0], h.mf_size, m[1], h.mf_size, g, h.channels_out) == X.GAIN_ANALYSIS_ERROR) return -6;
+ if (s -= d, b += d, h.channels_out, h.mf_size += g, h.mf_samples_to_encode < 1 && (h.mf_samples_to_encode = Pe.ENCDELAY + Pe.POSTDELAY), h.mf_samples_to_encode += g, h.mf_size >= f) {
+ var M = i - u;
+ if (0 == i && (M = 0), (o = V(e, m[0], m[1], n, r, M)) < 0) return o;
+ for (r += o, u += o, h.mf_size -= e.framesize, h.mf_samples_to_encode -= e.framesize, l = 0; l < h.channels_out; l++) for (_ = 0; _ < h.mf_size; _++) m[l][_] = m[l][_ + e.framesize];
}
}
- return h;
- }(e, f[0], f[1], n, s, r, i);
+ return u;
+ }(e, f[0], f[1], s, n, r, i);
};
}
- F.SFBMAX = 3 * Ae.SBMAX_s, Ae.ENCDELAY = 576, Ae.POSTDELAY = 1152, Ae.FFTOFFSET = 224 + (Ae.MDCTDELAY = 48), Ae.DECDELAY = 528, Ae.SBLIMIT = 32, Ae.CBANDS = 64, Ae.SBPSY_l = 21, Ae.SBPSY_s = 12, Ae.SBMAX_l = 22, Ae.SBMAX_s = 13, Ae.PSFB21 = 6, Ae.PSFB12 = 6, Ae.HBLKSIZE = (Ae.BLKSIZE = 1024) / 2 + 1, Ae.HBLKSIZE_s = (Ae.BLKSIZE_s = 256) / 2 + 1, Ae.NORM_TYPE = 0, Ae.START_TYPE = 1, Ae.SHORT_TYPE = 2, Ae.STOP_TYPE = 3, Ae.MPG_MD_LR_LR = 0, Ae.MPG_MD_LR_I = 1, Ae.MPG_MD_MS_LR = 2, Ae.MPG_MD_MS_I = 3, Ae.fircoef = [-.1039435, -.1892065, 5 * -.0432472, -.155915, 3.898045e-17, .0467745 * 5, .50455, .756825, .187098 * 5], j.MFSIZE = 3456 + Ae.ENCDELAY - Ae.MDCTDELAY, j.MAX_HEADER_BUF = 256, j.MAX_BITS_PER_CHANNEL = 4095, j.MAX_BITS_PER_GRANULE = 7680, j.BPC = 320, F.SFBMAX = 3 * Ae.SBMAX_s, t.Mp3Encoder = function (n, e, t) {
- 1 != n && me("fix cc: only supports mono");
- var s = new Y(),
+ z.SFBMAX = 3 * Pe.SBMAX_s, Pe.ENCDELAY = 576, Pe.POSTDELAY = 1152, Pe.FFTOFFSET = 224 + (Pe.MDCTDELAY = 48), Pe.DECDELAY = 528, Pe.SBLIMIT = 32, Pe.CBANDS = 64, Pe.SBPSY_l = 21, Pe.SBPSY_s = 12, Pe.SBMAX_l = 22, Pe.SBMAX_s = 13, Pe.PSFB21 = 6, Pe.PSFB12 = 6, Pe.HBLKSIZE = (Pe.BLKSIZE = 1024) / 2 + 1, Pe.HBLKSIZE_s = (Pe.BLKSIZE_s = 256) / 2 + 1, Pe.NORM_TYPE = 0, Pe.START_TYPE = 1, Pe.SHORT_TYPE = 2, Pe.STOP_TYPE = 3, Pe.MPG_MD_LR_LR = 0, Pe.MPG_MD_LR_I = 1, Pe.MPG_MD_MS_LR = 2, Pe.MPG_MD_MS_I = 3, Pe.fircoef = [-.1039435, -.1892065, 5 * -.0432472, -.155915, 3.898045e-17, .0467745 * 5, .50455, .756825, .187098 * 5], Z.MFSIZE = 3456 + Pe.ENCDELAY - Pe.MDCTDELAY, Z.MAX_HEADER_BUF = 256, Z.MAX_BITS_PER_CHANNEL = 4095, Z.MAX_BITS_PER_GRANULE = 7680, Z.BPC = 320, z.SFBMAX = 3 * Pe.SBMAX_s, t.Mp3Encoder = function (s, e, t) {
+ 3 != arguments.length && (console.error("WARN: Mp3Encoder(channels, samplerate, kbps) not specified"), s = 1, e = 44100, t = 128);
+ var n = new U(),
a = new function () {
this.setModules = function (e, t) {};
}(),
- r = new O(),
- i = new N(),
+ r = new X(),
+ i = new q(),
o = new function () {
- function e(e, t, a, n, s, r, i, o, _, l, f, c, u, h) {
- this.quant_comp = t, this.quant_comp_s = a, this.safejoint = n, this.nsmsfix = s, this.st_lrm = r, this.st_s = i, this.nsbass = o, this.scale = _, this.masking_adj = l, this.ath_lower = f, this.ath_curve = c, this.interch = u, this.sfscale = h;
+ function e(e, t, a, s, n, r, i, o, _, l, f, c, h, u, m) {
+ this.vbr_q = e, this.quant_comp = t, this.quant_comp_s = a, this.expY = s, this.st_lrm = n, this.st_s = r, this.masking_adj = i, this.masking_adj_short = o, this.ath_lower = _, this.ath_curve = l, this.ath_sensitivity = f, this.interch = c, this.safejoint = h, this.sfb21mod = u, this.msfix = m;
+ }
+ function t(e, t, a, s, n, r, i, o, _, l, f, c, h, u) {
+ this.quant_comp = t, this.quant_comp_s = a, this.safejoint = s, this.nsmsfix = n, this.st_lrm = r, this.st_s = i, this.nsbass = o, this.scale = _, this.masking_adj = l, this.ath_lower = f, this.ath_curve = c, this.interch = h, this.sfscale = u;
}
var i;
- function n(e, t, a) {
- me();
- }
this.setModules = function (e) {
i = e;
};
- var o = [new e(8, 9, 9, 0, 0, 6.6, 145, 0, .95, 0, -30, 11, .0012, 1), new e(16, 9, 9, 0, 0, 6.6, 145, 0, .95, 0, -25, 11, .001, 1), new e(24, 9, 9, 0, 0, 6.6, 145, 0, .95, 0, -20, 11, .001, 1), new e(32, 9, 9, 0, 0, 6.6, 145, 0, .95, 0, -15, 11, .001, 1), new e(40, 9, 9, 0, 0, 6.6, 145, 0, .95, 0, -10, 11, 9e-4, 1), new e(48, 9, 9, 0, 0, 6.6, 145, 0, .95, 0, -10, 11, 9e-4, 1), new e(56, 9, 9, 0, 0, 6.6, 145, 0, .95, 0, -6, 11, 8e-4, 1), new e(64, 9, 9, 0, 0, 6.6, 145, 0, .95, 0, -2, 11, 8e-4, 1), new e(80, 9, 9, 0, 0, 6.6, 145, 0, .95, 0, 0, 8, 7e-4, 1), new e(96, 9, 9, 0, 2.5, 6.6, 145, 0, .95, 0, 1, 5.5, 6e-4, 1), new e(112, 9, 9, 0, 2.25, 6.6, 145, 0, .95, 0, 2, 4.5, 5e-4, 1), new e(128, 9, 9, 0, 1.95, 6.4, 140, 0, .95, 0, 3, 4, 2e-4, 1), new e(160, 9, 9, 1, 1.79, 6, 135, 0, .95, -2, 5, 3.5, 0, 1), new e(192, 9, 9, 1, 1.49, 5.6, 125, 0, .97, -4, 7, 3, 0, 0), new e(224, 9, 9, 1, 1.25, 5.2, 125, 0, .98, -6, 9, 2, 0, 0), new e(256, 9, 9, 1, .97, 5.2, 125, 0, 1, -8, 10, 1, 0, 0), new e(320, 9, 9, 1, .9, 5.2, 125, 0, 1, -10, 12, 0, 0, 0)];
+ var f = [new e(0, 9, 9, 0, 5.2, 125, -4.2, -6.3, 4.8, 1, 0, 0, 2, 21, .97), new e(1, 9, 9, 0, 5.3, 125, -3.6, -5.6, 4.5, 1.5, 0, 0, 2, 21, 1.35), new e(2, 9, 9, 0, 5.6, 125, -2.2, -3.5, 2.8, 2, 0, 0, 2, 21, 1.49), new e(3, 9, 9, 1, 5.8, 130, -1.8, -2.8, 2.6, 3, -4, 0, 2, 20, 1.64), new e(4, 9, 9, 1, 6, 135, -.7, -1.1, 1.1, 3.5, -8, 0, 2, 0, 1.79), new e(5, 9, 9, 1, 6.4, 140, .5, .4, -7.5, 4, -12, 2e-4, 0, 0, 1.95), new e(6, 9, 9, 1, 6.6, 145, .67, .65, -14.7, 6.5, -19, 4e-4, 0, 0, 2.3), new e(7, 9, 9, 1, 6.6, 145, .8, .75, -19.7, 8, -22, 6e-4, 0, 0, 2.7), new e(8, 9, 9, 1, 6.6, 145, 1.2, 1.15, -27.5, 10, -23, 7e-4, 0, 0, 0), new e(9, 9, 9, 1, 6.6, 145, 1.6, 1.6, -36, 11, -25, 8e-4, 0, 0, 0), new e(10, 9, 9, 1, 6.6, 145, 2, 2, -36, 12, -25, 8e-4, 0, 0, 0)],
+ c = [new e(0, 9, 9, 0, 4.2, 25, -7, -4, 7.5, 1, 0, 0, 2, 26, .97), new e(1, 9, 9, 0, 4.2, 25, -5.6, -3.6, 4.5, 1.5, 0, 0, 2, 21, 1.35), new e(2, 9, 9, 0, 4.2, 25, -4.4, -1.8, 2, 2, 0, 0, 2, 18, 1.49), new e(3, 9, 9, 1, 4.2, 25, -3.4, -1.25, 1.1, 3, -4, 0, 2, 15, 1.64), new e(4, 9, 9, 1, 4.2, 25, -2.2, .1, 0, 3.5, -8, 0, 2, 0, 1.79), new e(5, 9, 9, 1, 4.2, 25, -1, 1.65, -7.7, 4, -12, 2e-4, 0, 0, 1.95), new e(6, 9, 9, 1, 4.2, 25, -0, 2.47, -7.7, 6.5, -19, 4e-4, 0, 0, 2), new e(7, 9, 9, 1, 4.2, 25, .5, 2, -14.5, 8, -22, 6e-4, 0, 0, 2), new e(8, 9, 9, 1, 4.2, 25, 1, 2.4, -22, 10, -23, 7e-4, 0, 0, 2), new e(9, 9, 9, 1, 4.2, 25, 1.5, 2.95, -30, 11, -25, 8e-4, 0, 0, 2), new e(10, 9, 9, 1, 4.2, 25, 2, 2.95, -36, 12, -30, 8e-4, 0, 0, 2)];
function s(e, t, a) {
- var n = t,
- s = i.nearestBitrateFullIndex(t);
- if (e.VBR = Me.vbr_abr, e.VBR_mean_bitrate_kbps = n, e.VBR_mean_bitrate_kbps = Math.min(e.VBR_mean_bitrate_kbps, 320), e.VBR_mean_bitrate_kbps = Math.max(e.VBR_mean_bitrate_kbps, 8), e.brate = e.VBR_mean_bitrate_kbps, 320 < e.VBR_mean_bitrate_kbps && (e.disable_reservoir = !0), 0 < o[s].safejoint && (e.exp_nspsytune = 2 | e.exp_nspsytune), 0 < o[s].sfscale && (e.internal_flags.noise_shaping = 2), 0 < Math.abs(o[s].nsbass)) {
- var r = int(4 * o[s].nsbass);
+ var s,
+ n,
+ r = e.VBR == xe.vbr_rh ? f : c,
+ i = e.VBR_q_frac,
+ o = r[t],
+ _ = r[t + 1],
+ l = o;
+ o.st_lrm = o.st_lrm + i * (_.st_lrm - o.st_lrm), o.st_s = o.st_s + i * (_.st_s - o.st_s), o.masking_adj = o.masking_adj + i * (_.masking_adj - o.masking_adj), o.masking_adj_short = o.masking_adj_short + i * (_.masking_adj_short - o.masking_adj_short), o.ath_lower = o.ath_lower + i * (_.ath_lower - o.ath_lower), o.ath_curve = o.ath_curve + i * (_.ath_curve - o.ath_curve), o.ath_sensitivity = o.ath_sensitivity + i * (_.ath_sensitivity - o.ath_sensitivity), o.interch = o.interch + i * (_.interch - o.interch), o.msfix = o.msfix + i * (_.msfix - o.msfix), s = e, (n = l.vbr_q) < 0 && (n = 0), 9 < n && (n = 9), s.VBR_q = n, (s.VBR_q_frac = 0) != a ? e.quant_comp = l.quant_comp : 0 < Math.abs(e.quant_comp - -1) || (e.quant_comp = l.quant_comp), 0 != a ? e.quant_comp_short = l.quant_comp_s : 0 < Math.abs(e.quant_comp_short - -1) || (e.quant_comp_short = l.quant_comp_s), 0 != l.expY && (e.experimentalY = 0 != l.expY), 0 != a ? e.internal_flags.nsPsy.attackthre = l.st_lrm : 0 < Math.abs(e.internal_flags.nsPsy.attackthre - -1) || (e.internal_flags.nsPsy.attackthre = l.st_lrm), 0 != a ? e.internal_flags.nsPsy.attackthre_s = l.st_s : 0 < Math.abs(e.internal_flags.nsPsy.attackthre_s - -1) || (e.internal_flags.nsPsy.attackthre_s = l.st_s), 0 != a ? e.maskingadjust = l.masking_adj : 0 < Math.abs(e.maskingadjust - 0) || (e.maskingadjust = l.masking_adj), 0 != a ? e.maskingadjust_short = l.masking_adj_short : 0 < Math.abs(e.maskingadjust_short - 0) || (e.maskingadjust_short = l.masking_adj_short), 0 != a ? e.ATHlower = -l.ath_lower / 10 : 0 < Math.abs(10 * -e.ATHlower - 0) || (e.ATHlower = -l.ath_lower / 10), 0 != a ? e.ATHcurve = l.ath_curve : 0 < Math.abs(e.ATHcurve - -1) || (e.ATHcurve = l.ath_curve), 0 != a ? e.athaa_sensitivity = l.ath_sensitivity : 0 < Math.abs(e.athaa_sensitivity - -1) || (e.athaa_sensitivity = l.ath_sensitivity), 0 < l.interch && (0 != a ? e.interChRatio = l.interch : 0 < Math.abs(e.interChRatio - -1) || (e.interChRatio = l.interch)), 0 < l.safejoint && (e.exp_nspsytune = e.exp_nspsytune | l.safejoint), 0 < l.sfb21mod && (e.exp_nspsytune = e.exp_nspsytune | l.sfb21mod << 20), 0 != a ? e.msfix = l.msfix : 0 < Math.abs(e.msfix - -1) || (e.msfix = l.msfix), 0 == a && (e.VBR_q = t, e.VBR_q_frac = i);
+ }
+ var o = [new t(8, 9, 9, 0, 0, 6.6, 145, 0, .95, 0, -30, 11, .0012, 1), new t(16, 9, 9, 0, 0, 6.6, 145, 0, .95, 0, -25, 11, .001, 1), new t(24, 9, 9, 0, 0, 6.6, 145, 0, .95, 0, -20, 11, .001, 1), new t(32, 9, 9, 0, 0, 6.6, 145, 0, .95, 0, -15, 11, .001, 1), new t(40, 9, 9, 0, 0, 6.6, 145, 0, .95, 0, -10, 11, 9e-4, 1), new t(48, 9, 9, 0, 0, 6.6, 145, 0, .95, 0, -10, 11, 9e-4, 1), new t(56, 9, 9, 0, 0, 6.6, 145, 0, .95, 0, -6, 11, 8e-4, 1), new t(64, 9, 9, 0, 0, 6.6, 145, 0, .95, 0, -2, 11, 8e-4, 1), new t(80, 9, 9, 0, 0, 6.6, 145, 0, .95, 0, 0, 8, 7e-4, 1), new t(96, 9, 9, 0, 2.5, 6.6, 145, 0, .95, 0, 1, 5.5, 6e-4, 1), new t(112, 9, 9, 0, 2.25, 6.6, 145, 0, .95, 0, 2, 4.5, 5e-4, 1), new t(128, 9, 9, 0, 1.95, 6.4, 140, 0, .95, 0, 3, 4, 2e-4, 1), new t(160, 9, 9, 1, 1.79, 6, 135, 0, .95, -2, 5, 3.5, 0, 1), new t(192, 9, 9, 1, 1.49, 5.6, 125, 0, .97, -4, 7, 3, 0, 0), new t(224, 9, 9, 1, 1.25, 5.2, 125, 0, .98, -6, 9, 2, 0, 0), new t(256, 9, 9, 1, .97, 5.2, 125, 0, 1, -8, 10, 1, 0, 0), new t(320, 9, 9, 1, .9, 5.2, 125, 0, 1, -10, 12, 0, 0, 0)];
+ function n(e, t, a) {
+ var s = t,
+ n = i.nearestBitrateFullIndex(t);
+ if (e.VBR = xe.vbr_abr, e.VBR_mean_bitrate_kbps = s, e.VBR_mean_bitrate_kbps = Math.min(e.VBR_mean_bitrate_kbps, 320), e.VBR_mean_bitrate_kbps = Math.max(e.VBR_mean_bitrate_kbps, 8), e.brate = e.VBR_mean_bitrate_kbps, 320 < e.VBR_mean_bitrate_kbps && (e.disable_reservoir = !0), 0 < o[n].safejoint && (e.exp_nspsytune = 2 | e.exp_nspsytune), 0 < o[n].sfscale && (e.internal_flags.noise_shaping = 2), 0 < Math.abs(o[n].nsbass)) {
+ var r = int(4 * o[n].nsbass);
r < 0 && (r += 64), e.exp_nspsytune = e.exp_nspsytune | r << 2;
}
- return 0 != a ? e.quant_comp = o[s].quant_comp : 0 < Math.abs(e.quant_comp - -1) || (e.quant_comp = o[s].quant_comp), 0 != a ? e.quant_comp_short = o[s].quant_comp_s : 0 < Math.abs(e.quant_comp_short - -1) || (e.quant_comp_short = o[s].quant_comp_s), 0 != a ? e.msfix = o[s].nsmsfix : 0 < Math.abs(e.msfix - -1) || (e.msfix = o[s].nsmsfix), 0 != a ? e.internal_flags.nsPsy.attackthre = o[s].st_lrm : 0 < Math.abs(e.internal_flags.nsPsy.attackthre - -1) || (e.internal_flags.nsPsy.attackthre = o[s].st_lrm), 0 != a ? e.internal_flags.nsPsy.attackthre_s = o[s].st_s : 0 < Math.abs(e.internal_flags.nsPsy.attackthre_s - -1) || (e.internal_flags.nsPsy.attackthre_s = o[s].st_s), 0 != a ? e.scale = o[s].scale : 0 < Math.abs(e.scale - -1) || (e.scale = o[s].scale), 0 != a ? e.maskingadjust = o[s].masking_adj : 0 < Math.abs(e.maskingadjust - 0) || (e.maskingadjust = o[s].masking_adj), 0 < o[s].masking_adj ? 0 != a ? e.maskingadjust_short = .9 * o[s].masking_adj : 0 < Math.abs(e.maskingadjust_short - 0) || (e.maskingadjust_short = .9 * o[s].masking_adj) : 0 != a ? e.maskingadjust_short = 1.1 * o[s].masking_adj : 0 < Math.abs(e.maskingadjust_short - 0) || (e.maskingadjust_short = 1.1 * o[s].masking_adj), 0 != a ? e.ATHlower = -o[s].ath_lower / 10 : 0 < Math.abs(10 * -e.ATHlower - 0) || (e.ATHlower = -o[s].ath_lower / 10), 0 != a ? e.ATHcurve = o[s].ath_curve : 0 < Math.abs(e.ATHcurve - -1) || (e.ATHcurve = o[s].ath_curve), 0 != a ? e.interChRatio = o[s].interch : 0 < Math.abs(e.interChRatio - -1) || (e.interChRatio = o[s].interch), t;
+ return 0 != a ? e.quant_comp = o[n].quant_comp : 0 < Math.abs(e.quant_comp - -1) || (e.quant_comp = o[n].quant_comp), 0 != a ? e.quant_comp_short = o[n].quant_comp_s : 0 < Math.abs(e.quant_comp_short - -1) || (e.quant_comp_short = o[n].quant_comp_s), 0 != a ? e.msfix = o[n].nsmsfix : 0 < Math.abs(e.msfix - -1) || (e.msfix = o[n].nsmsfix), 0 != a ? e.internal_flags.nsPsy.attackthre = o[n].st_lrm : 0 < Math.abs(e.internal_flags.nsPsy.attackthre - -1) || (e.internal_flags.nsPsy.attackthre = o[n].st_lrm), 0 != a ? e.internal_flags.nsPsy.attackthre_s = o[n].st_s : 0 < Math.abs(e.internal_flags.nsPsy.attackthre_s - -1) || (e.internal_flags.nsPsy.attackthre_s = o[n].st_s), 0 != a ? e.scale = o[n].scale : 0 < Math.abs(e.scale - -1) || (e.scale = o[n].scale), 0 != a ? e.maskingadjust = o[n].masking_adj : 0 < Math.abs(e.maskingadjust - 0) || (e.maskingadjust = o[n].masking_adj), 0 < o[n].masking_adj ? 0 != a ? e.maskingadjust_short = .9 * o[n].masking_adj : 0 < Math.abs(e.maskingadjust_short - 0) || (e.maskingadjust_short = .9 * o[n].masking_adj) : 0 != a ? e.maskingadjust_short = 1.1 * o[n].masking_adj : 0 < Math.abs(e.maskingadjust_short - 0) || (e.maskingadjust_short = 1.1 * o[n].masking_adj), 0 != a ? e.ATHlower = -o[n].ath_lower / 10 : 0 < Math.abs(10 * -e.ATHlower - 0) || (e.ATHlower = -o[n].ath_lower / 10), 0 != a ? e.ATHcurve = o[n].ath_curve : 0 < Math.abs(e.ATHcurve - -1) || (e.ATHcurve = o[n].ath_curve), 0 != a ? e.interChRatio = o[n].interch : 0 < Math.abs(e.interChRatio - -1) || (e.interChRatio = o[n].interch), t;
}
this.apply_preset = function (e, t, a) {
switch (t) {
- case Y.R3MIX:
- t = Y.V3, e.VBR = Me.vbr_mtrh;
+ case U.R3MIX:
+ t = U.V3, e.VBR = xe.vbr_mtrh;
break;
- case Y.MEDIUM:
- t = Y.V4, e.VBR = Me.vbr_rh;
+ case U.MEDIUM:
+ t = U.V4, e.VBR = xe.vbr_rh;
break;
- case Y.MEDIUM_FAST:
- t = Y.V4, e.VBR = Me.vbr_mtrh;
+ case U.MEDIUM_FAST:
+ t = U.V4, e.VBR = xe.vbr_mtrh;
break;
- case Y.STANDARD:
- t = Y.V2, e.VBR = Me.vbr_rh;
+ case U.STANDARD:
+ t = U.V2, e.VBR = xe.vbr_rh;
break;
- case Y.STANDARD_FAST:
- t = Y.V2, e.VBR = Me.vbr_mtrh;
+ case U.STANDARD_FAST:
+ t = U.V2, e.VBR = xe.vbr_mtrh;
break;
- case Y.EXTREME:
- t = Y.V0, e.VBR = Me.vbr_rh;
+ case U.EXTREME:
+ t = U.V0, e.VBR = xe.vbr_rh;
break;
- case Y.EXTREME_FAST:
- t = Y.V0, e.VBR = Me.vbr_mtrh;
+ case U.EXTREME_FAST:
+ t = U.V0, e.VBR = xe.vbr_mtrh;
break;
- case Y.INSANE:
- return t = 320, e.preset = t, s(e, t, a), e.VBR = Me.vbr_off, t;
+ case U.INSANE:
+ return t = 320, e.preset = t, n(e, t, a), e.VBR = xe.vbr_off, t;
}
switch (e.preset = t) {
- case Y.V9:
- return n(), t;
- case Y.V8:
- return n(), t;
- case Y.V7:
- return n(), t;
- case Y.V6:
- return n(), t;
- case Y.V5:
- return n(), t;
- case Y.V4:
- return n(), t;
- case Y.V3:
- return n(), t;
- case Y.V2:
- return n(), t;
- case Y.V1:
- return n(), t;
- case Y.V0:
- return n(), t;
+ case U.V9:
+ return s(e, 9, a), t;
+ case U.V8:
+ return s(e, 8, a), t;
+ case U.V7:
+ return s(e, 7, a), t;
+ case U.V6:
+ return s(e, 6, a), t;
+ case U.V5:
+ return s(e, 5, a), t;
+ case U.V4:
+ return s(e, 4, a), t;
+ case U.V3:
+ return s(e, 3, a), t;
+ case U.V2:
+ return s(e, 2, a), t;
+ case U.V1:
+ return s(e, 1, a), t;
+ case U.V0:
+ return s(e, 0, a), t;
}
- return 8 <= t && t <= 320 ? s(e, t, a) : (e.preset = 0, t);
+ return 8 <= t && t <= 320 ? n(e, t, a) : (e.preset = 0, t);
};
}(),
- _ = new T(),
- l = new C(),
- f = new y(),
+ _ = new x(),
+ l = new w(),
+ f = new M(),
c = new function () {
- this.getLameShortVersion = function () {
+ this.getLameVersion = function () {
return "3.98.4";
+ }, this.getLameShortVersion = function () {
+ return "3.98.4";
+ }, this.getLameVeryShortVersion = function () {
+ return "LAME3.98r";
+ }, this.getPsyVersion = function () {
+ return "0.93";
+ }, this.getLameUrl = function () {
+ return "http://www.mp3dev.org/";
+ }, this.getLameOsBitness = function () {
+ return "32bits";
};
}(),
- u = new function () {
- this.setModules = function (e, t) {};
- }(),
h = new function () {
+ this.setModules = function (e, t) {};
+ }(),
+ u = new function () {
var _;
this.setModules = function (e) {
_ = e;
}, this.ResvFrameBegin = function (e, t) {
var a,
- n = e.internal_flags,
- s = n.l3_side,
+ s = e.internal_flags,
+ n = s.l3_side,
r = _.getframebits(e);
- t.bits = (r - 8 * n.sideinfo_len) / n.mode_gr;
- var i = 2048 * n.mode_gr - 8;
- 320 < e.brate ? me() : (a = 11520, e.strict_ISO && me()), n.ResvMax = a - r, n.ResvMax > i && (n.ResvMax = i), (n.ResvMax < 0 || e.disable_reservoir) && (n.ResvMax = 0);
- var o = t.bits * n.mode_gr + Math.min(n.ResvSize, n.ResvMax);
- return a < o && (o = a), s.resvDrain_pre = 0, null != n.pinfo && me(), o;
- }, this.ResvMaxBits = function (e, t, a, n) {
- var s,
+ t.bits = (r - 8 * s.sideinfo_len) / s.mode_gr;
+ var i = 2048 * s.mode_gr - 8;
+ 320 < e.brate ? a = 8 * int(1e3 * e.brate / (e.out_samplerate / 1152) / 8 + .5) : (a = 11520, e.strict_ISO && (a = 8 * int(32e4 / (e.out_samplerate / 1152) / 8 + .5))), s.ResvMax = a - r, s.ResvMax > i && (s.ResvMax = i), (s.ResvMax < 0 || e.disable_reservoir) && (s.ResvMax = 0);
+ var o = t.bits * s.mode_gr + Math.min(s.ResvSize, s.ResvMax);
+ return a < o && (o = a), n.resvDrain_pre = 0, null != s.pinfo && (s.pinfo.mean_bits = t.bits / 2, s.pinfo.resvsize = s.ResvSize), o;
+ }, this.ResvMaxBits = function (e, t, a, s) {
+ var n,
r = e.internal_flags,
i = r.ResvSize,
o = r.ResvMax;
- 0 != n && (i += t), 0 != (1 & r.substep_shaping) && (o *= .9), a.bits = t, 9 * o < 10 * i ? (s = i - 9 * o / 10, a.bits += s, r.substep_shaping |= 128) : (s = 0, r.substep_shaping &= 127, e.disable_reservoir || 0 != (1 & r.substep_shaping) || (a.bits -= .1 * t));
+ 0 != s && (i += t), 0 != (1 & r.substep_shaping) && (o *= .9), a.bits = t, 9 * o < 10 * i ? (n = i - 9 * o / 10, a.bits += n, r.substep_shaping |= 128) : (n = 0, r.substep_shaping &= 127, e.disable_reservoir || 0 != (1 & r.substep_shaping) || (a.bits -= .1 * t));
var _ = i < 6 * r.ResvMax / 10 ? i : 6 * r.ResvMax / 10;
- return (_ -= s) < 0 && (_ = 0), _;
+ return (_ -= n) < 0 && (_ = 0), _;
}, this.ResvAdjust = function (e, t) {
e.ResvSize -= t.part2_3_length + t.part2_length;
}, this.ResvFrameEnd = function (e, t) {
var a,
- n = e.l3_side;
+ s = e.l3_side;
e.ResvSize += t * e.mode_gr;
- var s = 0;
- n.resvDrain_post = 0, (n.resvDrain_pre = 0) != (a = e.ResvSize % 8) && (s += a), 0 < (a = e.ResvSize - s - e.ResvMax) && (s += a);
- var r = Math.min(8 * n.main_data_begin, s) / 8;
- n.resvDrain_pre += 8 * r, s -= 8 * r, e.ResvSize -= 8 * r, n.main_data_begin -= r, n.resvDrain_post += s, e.ResvSize -= s;
+ var n = 0;
+ s.resvDrain_post = 0, (s.resvDrain_pre = 0) != (a = e.ResvSize % 8) && (n += a), 0 < (a = e.ResvSize - n - e.ResvMax) && (n += a);
+ var r = Math.min(8 * s.main_data_begin, n) / 8;
+ s.resvDrain_pre += 8 * r, n -= 8 * r, e.ResvSize -= 8 * r, s.main_data_begin -= r, s.resvDrain_post += n, e.ResvSize -= n;
};
}(),
- b = new A(),
+ m = new k(),
p = new function () {
this.setModules = function (e, t, a) {};
}(),
- m = new function () {}();
- s.setModules(r, i, o, _, l, f, c, u, m), i.setModules(r, m, c, f), u.setModules(i, c), o.setModules(s), l.setModules(i, h, _, b), _.setModules(b, h, s.enc.psy), h.setModules(i), b.setModules(_), f.setModules(s, i, c), a.setModules(p, m), p.setModules(c, u, o);
- var v = s.lame_init();
- v.num_channels = n, v.in_samplerate = e, v.out_samplerate = e, v.brate = t, v.mode = ye.STEREO, v.quality = 3, v.bWriteVbrTag = !1, v.disable_reservoir = !0, v.write_id3tag_automatic = !1, s.lame_init_params(v);
+ b = new function () {}();
+ n.setModules(r, i, o, _, l, f, c, h, b), i.setModules(r, b, c, f), h.setModules(i, c), o.setModules(n), l.setModules(i, u, _, m), _.setModules(m, u, n.enc.psy), u.setModules(i), m.setModules(_), f.setModules(n, i, c), a.setModules(p, b), p.setModules(c, h, o);
+ var v = n.lame_init();
+ v.num_channels = s, v.in_samplerate = e, v.out_samplerate = e, v.brate = t, v.mode = Ee.STEREO, v.quality = 3, v.bWriteVbrTag = !1, v.disable_reservoir = !0, v.write_id3tag_automatic = !1, n.lame_init_params(v);
var d = 1152,
g = 0 | 1.25 * d + 7200,
- w = S(g);
+ S = A(g);
this.encodeBuffer = function (e, t) {
- 1 == n && (t = e), e.length > d && (d = e.length, w = S(g = 0 | 1.25 * d + 7200));
- var a = s.lame_encode_buffer(v, e, t, e.length, w, 0, g);
- return new Int8Array(w.subarray(0, a));
+ 1 == s && (t = e), e.length > d && (d = e.length, S = A(g = 0 | 1.25 * d + 7200));
+ var a = n.lame_encode_buffer(v, e, t, e.length, S, 0, g);
+ return new Int8Array(S.subarray(0, a));
}, this.flush = function () {
- var e = s.lame_encode_flush(v, w, 0, g);
- return new Int8Array(w.subarray(0, e));
+ var e = n.lame_encode_flush(v, S, 0, g);
+ return new Int8Array(S.subarray(0, e));
};
};
}
- t(), e.lamejs = t;
-}(("object" == typeof window && window.document ? window : Object).Recorder);
+ t(), Recorder.lamejs = t;
+}();
});
/*
录音 Recorder扩展,动态波形显示
https://github.com/xiangyuecn/Recorder
*/
-(function (factory) {
- var browser = typeof window == "object" && !!window.document;
- var win = browser ? window : Object; //非浏览器环境,Recorder挂载在Object下面
- var rec = win.Recorder,
- ni = rec.i18n;
- factory(rec, ni, ni.$T, browser);
-})(function (Recorder, i18n, $T, isBrowser) {
-
+(function () {
var WaveView = function (set) {
return new fn(set);
};
@@ -15518,12 +15843,7 @@ https://github.com/xiangyuecn/Recorder
,width:0 //显示宽度
,height:0 //显示高度
- H5环境以上配置二选一
-
- compatibleCanvas: CanvasObject //提供一个兼容H5的canvas对象,需支持getContext("2d"),支持设置width、height,支持drawImage(canvas,...)
- ,width:0 //canvas显示宽度
- ,height:0 //canvas显示高度
- 非H5环境使用以上配置
+ 以上配置二选一
*/
scale: 2 //缩放系数,应为正整数,使用2(3? no!)倍宽高进行绘制,避免移动端绘制模糊
@@ -15552,44 +15872,38 @@ https://github.com/xiangyuecn/Recorder
o[k] = set[k];
}
This.set = set = o;
- var cCanvas = "compatibleCanvas";
- if (set[cCanvas]) {
- var canvas = This.canvas = set[cCanvas];
- } else {
- if (!isBrowser) throw new Error($T.G("NonBrowser-1", [ViewTxt]));
- var elem = set.elem;
- if (elem) {
- if (typeof elem == "string") {
- elem = document.querySelector(elem);
- } else if (elem.length) {
- elem = elem[0];
- }
- }
- if (elem) {
- set.width = elem.offsetWidth;
- set.height = elem.offsetHeight;
- }
- var thisElem = This.elem = document.createElement("div");
- thisElem.style.fontSize = 0;
- thisElem.innerHTML = '';
- var canvas = This.canvas = thisElem.querySelector("canvas");
- if (elem) {
- elem.innerHTML = "";
- elem.appendChild(thisElem);
+ var elem = set.elem;
+ if (elem) {
+ if (typeof elem == "string") {
+ elem = document.querySelector(elem);
+ } else if (elem.length) {
+ elem = elem[0];
}
}
+ if (elem) {
+ set.width = elem.offsetWidth;
+ set.height = elem.offsetHeight;
+ }
var scale = set.scale;
var width = set.width * scale;
var height = set.height * scale;
if (!width || !height) {
- throw new Error($T.G("IllegalArgs-1", [ViewTxt + " width=0 height=0"]));
+ throw new Error(ViewTxt + "无宽高");
}
+ var thisElem = This.elem = document.createElement("div");
+ var lowerCss = ["", "transform-origin:0 0;", "transform:scale(" + 1 / scale + ");"];
+ thisElem.innerHTML = '
';
+ var canvas = This.canvas = thisElem.querySelector("canvas");
+ var ctx = This.ctx = canvas.getContext("2d");
canvas.width = width;
canvas.height = height;
- var ctx = This.ctx = canvas.getContext("2d");
This.linear1 = This.genLinear(ctx, width, set.linear1);
This.linear2 = This.genLinear(ctx, width, set.linear2);
This.linearBg = This.genLinear(ctx, height, set.linearBg, true);
+ if (elem) {
+ elem.innerHTML = "";
+ elem.appendChild(thisElem);
+ }
This._phase = 0;
};
fn.prototype = WaveView.prototype = {
@@ -15608,7 +15922,7 @@ https://github.com/xiangyuecn/Recorder
var scale = set.scale;
var width = set.width * scale;
var maxAmplitude = set.height * scale / 2;
- for (var x = 0; x <= width; x += scale) {
+ for (var x = 0; x < width; x += scale) {
var scaling = (1 + Math.cos(Math.PI + x / width * 2 * Math.PI)) / 2;
var y = scaling * maxAmplitude * amplitude * Math.sin(2 * Math.PI * (x / width) * frequency + phase) + maxAmplitude;
rtv.push(y);
@@ -15680,7 +15994,7 @@ https://github.com/xiangyuecn/Recorder
//绘制包围背景
ctx.beginPath();
- for (var i = 0, x = 0; x <= width; i++, x += scale) {
+ for (var i = 0, x = 0; x < width; i++, x += scale) {
if (x == 0) {
ctx.moveTo(x, path1[i]);
} else {
@@ -15706,7 +16020,7 @@ https://github.com/xiangyuecn/Recorder
var scale = set.scale;
var width = set.width * scale;
ctx.beginPath();
- for (var i = 0, x = 0; x <= width; i++, x += scale) {
+ for (var i = 0, x = 0; x < width; i++, x += scale) {
if (x == 0) {
ctx.moveTo(x, path[i]);
} else {
@@ -15719,11 +16033,11 @@ https://github.com/xiangyuecn/Recorder
}
};
Recorder[ViewTxt] = WaveView;
-});
+})();
/*
录音 Recorder扩展,频率直方图显示
-使用本扩展需要引入src/extensions/lib.fft.js支持,直方图特意优化主要显示0-5khz语音部分(线性),其他高频显示区域较小,不适合用来展示音乐频谱,可通过配置fullFreq来恢复成完整的线性频谱,或自行修改源码修改成倍频程频谱(伯德图、对数频谱);本可视化插件可以移植到其他语言环境,如需定制可联系作者
+使用本扩展需要引入lib.fft.js支持,直方图特意优化主要显示0-5khz语音部分(线性),其他高频显示区域较小,不适合用来展示音乐频谱,可自行修改源码恢复成完整的线性频谱,或修改成倍频程频谱(伯德图、对数频谱);本可视化插件可以移植到其他语言环境,如需定制可联系作者
https://github.com/xiangyuecn/Recorder
@@ -15731,13 +16045,7 @@ https://github.com/xiangyuecn/Recorder
https://www.iteye.com/topic/851459
https://sourceforge.net/projects/jmp123/files/
*/
-(function (factory) {
- var browser = typeof window == "object" && !!window.document;
- var win = browser ? window : Object; //非浏览器环境,Recorder挂载在Object下面
- var rec = win.Recorder,
- ni = rec.i18n;
- factory(rec, ni, ni.$T, browser);
-})(function (Recorder, i18n, $T, isBrowser) {
+(function () {
var FrequencyHistogramView = function (set) {
return new fn(set);
@@ -15752,12 +16060,7 @@ https://sourceforge.net/projects/jmp123/files/
,width:0 //显示宽度
,height:0 //显示高度
- H5环境以上配置二选一
-
- compatibleCanvas: CanvasObject //提供一个兼容H5的canvas对象,需支持getContext("2d"),支持设置width、height,支持drawImage(canvas,...)
- ,width:0 //canvas显示宽度
- ,height:0 //canvas显示高度
- 非H5环境使用以上配置
+ 以上配置二选一
*/
scale: 2 //缩放系数,应为正整数,使用2(3? no!)倍宽高进行绘制,避免移动端绘制模糊
@@ -15803,9 +16106,7 @@ https://sourceforge.net/projects/jmp123/files/
stripeShadowBlur: -1 //峰值小横条阴影基础大小,设为0不显示阴影,-1为柱子的大小,如果柱子数量太多时请勿开启,非常影响性能
,
stripeShadowColor: "" //峰值小横条阴影颜色,留空为柱子的阴影颜色
- ,
- fullFreq: false //是否要绘制所有频率;默认false主要绘制5khz以下的频率,高频部分占比很少,此时不同的采样率对频谱显示几乎没有影响;设为true后不同采样率下显示的频谱是不一样的,因为 最大频率=采样率/2 会有差异
//当发生绘制时会回调此方法,参数为当前绘制的频率数据和采样率,可实现多个直方图同时绘制,只消耗一个input输入和计算时间
,
onDraw: function (frequencyData, sampleRate) {}
@@ -15814,43 +16115,37 @@ https://sourceforge.net/projects/jmp123/files/
o[k] = set[k];
}
This.set = set = o;
- var cCanvas = "compatibleCanvas";
- if (set[cCanvas]) {
- var canvas = This.canvas = set[cCanvas];
- } else {
- if (!isBrowser) throw new Error($T.G("NonBrowser-1", [ViewTxt]));
- var elem = set.elem;
- if (elem) {
- if (typeof elem == "string") {
- elem = document.querySelector(elem);
- } else if (elem.length) {
- elem = elem[0];
- }
- }
- if (elem) {
- set.width = elem.offsetWidth;
- set.height = elem.offsetHeight;
- }
- var thisElem = This.elem = document.createElement("div");
- thisElem.style.fontSize = 0;
- thisElem.innerHTML = '';
- var canvas = This.canvas = thisElem.querySelector("canvas");
- if (elem) {
- elem.innerHTML = "";
- elem.appendChild(thisElem);
+ var elem = set.elem;
+ if (elem) {
+ if (typeof elem == "string") {
+ elem = document.querySelector(elem);
+ } else if (elem.length) {
+ elem = elem[0];
}
}
+ if (elem) {
+ set.width = elem.offsetWidth;
+ set.height = elem.offsetHeight;
+ }
var scale = set.scale;
var width = set.width * scale;
var height = set.height * scale;
if (!width || !height) {
- throw new Error($T.G("IllegalArgs-1", [ViewTxt + " width=0 height=0"]));
+ throw new Error(ViewTxt + "无宽高");
}
+ var thisElem = This.elem = document.createElement("div");
+ var lowerCss = ["", "transform-origin:0 0;", "transform:scale(" + 1 / scale + ");"];
+ thisElem.innerHTML = '';
+ var canvas = This.canvas = thisElem.querySelector("canvas");
+ This.ctx = canvas.getContext("2d");
canvas.width = width;
canvas.height = height;
- This.ctx = canvas.getContext("2d");
+ if (elem) {
+ elem.innerHTML = "";
+ elem.appendChild(thisElem);
+ }
if (!Recorder.LibFFT) {
- throw new Error($T.G("NeedImport-2", [ViewTxt, "src/extensions/lib.fft.js"]));
+ throw new Error("需要lib.fft.js支持");
}
This.fft = Recorder.LibFFT(1024);
@@ -15890,9 +16185,6 @@ https://sourceforge.net/projects/jmp123/files/
//超时没有输入,顶部横条已全部落下,干掉定时器
clearInterval(This.timer);
This.timer = 0;
- This.lastH = []; //重置高度再绘制一次,避免定时不准没到底就停了
- This.stripesH = [];
- This.draw(null, This.sampleRate);
return;
}
if (now - drawTime < interval) {
@@ -15944,19 +16236,15 @@ https://sourceforge.net/projects/jmp123/files/
var Y0 = 1 << (Math.round(Math.log(bufferSize) / Math.log(2) + 3) << 1);
var logY0 = Math.log(Y0) / Math.log(10);
var dBmax = 20 * Math.log(0x7fff) / Math.log(10);
- var fftSize = bufferSize / 2,
- fftSize5k = fftSize;
- if (!set.fullFreq) {
- //非绘制所有频率时,计算5khz所在位置,8000采样率及以下最高只有4khz
- fftSize5k = Math.min(fftSize, Math.floor(fftSize * 5000 / (sampleRate / 2)));
- }
- var isFullFreq = fftSize5k == fftSize;
- var line80 = isFullFreq ? lineCount : Math.round(lineCount * 0.8); //80%的柱子位置
+ var fftSize = bufferSize / 2;
+ var fftSize5k = Math.min(fftSize, Math.floor(fftSize * 5000 / (sampleRate / 2))); //5khz所在位置,8000采样率及以下最高只有4khz
+ var fftSize5kIsAll = fftSize5k == fftSize;
+ var line80 = fftSize5kIsAll ? lineCount : Math.round(lineCount * 0.8); //80%的柱子位置
var fftSizeStep1 = fftSize5k / line80;
- var fftSizeStep2 = isFullFreq ? 0 : (fftSize - fftSize5k) / (lineCount - line80);
+ var fftSizeStep2 = fftSize5kIsAll ? 0 : (fftSize - fftSize5k) / (lineCount - line80);
var fftIdx = 0;
for (var i = 0; i < lineCount; i++) {
- // !fullFreq 时不采用jmp123的非线性划分频段,录音语音并不适用于音乐的频率,应当弱化高频部分
+ //不采用jmp123的非线性划分频段,录音语音并不适用于音乐的频率,应当弱化高频部分
//80%关注0-5khz主要人声部分 20%关注剩下的高频,这样不管什么采样率都能做到大部分频率显示一致。
var start = Math.ceil(fftIdx);
if (i < line80) {
@@ -15966,18 +16254,14 @@ https://sourceforge.net/projects/jmp123/files/
//5khz以上
fftIdx += fftSizeStep2;
}
- var end = Math.ceil(fftIdx);
- if (end == start) end++;
- end = Math.min(end, fftSize);
+ var end = Math.min(Math.ceil(fftIdx), fftSize);
//参考AudioGUI.java .drawHistogram方法
//查找当前频段的最大"幅值"
var maxAmp = 0;
- if (frequencyData) {
- for (var j = start; j < end; j++) {
- maxAmp = Math.max(maxAmp, Math.abs(frequencyData[j]));
- }
+ for (var j = start; j < end; j++) {
+ maxAmp = Math.max(maxAmp, Math.abs(frequencyData[j]));
}
//计算音量
@@ -16015,6 +16299,8 @@ https://sourceforge.net/projects/jmp123/files/
var stripeLinear2 = set.stripeLinear && This.genLinear(ctx, set.stripeLinear, originY, originY + heightY) || linear2; //上半部分的峰值小横条填充
//计算柱子间距
+ ctx.shadowBlur = set.shadowBlur * scale;
+ ctx.shadowColor = set.shadowColor;
var mirrorEnable = set.mirrorEnable;
var mirrorCount = mirrorEnable ? lineCount * 2 - 1 : lineCount; //镜像柱子数量翻一倍-1根
@@ -16023,105 +16309,78 @@ https://sourceforge.net/projects/jmp123/files/
if (spaceWidth != 0) {
widthRatio = (width - spaceWidth * (mirrorCount + 1)) / width;
}
- for (var i = 0; i < 2; i++) {
- var lineFloat = Math.max(1 * scale, width * widthRatio / mirrorCount); //柱子宽度至少1个单位
- var lineWN = Math.floor(lineFloat),
- lineWF = lineFloat - lineWN; //提取出小数部分
- var spaceFloat = (width - mirrorCount * lineFloat) / (mirrorCount + 1); //均匀间隔,首尾都留空,可能为负数,柱子将发生重叠
- if (spaceFloat > 0 && spaceFloat < 1) {
- widthRatio = 1;
- spaceFloat = 0; //不够一个像素,丢弃不绘制间隔,重新计算
- } else break;
+ var lineWidth = Math.max(1 * scale, Math.floor(width * widthRatio / mirrorCount)); //柱子宽度至少1个单位
+ var spaceFloat = (width - mirrorCount * lineWidth) / (mirrorCount + 1); //均匀间隔,首尾都留空,可能为负数,柱子将发生重叠
+
+ //绘制柱子
+ var minHeight = set.minHeight * scale;
+ var mirrorSubX = spaceFloat + lineWidth / 2;
+ var XFloat = mirrorEnable ? width / 2 - mirrorSubX : 0; //镜像时,中间柱子位于正中心
+ for (var i = 0, xFloat = XFloat, x, y, h; i < lineCount; i++) {
+ xFloat += spaceFloat;
+ x = Math.floor(xFloat);
+ h = Math.max(lastH[i], minHeight);
+
+ //绘制上半部分
+ if (originY != 0) {
+ y = originY - h;
+ ctx.fillStyle = linear1;
+ ctx.fillRect(x, y, lineWidth, h);
+ }
+ //绘制下半部分
+ if (originY != height) {
+ ctx.fillStyle = linear2;
+ ctx.fillRect(x, originY, lineWidth, h);
+ }
+ xFloat += lineWidth;
}
- //绘制
- var minHeight = set.minHeight * scale;
- var XFloat = mirrorEnable ? (width - lineWN) / 2 - spaceFloat : 0; //镜像时,中间柱子位于正中心
- for (var iMirror = 0; iMirror < 2; iMirror++) {
- if (iMirror) {
- ctx.save();
- ctx.scale(-1, 1);
- }
- var xMirror = iMirror ? width : 0; //绘制镜像部分,不用drawImage(canvas)进行镜像绘制,提升兼容性(iOS微信小程序bug https://developers.weixin.qq.com/community/develop/doc/000aaca2148dc8a235a0fb8c66b000)
-
- //绘制柱子
- ctx.shadowBlur = set.shadowBlur * scale;
- ctx.shadowColor = set.shadowColor;
- for (var i = 0, xFloat = XFloat, wFloat = 0, x, y, w, h; i < lineCount; i++) {
+ //绘制柱子顶上峰值小横条
+ if (set.stripeEnable) {
+ var stripeShadowBlur = set.stripeShadowBlur;
+ ctx.shadowBlur = (stripeShadowBlur == -1 ? set.shadowBlur : stripeShadowBlur) * scale;
+ ctx.shadowColor = set.stripeShadowColor || set.shadowColor;
+ var stripeHeight = set.stripeHeight * scale;
+ for (var i = 0, xFloat = XFloat, x, y, h; i < lineCount; i++) {
xFloat += spaceFloat;
- x = Math.floor(xFloat) - xMirror;
- w = lineWN;
- wFloat += lineWF;
- if (wFloat >= 1) {
- w++;
- wFloat--;
- } //小数凑够1像素
- h = Math.max(lastH[i], minHeight);
+ x = Math.floor(xFloat);
+ h = stripesH[i];
//绘制上半部分
if (originY != 0) {
- y = originY - h;
- ctx.fillStyle = linear1;
- ctx.fillRect(x, y, w, h);
+ y = originY - h - stripeHeight;
+ if (y < 0) {
+ y = 0;
+ }
+ ctx.fillStyle = stripeLinear1;
+ ctx.fillRect(x, y, lineWidth, stripeHeight);
}
//绘制下半部分
if (originY != height) {
- ctx.fillStyle = linear2;
- ctx.fillRect(x, originY, w, h);
- }
- xFloat += w;
- }
-
- //绘制柱子顶上峰值小横条
- if (set.stripeEnable) {
- var stripeShadowBlur = set.stripeShadowBlur;
- ctx.shadowBlur = (stripeShadowBlur == -1 ? set.shadowBlur : stripeShadowBlur) * scale;
- ctx.shadowColor = set.stripeShadowColor || set.shadowColor;
- var stripeHeight = set.stripeHeight * scale;
- for (var i = 0, xFloat = XFloat, wFloat = 0, x, y, w, h; i < lineCount; i++) {
- xFloat += spaceFloat;
- x = Math.floor(xFloat) - xMirror;
- w = lineWN;
- wFloat += lineWF;
- if (wFloat >= 1) {
- w++;
- wFloat--;
- } //小数凑够1像素
- h = stripesH[i];
-
- //绘制上半部分
- if (originY != 0) {
- y = originY - h - stripeHeight;
- if (y < 0) {
- y = 0;
- }
- ctx.fillStyle = stripeLinear1;
- ctx.fillRect(x, y, w, stripeHeight);
+ y = originY + h;
+ if (y + stripeHeight > height) {
+ y = height - stripeHeight;
}
- //绘制下半部分
- if (originY != height) {
- y = originY + h;
- if (y + stripeHeight > height) {
- y = height - stripeHeight;
- }
- ctx.fillStyle = stripeLinear2;
- ctx.fillRect(x, y, w, stripeHeight);
- }
- xFloat += w;
+ ctx.fillStyle = stripeLinear2;
+ ctx.fillRect(x, y, lineWidth, stripeHeight);
}
+ xFloat += lineWidth;
}
- if (iMirror) {
- ctx.restore();
- }
- if (!mirrorEnable) break;
}
- if (frequencyData) {
- set.onDraw(frequencyData, sampleRate);
+
+ //镜像,从中间直接镜像即可
+ if (mirrorEnable) {
+ var srcW = Math.floor(width / 2);
+ ctx.save();
+ ctx.scale(-1, 1);
+ ctx.drawImage(This.canvas, Math.ceil(width / 2), 0, srcW, height, -srcW, 0, srcW, height);
+ ctx.restore();
}
+ set.onDraw(frequencyData, sampleRate);
}
};
Recorder[ViewTxt] = FrequencyHistogramView;
-});
+})();
/*
时域转频域,快速傅里叶变换(FFT)
@@ -16135,111 +16394,104 @@ fft.transform(inBuffer)
inBuffer:[Int16,...] 数组长度必须是bufferSize
返回[Float64(Long),...],长度为bufferSize/2
*/
-(function (factory) {
- var browser = typeof window == "object" && !!window.document;
- var win = browser ? window : Object; //非浏览器环境,Recorder挂载在Object下面
- var rec = win.Recorder,
- ni = rec.i18n;
- factory(rec, ni, ni.$T, browser);
-})(function (Recorder, i18n, $T, isBrowser) {
+
+/*
+从FFT.java 移植,Java开源库:jmp123 版本0.3
+https://www.iteye.com/topic/851459
+https://sourceforge.net/projects/jmp123/files/
+*/
+Recorder.LibFFT = function (bufferSize) {
+
+ var FFT_N_LOG, FFT_N, MINY;
+ var real, imag, sintable, costable;
+ var bitReverse;
+ var FFT_Fn = function (bufferSize) {
+ //bufferSize只能取值2的n次方
+ FFT_N_LOG = Math.round(Math.log(bufferSize) / Math.log(2));
+ FFT_N = 1 << FFT_N_LOG;
+ MINY = (FFT_N << 2) * Math.sqrt(2);
+ real = [];
+ imag = [];
+ sintable = [0];
+ costable = [0];
+ bitReverse = [];
+ var i, j, k, reve;
+ for (i = 0; i < FFT_N; i++) {
+ k = i;
+ for (j = 0, reve = 0; j != FFT_N_LOG; j++) {
+ reve <<= 1;
+ reve |= k & 1;
+ k >>>= 1;
+ }
+ bitReverse[i] = reve;
+ }
+ var theta,
+ dt = 2 * Math.PI / FFT_N;
+ for (i = (FFT_N >> 1) - 1; i > 0; i--) {
+ theta = i * dt;
+ costable[i] = Math.cos(theta);
+ sintable[i] = Math.sin(theta);
+ }
+ };
/*
- 从FFT.java 移植,Java开源库:jmp123 版本0.3
- https://www.iteye.com/topic/851459
- https://sourceforge.net/projects/jmp123/files/
+ 用于频谱显示的快速傅里叶变换
+ inBuffer 输入FFT_N个实数,返回 FFT_N/2个输出值(复数模的平方)。
*/
- Recorder.LibFFT = function (bufferSize) {
- var FFT_N_LOG, FFT_N, MINY;
- var real, imag, sintable, costable;
- var bitReverse;
- var FFT_Fn = function (bufferSize) {
- //bufferSize只能取值2的n次方
- FFT_N_LOG = Math.round(Math.log(bufferSize) / Math.log(2));
- FFT_N = 1 << FFT_N_LOG;
- MINY = (FFT_N << 2) * Math.sqrt(2);
- real = [];
- imag = [];
- sintable = [0];
- costable = [0];
- bitReverse = [];
- var i, j, k, reve;
- for (i = 0; i < FFT_N; i++) {
- k = i;
- for (j = 0, reve = 0; j != FFT_N_LOG; j++) {
- reve <<= 1;
- reve |= k & 1;
- k >>>= 1;
+ var getModulus = function (inBuffer) {
+ var i,
+ j,
+ k,
+ ir,
+ j0 = 1,
+ idx = FFT_N_LOG - 1;
+ var cosv, sinv, tmpr, tmpi;
+ for (i = 0; i != FFT_N; i++) {
+ real[i] = inBuffer[bitReverse[i]];
+ imag[i] = 0;
+ }
+ for (i = FFT_N_LOG; i != 0; i--) {
+ for (j = 0; j != j0; j++) {
+ cosv = costable[j << idx];
+ sinv = sintable[j << idx];
+ for (k = j; k < FFT_N; k += j0 << 1) {
+ ir = k + j0;
+ tmpr = cosv * real[ir] - sinv * imag[ir];
+ tmpi = cosv * imag[ir] + sinv * real[ir];
+ real[ir] = real[k] - tmpr;
+ imag[ir] = imag[k] - tmpi;
+ real[k] += tmpr;
+ imag[k] += tmpi;
}
- bitReverse[i] = reve;
}
- var theta,
- dt = 2 * Math.PI / FFT_N;
- for (i = (FFT_N >> 1) - 1; i > 0; i--) {
- theta = i * dt;
- costable[i] = Math.cos(theta);
- sintable[i] = Math.sin(theta);
- }
- };
-
+ j0 <<= 1;
+ idx--;
+ }
+ j = FFT_N >> 1;
+ var outBuffer = new Float64Array(j);
/*
- 用于频谱显示的快速傅里叶变换
- inBuffer 输入FFT_N个实数,返回 FFT_N/2个输出值(复数模的平方)。
- */
- var getModulus = function (inBuffer) {
- var i,
- j,
- k,
- ir,
- j0 = 1,
- idx = FFT_N_LOG - 1;
- var cosv, sinv, tmpr, tmpi;
- for (i = 0; i != FFT_N; i++) {
- real[i] = inBuffer[bitReverse[i]];
- imag[i] = 0;
- }
- for (i = FFT_N_LOG; i != 0; i--) {
- for (j = 0; j != j0; j++) {
- cosv = costable[j << idx];
- sinv = sintable[j << idx];
- for (k = j; k < FFT_N; k += j0 << 1) {
- ir = k + j0;
- tmpr = cosv * real[ir] - sinv * imag[ir];
- tmpi = cosv * imag[ir] + sinv * real[ir];
- real[ir] = real[k] - tmpr;
- imag[ir] = imag[k] - tmpi;
- real[k] += tmpr;
- imag[k] += tmpi;
- }
- }
- j0 <<= 1;
- idx--;
- }
- j = FFT_N >> 1;
- var outBuffer = new Float64Array(j);
- /*
- * 输出模的平方:
- * for(i = 1; i <= j; i++)
- * inBuffer[i-1] = real[i] * real[i] + imag[i] * imag[i];
- *
- * 如果FFT只用于频谱显示,可以"淘汰"幅值较小的而减少浮点乘法运算. MINY的值
- * 和Spectrum.Y0,Spectrum.logY0对应.
- */
- sinv = MINY;
- cosv = -MINY;
- for (i = j; i != 0; i--) {
- tmpr = real[i];
- tmpi = imag[i];
- if (tmpr > cosv && tmpr < sinv && tmpi > cosv && tmpi < sinv) outBuffer[i - 1] = 0;else outBuffer[i - 1] = Math.round(tmpr * tmpr + tmpi * tmpi);
- }
- return outBuffer;
- };
- FFT_Fn(bufferSize);
- return {
- transform: getModulus,
- bufferSize: FFT_N
- };
+ * 输出模的平方:
+ * for(i = 1; i <= j; i++)
+ * inBuffer[i-1] = real[i] * real[i] + imag[i] * imag[i];
+ *
+ * 如果FFT只用于频谱显示,可以"淘汰"幅值较小的而减少浮点乘法运算. MINY的值
+ * 和Spectrum.Y0,Spectrum.logY0对应.
+ */
+ sinv = MINY;
+ cosv = -MINY;
+ for (i = j; i != 0; i--) {
+ tmpr = real[i];
+ tmpi = imag[i];
+ if (tmpr > cosv && tmpr < sinv && tmpi > cosv && tmpi < sinv) outBuffer[i - 1] = 0;else outBuffer[i - 1] = Math.round(tmpr * tmpr + tmpi * tmpi);
+ }
+ return outBuffer;
};
-});
+ FFT_Fn(bufferSize);
+ return {
+ transform: getModulus,
+ bufferSize: FFT_N
+ };
+};
var playIcon = "";
@@ -16538,7 +16790,9 @@ var script$9 = {
minHeight: 12,
mirrorEnable: true,
stripeEnable: false,
- linear: [0, '#8FC1FD', 1, '#8FC1FD']
+ linear: [0, '#8FC1FD', 1, '#8FC1FD'],
+ width: 300,
+ height: 100
});
this.waveStore.Histogram3 = recorder_mp3_min.FrequencyHistogramView({
elem: elem,
@@ -16548,7 +16802,9 @@ var script$9 = {
fallDuration: 400,
stripeEnable: false,
mirrorEnable: true,
- linear: [0, '#0ac', 1, '#0ac']
+ linear: [0, '#0ac', 1, '#0ac'],
+ width: 300,
+ height: 100
});
},
toggleRec() {
@@ -16585,7 +16841,7 @@ var script$9 = {
rec.open(function () {
_this.dialogCancel();
// _this.reclog("已打开:"+_this.type+" "+_this.sampleRate+"hz "+_this.bitRate+"kbps",2);
-
+ console.log(waveBoxSelector);
// _this.wave=Recorder.WaveView({elem:".ctrlProcessWave"});
_this.initWaveStore(waveBoxSelector);
rec.start();
@@ -16828,7 +17084,7 @@ var __vue_render__$9 = function () {
!_vm.recBolb
? _c("div", {
staticClass: "recwave",
- staticStyle: { height: "75%", width: "100%" },
+ staticStyle: { height: "80px", width: "100%" },
attrs: { id: _vm.waveBoxKey },
})
: _vm._e(),
diff --git a/src/plugin/xml-digital-teaching/lib/imageText.min.css b/src/plugin/xml-digital-teaching/lib/imageText.min.css
index 125dd05..d8957de 100644
--- a/src/plugin/xml-digital-teaching/lib/imageText.min.css
+++ b/src/plugin/xml-digital-teaching/lib/imageText.min.css
@@ -1 +1 @@
-.xml-text-h5 .inline-audio-wrap,.xml-text-h5 .inline-link-wrap{align-items:center}.xml-text-h5 .inline-audio-wrap span,.xml-text-h5 .inline-link-wrap span{display:inline-block}.xml-text-h5 .inline-audio-box{width:20px;height:20px;box-sizing:border-box;position:relative;margin-left:6px}.xml-text-h5 .inline-audio-box .wifi-symbol{width:20px;height:20px;box-sizing:border-box;overflow:hidden;transform:rotate(135deg);position:relative}.xml-text-h5 .inline-audio-box .wifi-symbol .wifi-circle{border:3px solid #418eed;border-radius:50%;position:absolute}.xml-text-h5 .inline-audio-box .wifi-symbol .wifi-circle.first{width:3px;height:3px;background:#0076bc;top:14px;left:14px}.xml-text-h5 .inline-audio-box .wifi-symbol .wifi-circle.second{width:15px;height:15px;top:10px;left:10px}.xml-text-h5 .inline-audio-box .wifi-symbol .wifi-circle.third{width:24px;height:24px;top:6px;left:6px}.xml-text-h5 .inline-audio-box .wifi-symbol.playing .second{animation:fadeInOut 1s infinite .2s}.xml-text-h5 .inline-audio-box .wifi-symbol.playing .third{animation:fadeInOut 1s infinite .4s}@keyframes fadeInOut{0%{opacity:0}100%{opacity:1}}.virtual-input .el-textarea__inner{min-height:0!important;height:0!important;padding:0!important;margin:0!important;border:none!important}.xml-image-lun-bo .el-carousel__item{text-align:center}.el-image__inner[data-v-755c322e]{width:100%!important}.xml-image-ping-pu-h5[data-v-755c322e]{display:flex;flex-direction:column;align-items:center}.xml-image-hua-lang[data-v-755c322e]{display:flex;flex-direction:column;align-items:center}
\ No newline at end of file
+.xml-text-h5 .inline-audio-wrap,.xml-text-h5 .inline-link-wrap{align-items:center}.xml-text-h5 .inline-audio-wrap span,.xml-text-h5 .inline-link-wrap span{display:inline-block}.xml-text-h5 .inline-audio-box{width:20px;height:20px;box-sizing:border-box;position:relative;margin-left:6px}.xml-text-h5 .inline-audio-box .wifi-symbol{width:20px;height:20px;box-sizing:border-box;overflow:hidden;transform:rotate(135deg);position:relative}.xml-text-h5 .inline-audio-box .wifi-symbol .wifi-circle{border:3px solid #418eed;border-radius:50%;position:absolute}.xml-text-h5 .inline-audio-box .wifi-symbol .wifi-circle.first{width:3px;height:3px;background:#0076bc;top:14px;left:14px}.xml-text-h5 .inline-audio-box .wifi-symbol .wifi-circle.second{width:15px;height:15px;top:10px;left:10px}.xml-text-h5 .inline-audio-box .wifi-symbol .wifi-circle.third{width:24px;height:24px;top:6px;left:6px}.xml-text-h5 .inline-audio-box .wifi-symbol.playing .second{animation:fadeInOut 1s infinite .2s}.xml-text-h5 .inline-audio-box .wifi-symbol.playing .third{animation:fadeInOut 1s infinite .4s}@keyframes fadeInOut{0%{opacity:0}100%{opacity:1}}.virtual-input .el-textarea__inner{min-height:0!important;height:0!important;padding:0!important;margin:0!important;border:none!important}.xml-image-lun-bo .el-carousel__item{text-align:center}.el-image__inner[data-v-fb4f6862]{width:100%!important}.xml-image-ping-pu-h5[data-v-fb4f6862]{display:flex;flex-direction:column;align-items:center}.xml-image-hua-lang[data-v-fb4f6862]{display:flex;flex-direction:column;align-items:center}
\ No newline at end of file
diff --git a/src/plugin/xml-digital-teaching/lib/index.css b/src/plugin/xml-digital-teaching/lib/index.css
index c36b105..896c958 100644
--- a/src/plugin/xml-digital-teaching/lib/index.css
+++ b/src/plugin/xml-digital-teaching/lib/index.css
@@ -1,32 +1,32 @@
-.preview-container-h5[data-v-deb005fc] {
+.preview-container-h5[data-v-2ddaab64] {
padding-top: 15px;
}
-.preview-container-pc[data-v-deb005fc] {
+.preview-container-pc[data-v-2ddaab64] {
padding-top: 15px;
}
-.preview-container-pad[data-v-deb005fc] {
+.preview-container-pad[data-v-2ddaab64] {
padding-top: 15px;
}
-.preview-container[data-v-deb005fc] .el-dialog__wrapper.preview-box-dialog {
+.preview-container[data-v-2ddaab64] .el-dialog__wrapper.preview-box-dialog {
display: flex;
align-items: center;
}
-.preview-container[data-v-deb005fc] .el-dialog__wrapper.preview-box-dialog .el-dialog:not(.is-fullscreen) {
+.preview-container[data-v-2ddaab64] .el-dialog__wrapper.preview-box-dialog .el-dialog:not(.is-fullscreen) {
margin-top: 0 !important;
}
-.preview-container[data-v-deb005fc] .el-dialog__wrapper.preview-box-dialog .el-dialog__header {
+.preview-container[data-v-2ddaab64] .el-dialog__wrapper.preview-box-dialog .el-dialog__header {
padding: 0;
}
-.preview-container[data-v-deb005fc] .el-dialog__wrapper.preview-box-dialog .custom-dialog {
+.preview-container[data-v-2ddaab64] .el-dialog__wrapper.preview-box-dialog .custom-dialog {
background-color: transparent;
box-shadow: none;
}
-.preview-container[data-v-deb005fc] .el-dialog__wrapper.preview-box-dialog .el-dialog__body {
+.preview-container[data-v-2ddaab64] .el-dialog__wrapper.preview-box-dialog .el-dialog__body {
padding: 20px 18px;
position: relative;
background: linear-gradient(-45deg, transparent 11px, #fff 0);
}
-.preview-container[data-v-deb005fc] .el-dialog__wrapper.preview-box-dialog .el-dialog__body .top-line {
+.preview-container[data-v-2ddaab64] .el-dialog__wrapper.preview-box-dialog .el-dialog__body .top-line {
position: absolute;
top: 0;
left: 0;
@@ -34,24 +34,24 @@
height: 4px;
background: linear-gradient(90deg, #4994fb, #4994fb, #a2c5f9);
}
-.preview-container[data-v-deb005fc] .el-dialog__wrapper.preview-box-dialog .el-dialog__body .native-html-wrapper {
+.preview-container[data-v-2ddaab64] .el-dialog__wrapper.preview-box-dialog .el-dialog__body .native-html-wrapper {
max-height: 60vh;
overflow-y: scroll;
}
-.preview-container[data-v-deb005fc] .el-dialog__wrapper.preview-box-dialog .el-dialog__body .native-html-wrapper::-webkit-scrollbar {
+.preview-container[data-v-2ddaab64] .el-dialog__wrapper.preview-box-dialog .el-dialog__body .native-html-wrapper::-webkit-scrollbar {
width: 0;
}
-.preview-container[data-v-deb005fc] .el-dialog__wrapper.preview-box-dialog .el-dialog__body .native-html-wrapper h1,
-.preview-container[data-v-deb005fc] .el-dialog__wrapper.preview-box-dialog .el-dialog__body .native-html-wrapper h2,
-.preview-container[data-v-deb005fc] .el-dialog__wrapper.preview-box-dialog .el-dialog__body .native-html-wrapper h3,
-.preview-container[data-v-deb005fc] .el-dialog__wrapper.preview-box-dialog .el-dialog__body .native-html-wrapper h4,
-.preview-container[data-v-deb005fc] .el-dialog__wrapper.preview-box-dialog .el-dialog__body .native-html-wrapper h5,
-.preview-container[data-v-deb005fc] .el-dialog__wrapper.preview-box-dialog .el-dialog__body .native-html-wrapper h6 {
+.preview-container[data-v-2ddaab64] .el-dialog__wrapper.preview-box-dialog .el-dialog__body .native-html-wrapper h1,
+.preview-container[data-v-2ddaab64] .el-dialog__wrapper.preview-box-dialog .el-dialog__body .native-html-wrapper h2,
+.preview-container[data-v-2ddaab64] .el-dialog__wrapper.preview-box-dialog .el-dialog__body .native-html-wrapper h3,
+.preview-container[data-v-2ddaab64] .el-dialog__wrapper.preview-box-dialog .el-dialog__body .native-html-wrapper h4,
+.preview-container[data-v-2ddaab64] .el-dialog__wrapper.preview-box-dialog .el-dialog__body .native-html-wrapper h5,
+.preview-container[data-v-2ddaab64] .el-dialog__wrapper.preview-box-dialog .el-dialog__body .native-html-wrapper h6 {
color: revert;
font-size: revert;
font-weight: revert;
}
-.preview-container[data-v-deb005fc] .el-dialog__wrapper.preview-box-dialog .el-dialog__body .bottom-triangle {
+.preview-container[data-v-2ddaab64] .el-dialog__wrapper.preview-box-dialog .el-dialog__body .bottom-triangle {
position: absolute;
bottom: 0;
right: 0;
@@ -353,14 +353,6 @@
-
-
-
-/*# sourceMappingURL=XmlTextDialog.vue.map */
-
-.xml-show-catalog .el-tree-node__content {
- display: flex !important;
-}
@@ -370,23 +362,17 @@
text-align: center;
}
-.catalog-node-label[data-v-61c986fa] {
- display: flex;
- align-items: center;
-}
-.catalog-node-label img[data-v-61c986fa] {
- margin-right: 4px;
-}
-.xml-show-catalog[data-v-61c986fa] .el-tree-node__content {
- height: auto;
-}
-.xml-show-catalog[data-v-61c986fa] .el-tree-node__content .catalog-node-label {
- max-width: calc(100% - 24px);
- word-break: break-all;
- white-space: normal;
-}
-/*# sourceMappingURL=XmlCatalog.vue.map */
+.xml-text-h5[data-v-5d93942a] {
+}
+.xml-text-pc[data-v-5d93942a] {
+}
+.xml-text-h5[data-v-5d93942a] {
+}
+
+
+
+/*# sourceMappingURL=XmlTextDialog.vue.map */
.xml-text-h5 .inline-audio-wrap,
.xml-text-h5 .inline-link-wrap {
align-items: center;
@@ -457,12 +443,56 @@
}
/*# sourceMappingURL=XmlText.vue.map */
+.preview-item-file[data-v-2be4d8c2]:hover,
+.slip-over-cover[data-v-2be4d8c2]:hover {
+ cursor: pointer;
+}
-.xml-text-h5[data-v-5d93942a] {
+/*# sourceMappingURL=XmlResource.vue.map */
+
+.xml-show-catalog .el-tree-node__content {
+ display: flex !important;
+}
+
+
+.xml-ebook-container-h5[data-v-7ea50222] {
}
-.xml-text-pc[data-v-5d93942a] {
+.xml-ebook-container-pc[data-v-7ea50222] {
}
-.xml-text-h5[data-v-5d93942a] {
+.xml-ebook-container-pad[data-v-7ea50222] {
+}
+
+.catalog-node-label[data-v-61c986fa] {
+ display: flex;
+ align-items: center;
+}
+.catalog-node-label img[data-v-61c986fa] {
+ margin-right: 4px;
+}
+.xml-show-catalog[data-v-61c986fa] .el-tree-node__content {
+ height: auto;
+}
+.xml-show-catalog[data-v-61c986fa] .el-tree-node__content .catalog-node-label {
+ max-width: calc(100% - 24px);
+ word-break: break-all;
+ white-space: normal;
+}
+
+/*# sourceMappingURL=XmlCatalog.vue.map */
+
+.xml-question-container-h5[data-v-2e04d85c] {
+}
+.xml-question-container-pc[data-v-2e04d85c] {
+}
+.xml-question-container-pad[data-v-2e04d85c] {
+}
+
+
+.xml-video-container-h5[data-v-82da5782] {
+}
+.xml-video-container-pc[data-v-82da5782] {
+}
+.xml-video-container-pad[data-v-82da5782] {
}
.xml-video-container-pdf[data-v-3c5e97c1] {
@@ -492,38 +522,11 @@
/*# sourceMappingURL=XmlVideoImg.vue.map */
-.xml-question-container-h5[data-v-0f531fa4] {
-}
-.xml-question-container-pc[data-v-0f531fa4] {
-}
-.xml-question-container-pad[data-v-0f531fa4] {
-}
-
-
/*# sourceMappingURL=XmlTestPaper.vue.map */
-.xml-video-container-h5[data-v-82da5782] {
-}
-.xml-video-container-pc[data-v-82da5782] {
-}
-.xml-video-container-pad[data-v-82da5782] {
-}
-
-.preview-item-file[data-v-2be4d8c2]:hover,
-.slip-over-cover[data-v-2be4d8c2]:hover {
- cursor: pointer;
-}
-/*# sourceMappingURL=XmlResource.vue.map */
-
-.xml-ebook-container-h5[data-v-7ea50222] {
-}
-.xml-ebook-container-pc[data-v-7ea50222] {
-}
-.xml-ebook-container-pad[data-v-7ea50222] {
-}
-
+/*# sourceMappingURL=second.vue.map */
/*# sourceMappingURL=second.vue.map */
@@ -535,10 +538,25 @@
/*# sourceMappingURL=second.vue.map */
-/*# sourceMappingURL=hexagon.vue.map */
+/*# sourceMappingURL=eighth.vue.map */
-/*# sourceMappingURL=second.vue.map */
+/*# sourceMappingURL=isosceles.vue.map */
+
+
+/*# sourceMappingURL=eighth.vue.map */
+
+
+/*# sourceMappingURL=first.vue.map */
+
+
+/*# sourceMappingURL=eighth.vue.map */
+
+
+/*# sourceMappingURL=first.vue.map */
+
+
+/*# sourceMappingURL=ninth.vue.map */
/*# sourceMappingURL=first.vue.map */
@@ -547,37 +565,46 @@
/*# sourceMappingURL=first.vue.map */
-/*# sourceMappingURL=first.vue.map */
+/*# sourceMappingURL=wave.vue.map */
-/*# sourceMappingURL=first.vue.map */
+/*# sourceMappingURL=tenth.vue.map */
+
+
+/*# sourceMappingURL=quadrangle.vue.map */
+
+
+/*# sourceMappingURL=ninth.vue.map */
+
+
+/*# sourceMappingURL=thirteen.vue.map */
+
+
+/*# sourceMappingURL=seventh.vue.map */
+
+
+/*# sourceMappingURL=tenth.vue.map */
+
+
+/*# sourceMappingURL=seventh.vue.map */
+
+
+/*# sourceMappingURL=seventh.vue.map */
+
+
+/*# sourceMappingURL=twelve.vue.map */
/*# sourceMappingURL=fourteen.vue.map */
-/*# sourceMappingURL=sixth.vue.map */
+/*# sourceMappingURL=fifteen.vue.map */
/*# sourceMappingURL=fourteen.vue.map */
-/*# sourceMappingURL=sixth.vue.map */
-
-
-/*# sourceMappingURL=sixth.vue.map */
-
-
-/*# sourceMappingURL=third.vue.map */
-
-
-/*# sourceMappingURL=rotundity.vue.map */
-
-
-/*# sourceMappingURL=third.vue.map */
-
-
-/*# sourceMappingURL=rectangle.vue.map */
+/*# sourceMappingURL=eleven.vue.map */
/*# sourceMappingURL=third.vue.map */
@@ -586,76 +613,55 @@
/*# sourceMappingURL=third.vue.map */
-/*# sourceMappingURL=fifth.vue.map */
-
-
-/*# sourceMappingURL=fifth.vue.map */
+/*# sourceMappingURL=third.vue.map */
/*# sourceMappingURL=fifteen.vue.map */
-/*# sourceMappingURL=semicircle.vue.map */
+/*# sourceMappingURL=Greentheme5.vue.map */
-/*# sourceMappingURL=fifth.vue.map */
-
-
-/*# sourceMappingURL=square.vue.map */
-
-
-/*# sourceMappingURL=fifteen.vue.map */
-
-
-/*# sourceMappingURL=twelfth.vue.map */
-
-
-/*# sourceMappingURL=triangle.vue.map */
-
-
-/*# sourceMappingURL=thirteenth.vue.map */
-
-
-/*# sourceMappingURL=eighteen.vue.map */
-
-
-/*# sourceMappingURL=seventeen.vue.map */
-
-
-/*# sourceMappingURL=Greentheme2.vue.map */
-
-
-/*# sourceMappingURL=nineteen.vue.map */
-
-
-/*# sourceMappingURL=Greentheme2.vue.map */
-
-
-/*# sourceMappingURL=sixteen.vue.map */
-
-
-/*# sourceMappingURL=sixteen.vue.map */
-
-
-/*# sourceMappingURL=Greentheme2.vue.map */
-
-
-/*# sourceMappingURL=eighteen2.vue.map */
+/*# sourceMappingURL=Greentheme5.vue.map */
/*# sourceMappingURL=Greentheme3.vue.map */
-/*# sourceMappingURL=Greentheme3.vue.map */
+/*# sourceMappingURL=third.vue.map */
/*# sourceMappingURL=Greentheme3.vue.map */
-/*# sourceMappingURL=Greentheme1.vue.map */
+/*# sourceMappingURL=Greentheme4.vue.map */
-/*# sourceMappingURL=Greentheme1.vue.map */
+/*# sourceMappingURL=Greentheme4.vue.map */
+
+
+/*# sourceMappingURL=Greentheme4.vue.map */
+
+
+/*# sourceMappingURL=Greentheme3.vue.map */
+
+
+/*# sourceMappingURL=Yellowtheme3.vue.map */
+
+
+/*# sourceMappingURL=Yellowtheme3.vue.map */
+
+
+/*# sourceMappingURL=Yellowtheme3.vue.map */
+
+
+/*# sourceMappingURL=Greentheme2.vue.map */
+
+
+/*# sourceMappingURL=Greentheme2.vue.map */
+
+
+/*# sourceMappingURL=Greentheme2.vue.map */
/*# sourceMappingURL=Yellowtheme1.vue.map */
@@ -667,100 +673,88 @@
/*# sourceMappingURL=Yellowtheme1.vue.map */
+/*# sourceMappingURL=Redtheme1.vue.map */
+
+
+/*# sourceMappingURL=Redtheme1.vue.map */
+
+
+/*# sourceMappingURL=Yellowtheme2.vue.map */
+
+
+/*# sourceMappingURL=Yellowtheme2.vue.map */
+
+
+/*# sourceMappingURL=Yellowtheme2.vue.map */
+
+
+/*# sourceMappingURL=Yellowtheme4.vue.map */
+
+
+/*# sourceMappingURL=Yellowtheme4.vue.map */
+
+
+/*# sourceMappingURL=Redtheme2.vue.map */
+
+
+/*# sourceMappingURL=Yellowtheme4.vue.map */
+
+
+/*# sourceMappingURL=Redtheme2.vue.map */
+
+
+/*# sourceMappingURL=Redtheme5.vue.map */
+
+
+/*# sourceMappingURL=Redtheme3.vue.map */
+
+
+/*# sourceMappingURL=SanQintheme2.vue.map */
+
+
+/*# sourceMappingURL=SanQintheme2.vue.map */
+
+
+/*# sourceMappingURL=Redtheme3.vue.map */
+
+
+/*# sourceMappingURL=Redtheme6.vue.map */
+
+
+/*# sourceMappingURL=Yellowtheme5.vue.map */
+
+
/*# sourceMappingURL=SanQintheme1.vue.map */
/*# sourceMappingURL=SanQintheme1.vue.map */
-/*# sourceMappingURL=Greentheme4.vue.map */
+/*# sourceMappingURL=Yellowtheme5.vue.map */
-/*# sourceMappingURL=Greentheme4.vue.map */
+/*# sourceMappingURL=sixteen.vue.map */
-/*# sourceMappingURL=Greentheme4.vue.map */
+/*# sourceMappingURL=Redtheme4.vue.map */
-/*# sourceMappingURL=Greentheme6.vue.map */
+/*# sourceMappingURL=Redtheme4.vue.map */
-/*# sourceMappingURL=Yellowtheme3.vue.map */
-
-
-/*# sourceMappingURL=Yellowtheme3.vue.map */
-
-
-/*# sourceMappingURL=Yellowtheme2.vue.map */
-
-
-/*# sourceMappingURL=Yellowtheme3.vue.map */
-
-
-/*# sourceMappingURL=Yellowtheme2.vue.map */
-
-
-/*# sourceMappingURL=Yellowtheme2.vue.map */
-
-
-/*# sourceMappingURL=Yellowtheme6.vue.map */
-
-
-/*# sourceMappingURL=Yellowtheme4.vue.map */
-
-
-/*# sourceMappingURL=Yellowtheme4.vue.map */
-
-
-/*# sourceMappingURL=SanQintheme2.vue.map */
-
-
-/*# sourceMappingURL=Yellowtheme4.vue.map */
+/*# sourceMappingURL=sixteen.vue.map */
/*# sourceMappingURL=SanQintheme3.vue.map */
-/*# sourceMappingURL=SanQintheme2.vue.map */
-
-
/*# sourceMappingURL=SanQintheme3.vue.map */
-/*# sourceMappingURL=Greentheme5.vue.map */
-
-
-/*# sourceMappingURL=Yellowtheme5.vue.map */
-
-
-/*# sourceMappingURL=Yellowtheme5.vue.map */
-
-
-/*# sourceMappingURL=Knowledge.vue.map */
-
-
-/*# sourceMappingURL=Greentheme5.vue.map */
-
-
/*# sourceMappingURL=first.vue.map */
-/*# sourceMappingURL=sixth.vue.map */
-
-
-/*# sourceMappingURL=semicircle.vue.map */
-
-
-/*# sourceMappingURL=Greentheme4.vue.map */
-
-
-/*# sourceMappingURL=Yellowtheme5.vue.map */
-
-
-/*# sourceMappingURL=Greentheme1.vue.map */
-
-
-/*# sourceMappingURL=fifteen.vue.map */
+/*# sourceMappingURL=Yellowtheme1.vue.map */
.title-text[data-v-616d10ee] {
background-color: var(--background-color) !important;
}
@@ -772,307 +766,301 @@
/*# sourceMappingURL=third.vue.map */
-/*# sourceMappingURL=rectangle.vue.map */
-
-
-/*# sourceMappingURL=Yellowtheme1.vue.map */
-
-
-/*# sourceMappingURL=twelfth.vue.map */
-
-
-/*# sourceMappingURL=Yellowtheme2.vue.map */
-
-
-/*# sourceMappingURL=thirteenth.vue.map */
+/*# sourceMappingURL=Yellowtheme5.vue.map */
/*# sourceMappingURL=Yellowtheme4.vue.map */
-/*# sourceMappingURL=Yellowtheme6.vue.map */
+/*# sourceMappingURL=Yellowtheme2.vue.map */
-/*# sourceMappingURL=seventeen.vue.map */
+/*# sourceMappingURL=fifteen.vue.map */
-/*# sourceMappingURL=hexagon.vue.map */
-
-
-/*# sourceMappingURL=nineteen.vue.map */
-
-
-/*# sourceMappingURL=sixteen.vue.map */
+/*# sourceMappingURL=Greentheme3.vue.map */
/*# sourceMappingURL=Greentheme2.vue.map */
-/*# sourceMappingURL=Greentheme6.vue.map */
-
-
-/*# sourceMappingURL=Greentheme3.vue.map */
-
-
-/*# sourceMappingURL=Knowledge.vue.map */
-
-
/*# sourceMappingURL=fourteen.vue.map */
-/*# sourceMappingURL=triangle.vue.map */
-
-
-/*# sourceMappingURL=seventh.vue.map */
-
-
-/*# sourceMappingURL=seventh.vue.map */
-
-
-/*# sourceMappingURL=seventh.vue.map */
-
-
-/*# sourceMappingURL=eighth.vue.map */
-
-
-/*# sourceMappingURL=eighth.vue.map */
-
-
-/*# sourceMappingURL=eighth.vue.map */
-
-
-/*# sourceMappingURL=fourth.vue.map */
-
-
-/*# sourceMappingURL=fourth.vue.map */
-
-
-/*# sourceMappingURL=fifth.vue.map */
-
-
-/*# sourceMappingURL=ninth.vue.map */
-
-
-/*# sourceMappingURL=ninth.vue.map */
-
-
-/*# sourceMappingURL=isosceles.vue.map */
-
-
-/*# sourceMappingURL=twelve.vue.map */
-
-
-/*# sourceMappingURL=wave.vue.map */
-
-
-/*# sourceMappingURL=quadrangle.vue.map */
-
-
-/*# sourceMappingURL=thirteen.vue.map */
-
-
-/*# sourceMappingURL=tenth.vue.map */
-
-
-/*# sourceMappingURL=tenth.vue.map */
-
-
-/*# sourceMappingURL=Redtheme6.vue.map */
-
-
-/*# sourceMappingURL=eleven.vue.map */
-
-
-/*# sourceMappingURL=Redtheme3.vue.map */
-
-
-/*# sourceMappingURL=Redtheme3.vue.map */
-
-
-/*# sourceMappingURL=Redtheme3.vue.map */
-
-
-/*# sourceMappingURL=second.vue.map */
-
-
-/*# sourceMappingURL=isosceles.vue.map */
-
-
-/*# sourceMappingURL=ninth.vue.map */
-
-
-/*# sourceMappingURL=first.vue.map */
-
-
-/*# sourceMappingURL=sixteen.vue.map */
-
-
-/*# sourceMappingURL=eighth.vue.map */
-
-
-/*# sourceMappingURL=seventh.vue.map */
-
-
-/*# sourceMappingURL=third.vue.map */
-
-
-/*# sourceMappingURL=thirteen.vue.map */
-
-
-/*# sourceMappingURL=quadrangle.vue.map */
-
-
-/*# sourceMappingURL=tenth.vue.map */
-
-
-/*# sourceMappingURL=eleven.vue.map */
-
-
-/*# sourceMappingURL=Greentheme3.vue.map */
-
-
/*# sourceMappingURL=Greentheme4.vue.map */
-/*# sourceMappingURL=Redtheme2.vue.map */
+/*# sourceMappingURL=sixteen.vue.map */
-/*# sourceMappingURL=Redtheme2.vue.map */
+/*# sourceMappingURL=sixth.vue.map */
-/*# sourceMappingURL=Redtheme2.vue.map */
+/*# sourceMappingURL=sixth.vue.map */
-/*# sourceMappingURL=Redtheme1.vue.map */
+/*# sourceMappingURL=sixth.vue.map */
-/*# sourceMappingURL=Redtheme1.vue.map */
+/*# sourceMappingURL=Redtheme3.vue.map */
-/*# sourceMappingURL=Redtheme1.vue.map */
+/*# sourceMappingURL=sixth.vue.map */
-/*# sourceMappingURL=Redtheme5.vue.map */
+/*# sourceMappingURL=hexagon.vue.map */
+
+
+/*# sourceMappingURL=fifth.vue.map */
+
+
+/*# sourceMappingURL=hexagon.vue.map */
+
+
+/*# sourceMappingURL=fifth.vue.map */
+
+
+/*# sourceMappingURL=fifth.vue.map */
+
+
+/*# sourceMappingURL=fifth.vue.map */
+
+
+/*# sourceMappingURL=rectangle.vue.map */
/*# sourceMappingURL=Redtheme4.vue.map */
-/*# sourceMappingURL=Redtheme4.vue.map */
+/*# sourceMappingURL=rectangle.vue.map */
-/*# sourceMappingURL=Redtheme4.vue.map */
+/*# sourceMappingURL=Redtheme1.vue.map */
+
+
+/*# sourceMappingURL=Redtheme2.vue.map */
+
+
+/*# sourceMappingURL=twelfth.vue.map */
+
+
+/*# sourceMappingURL=twelfth.vue.map */
+
+
+/*# sourceMappingURL=semicircle.vue.map */
+
+
+/*# sourceMappingURL=semicircle.vue.map */
+
+
+/*# sourceMappingURL=square.vue.map */
+
+
+/*# sourceMappingURL=rotundity.vue.map */
+
+
+/*# sourceMappingURL=triangle.vue.map */
+
+
+/*# sourceMappingURL=triangle.vue.map */
+
+
+/*# sourceMappingURL=thirteenth.vue.map */
+
+
+/*# sourceMappingURL=thirteenth.vue.map */
+
+
+/*# sourceMappingURL=seventeen.vue.map */
+
+
+/*# sourceMappingURL=seventeen.vue.map */
+
+
+/*# sourceMappingURL=eighteen2.vue.map */
+
+
+/*# sourceMappingURL=nineteen.vue.map */
+
+
+/*# sourceMappingURL=nineteen.vue.map */
+
+
+/*# sourceMappingURL=eighteen.vue.map */
+
+
+/*# sourceMappingURL=Greentheme1.vue.map */
+
+
+/*# sourceMappingURL=Greentheme1.vue.map */
+
+
+/*# sourceMappingURL=Greentheme1.vue.map */
+
+
+/*# sourceMappingURL=Greentheme6.vue.map */
+
+
+/*# sourceMappingURL=Greentheme6.vue.map */
+
+
+/*# sourceMappingURL=eighth.vue.map */
+
+
+/*# sourceMappingURL=first.vue.map */
+
+
+/*# sourceMappingURL=quadrangle.vue.map */
+
+
+/*# sourceMappingURL=tenth.vue.map */
+
+
+/*# sourceMappingURL=ninth.vue.map */
+
+
+/*# sourceMappingURL=second.vue.map */
+
+
+/*# sourceMappingURL=thirteen.vue.map */
+
+
+/*# sourceMappingURL=third.vue.map */
+
+
+/*# sourceMappingURL=seventh.vue.map */
+
+
+/*# sourceMappingURL=sixteen.vue.map */
+
+
+/*# sourceMappingURL=isosceles.vue.map */
+
+
+/*# sourceMappingURL=Greentheme3.vue.map */
/*# sourceMappingURL=fourteen.vue.map */
+/*# sourceMappingURL=eleven.vue.map */
+
+
+/*# sourceMappingURL=Yellowtheme1.vue.map */
+
+
+/*# sourceMappingURL=Yellowtheme6.vue.map */
+
+
+/*# sourceMappingURL=Yellowtheme6.vue.map */
+
+
+/*# sourceMappingURL=Knowledge.vue.map */
+
+
+/*# sourceMappingURL=Knowledge.vue.map */
+
+
+/*# sourceMappingURL=Greentheme4.vue.map */
+
+
/*# sourceMappingURL=Greentheme2.vue.map */
/*# sourceMappingURL=Greentheme5.vue.map */
-/*# sourceMappingURL=Yellowtheme5.vue.map */
-
-
-/*# sourceMappingURL=Yellowtheme1.vue.map */
-
-
-/*# sourceMappingURL=Yellowtheme4.vue.map */
-
-
/*# sourceMappingURL=Yellowtheme2.vue.map */
-/*# sourceMappingURL=Redtheme4.vue.map */
-
-
/*# sourceMappingURL=Yellowtheme3.vue.map */
+/*# sourceMappingURL=Yellowtheme4.vue.map */
+
+
+/*# sourceMappingURL=Yellowtheme5.vue.map */
+
+
/*# sourceMappingURL=Redtheme1.vue.map */
-/*# sourceMappingURL=Redtheme3.vue.map */
-
-
-/*# sourceMappingURL=Redtheme6.vue.map */
-
-
-/*# sourceMappingURL=Redtheme2.vue.map */
-
-
/*# sourceMappingURL=Redtheme5.vue.map */
-/*# sourceMappingURL=Greytheme2.vue.map */
+/*# sourceMappingURL=Redtheme4.vue.map */
-/*# sourceMappingURL=Greytheme3.vue.map */
+/*# sourceMappingURL=fourth.vue.map */
-/*# sourceMappingURL=Greytheme5.vue.map */
+/*# sourceMappingURL=Redtheme3.vue.map */
+
+
+/*# sourceMappingURL=fourth.vue.map */
+
+
+/*# sourceMappingURL=Redtheme2.vue.map */
+
+
+/*# sourceMappingURL=Redtheme6.vue.map */
+
+
+/*# sourceMappingURL=SanQintheme1.vue.map */
/*# sourceMappingURL=Greytheme1.vue.map */
-/*# sourceMappingURL=eleventh.vue.map */
-
-
-/*# sourceMappingURL=Greytheme6.vue.map */
+/*# sourceMappingURL=Greytheme3.vue.map */
/*# sourceMappingURL=Greytheme4.vue.map */
+/*# sourceMappingURL=Greytheme2.vue.map */
+
+
+/*# sourceMappingURL=Greytheme5.vue.map */
+
+
+/*# sourceMappingURL=Greytheme6.vue.map */
+
+
+/*# sourceMappingURL=eleventh.vue.map */
+
+
/*# sourceMappingURL=twelve.vue.map */
-/*# sourceMappingURL=SanQintheme1.vue.map */
-
-
/*# sourceMappingURL=Bluetheme2.vue.map */
/*# sourceMappingURL=Bluetheme3.vue.map */
+/*# sourceMappingURL=Bluetheme4.vue.map */
+
+
/*# sourceMappingURL=Bluetheme1.vue.map */
/*# sourceMappingURL=first.vue.map */
-/*# sourceMappingURL=fifth.vue.map */
-
-
-/*# sourceMappingURL=seventh.vue.map */
-
-
-/*# sourceMappingURL=sixth.vue.map */
+/*# sourceMappingURL=second.vue.map */
/*# sourceMappingURL=third.vue.map */
-/*# sourceMappingURL=second.vue.map */
+/*# sourceMappingURL=sixth.vue.map */
-/*# sourceMappingURL=fourth.vue.map */
+/*# sourceMappingURL=seventh.vue.map */
-/*# sourceMappingURL=Bluetheme4.vue.map */
-
-
-/*# sourceMappingURL=tenth.vue.map */
-
-
-/*# sourceMappingURL=first.vue.map */
-
-
-/*# sourceMappingURL=second.vue.map */
+/*# sourceMappingURL=fifth.vue.map */
/*# sourceMappingURL=fourth.vue.map */
@@ -1081,49 +1069,64 @@
/*# sourceMappingURL=sixth.vue.map */
+/*# sourceMappingURL=first.vue.map */
+
+
+/*# sourceMappingURL=fourth.vue.map */
+
+
+/*# sourceMappingURL=second.vue.map */
+
+
/*# sourceMappingURL=eleventh.vue.map */
-/*# sourceMappingURL=fifth.vue.map */
-
-
/*# sourceMappingURL=eighth.vue.map */
/*# sourceMappingURL=seventh.vue.map */
+/*# sourceMappingURL=Bluetheme1.vue.map */
+
+
+/*# sourceMappingURL=fifth.vue.map */
+
+
+/*# sourceMappingURL=Greytheme3.vue.map */
+
+
+/*# sourceMappingURL=ninth.vue.map */
+
+
/*# sourceMappingURL=Greytheme2.vue.map */
/*# sourceMappingURL=Redtheme1.vue.map */
+/*# sourceMappingURL=Bluetheme2.vue.map */
+
+
/*# sourceMappingURL=Greytheme5.vue.map */
-/*# sourceMappingURL=Greytheme3.vue.map */
-
-
-/*# sourceMappingURL=Yellowtheme2.vue.map */
-
-
-/*# sourceMappingURL=Bluetheme1.vue.map */
-
-
-/*# sourceMappingURL=Yellowtheme3.vue.map */
-
-
-/*# sourceMappingURL=Redtheme4.vue.map */
+/*# sourceMappingURL=tenth.vue.map */
/*# sourceMappingURL=Greytheme1.vue.map */
-/*# sourceMappingURL=ninth.vue.map */
+/*# sourceMappingURL=Yellowtheme1.vue.map */
-/*# sourceMappingURL=Bluetheme2.vue.map */
+/*# sourceMappingURL=Redtheme4.vue.map */
+
+
+/*# sourceMappingURL=Yellowtheme3.vue.map */
+
+
+/*# sourceMappingURL=Yellowtheme2.vue.map */
.xml-single-ebook-group-h5[data-v-55908341] {
}
@@ -1165,11 +1168,11 @@
}
-.xml-single-text-group-h5[data-v-647015fa] {
+.xml-single-resource-group-h5[data-v-2b4774b7] {
}
-.xml-single-text-group-pc[data-v-647015fa] {
+.xml-single-resource-group-pc[data-v-2b4774b7] {
}
-.xml-single-text-group-pad[data-v-647015fa] {
+.xml-single-resource-group-pad[data-v-2b4774b7] {
}
@@ -1181,11 +1184,14 @@
}
-.xml-single-resource-group-h5[data-v-2b4774b7] {
+
+/*# sourceMappingURL=Bluetheme4.vue.map */
+
+.xml-single-text-group-h5[data-v-647015fa] {
}
-.xml-single-resource-group-pc[data-v-2b4774b7] {
+.xml-single-text-group-pc[data-v-647015fa] {
}
-.xml-single-resource-group-pad[data-v-2b4774b7] {
+.xml-single-text-group-pad[data-v-647015fa] {
}
@@ -1198,31 +1204,16 @@
-/*# sourceMappingURL=Yellowtheme1.vue.map */
-
-
/*# sourceMappingURL=single-agent-group.vue.map */
-/*# sourceMappingURL=Bluetheme4.vue.map */
-
-
/*# sourceMappingURL=Thirtytwo.vue.map */
-/*# sourceMappingURL=Thirtythree.vue.map */
-
-
/*# sourceMappingURL=Thirtyone.vue.map */
-/*# sourceMappingURL=Thirtyfive.vue.map */
-
-
-/*# sourceMappingURL=Thirtyeight.vue.map */
-
-
-/*# sourceMappingURL=Thirtyfour.vue.map */
+/*# sourceMappingURL=Thirtythree.vue.map */
/*# sourceMappingURL=Thirtyseven.vue.map */
@@ -1231,28 +1222,43 @@
/*# sourceMappingURL=Thirtysix.vue.map */
+/*# sourceMappingURL=Thirtyfour.vue.map */
+
+
+/*# sourceMappingURL=Thirtyfive.vue.map */
+
+
+/*# sourceMappingURL=Thirtyeight.vue.map */
+
+
/*# sourceMappingURL=Foldtheme1.vue.map */
/*# sourceMappingURL=Tabstheme1.vue.map */
-/*# sourceMappingURL=Redtheme7.vue.map */
-
-
-/*# sourceMappingURL=Tabstheme3.vue.map */
-
-
/*# sourceMappingURL=Foldtheme3.vue.map */
+/*# sourceMappingURL=Redtheme7.vue.map */
+
+
/*# sourceMappingURL=Foldtheme2.vue.map */
+/*# sourceMappingURL=Foldtheme4.vue.map */
+
+
+/*# sourceMappingURL=Tabstheme4.vue.map */
+
+
+/*# sourceMappingURL=Tabstheme3.vue.map */
+
+
/*# sourceMappingURL=Tabstheme2.vue.map */
-/*# sourceMappingURL=Foldtheme4.vue.map */
+/*# sourceMappingURL=Tabstheme5.vue.map */
/*# sourceMappingURL=Foldtheme5.vue.map */
@@ -1261,68 +1267,113 @@
/*# sourceMappingURL=Fortytwo.vue.map */
-/*# sourceMappingURL=Tabstheme5.vue.map */
-
-
-/*# sourceMappingURL=Tabstheme4.vue.map */
-
-
/*# sourceMappingURL=Tabstheme6.vue.map */
+/*# sourceMappingURL=Fortythree.vue.map */
+
+
/*# sourceMappingURL=Fortyfour.vue.map */
/*# sourceMappingURL=Fortyfive.vue.map */
-/*# sourceMappingURL=Fortythree.vue.map */
-
-
-/*# sourceMappingURL=Twentyfour.vue.map */
+/*# sourceMappingURL=Twentythree.vue.map */
/*# sourceMappingURL=Twentyfive.vue.map */
+/*# sourceMappingURL=Twentysix.vue.map */
+
+
/*# sourceMappingURL=Twentytwo.vue.map */
-/*# sourceMappingURL=Twentysix.vue.map */
+/*# sourceMappingURL=Twentyeight.vue.map */
+
+
+/*# sourceMappingURL=Twentyfour.vue.map */
/*# sourceMappingURL=Twentyseven.vue.map */
-/*# sourceMappingURL=Twentythree.vue.map */
+/*# sourceMappingURL=xmlPopup.vue.map */
-/*# sourceMappingURL=Twentyeight.vue.map */
-.el-image__inner[data-v-755c322e] {
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+/*# sourceMappingURL=xmlWrapperPage.vue.map */
+
+
+/*# sourceMappingURL=xmlCollapse.vue.map */
+
+.el-image__inner[data-v-fb4f6862] {
width: 100% !important;
}
-.xml-image-ping-pu-h5[data-v-755c322e] {
+.xml-image-ping-pu-h5[data-v-fb4f6862] {
display: flex;
flex-direction: column;
align-items: center;
}
-.xml-image-hua-lang[data-v-755c322e] {
+.xml-image-hua-lang[data-v-fb4f6862] {
display: flex;
flex-direction: column;
align-items: center;
}
-
-
-/*# sourceMappingURL=xmlCollapse.vue.map */
-
-
-/*# sourceMappingURL=xmlPopup.vue.map */
-
-
-
-/*# sourceMappingURL=xmlWrapperPage.vue.map */
.preview-container-h5[data-v-25742cb8] {
padding-top: 15px;
}
@@ -1540,150 +1591,6 @@
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
@@ -1794,443 +1701,6 @@
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
@@ -2384,6 +1854,589 @@
}
/*# sourceMappingURL=setPop.vue.map */
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
.el-dialog__header {
background-color: #f2f2f2 !important;
}
@@ -2484,6 +2537,9 @@
+
+/*# sourceMappingURL=QuestionItem.vue.map */
+
/*# sourceMappingURL=QuestionItem.vue.map */
@@ -2775,6 +2831,10 @@
+
+
+
+
@@ -2934,41 +2994,56 @@
-
-
-
-
-.content[data-v-3d2dcb5b] {
- width: 100%;
+.option-item + .option-item[data-v-6b27b5ec] {
+ margin-top: 16px;
}
-.content .stem-content[data-v-3d2dcb5b] {
- width: 100%;
- box-sizing: border-box;
- padding: 5px 14px;
- height: auto;
- border: 1px solid #e7e7e7;
+.option-item[data-v-6b27b5ec] {
+ display: flex;
+ background: #fbfbfb;
border-radius: 6px;
+ padding-left: 16px;
+ cursor: pointer;
+ transition: all ease 0.3s;
+ border: 1px solid #fbfbfb;
+}
+.option-item .questionSeq[data-v-6b27b5ec] {
+ padding: 8px 0;
+}
+.option-item.isActive[data-v-6b27b5ec] {
+ border-color: #2e9adb;
+}
+.option-item.isTrue[data-v-6b27b5ec] {
+ border: 1px solid #70b603;
+}
+.option-item.isTrue[data-v-6b27b5ec] .el-radio__input.is-checked .el-radio__inner {
+ border-color: #70b603;
+ background: #70b603;
+}
+.option-item.isFalse[data-v-6b27b5ec] {
+ border: 1px solid #d9001b;
+}
+.option-item.isFalse[data-v-6b27b5ec] .el-radio__input.is-checked .el-radio__inner {
+ border-color: #d9001b;
+ background: #d9001b;
+}
+.option-item[data-v-6b27b5ec]:hover {
+ background: #ddd;
+}
+.option-item[data-v-6b27b5ec] .content {
cursor: pointer;
}
-.content .stem-content.no-border[data-v-3d2dcb5b] {
- padding: 0;
- border: none;
- cursor: default;
-}
-.content .stem-content .placeholder[data-v-3d2dcb5b] {
- color: #c0c4cc;
- font-size: 14px;
+.option-item[data-v-6b27b5ec] .stem-content.no-border {
+ padding: 8px 14px !important;
cursor: pointer;
- user-select: none;
}
-/*# sourceMappingURL=common.vue.map */
+/*# sourceMappingURL=radio.vue.map */
.option-item + .option-item[data-v-fa728c70] {
margin-top: 16px;
}
@@ -3013,6 +3088,31 @@
}
/*# sourceMappingURL=checkbox.vue.map */
+.content[data-v-3d2dcb5b] {
+ width: 100%;
+}
+.content .stem-content[data-v-3d2dcb5b] {
+ width: 100%;
+ box-sizing: border-box;
+ padding: 5px 14px;
+ height: auto;
+ border: 1px solid #e7e7e7;
+ border-radius: 6px;
+ cursor: pointer;
+}
+.content .stem-content.no-border[data-v-3d2dcb5b] {
+ padding: 0;
+ border: none;
+ cursor: default;
+}
+.content .stem-content .placeholder[data-v-3d2dcb5b] {
+ color: #c0c4cc;
+ font-size: 14px;
+ cursor: pointer;
+ user-select: none;
+}
+
+/*# sourceMappingURL=common.vue.map */
.option-item + .option-item[data-v-7fac7a23] {
margin-top: 16px;
}
@@ -3057,6 +3157,75 @@
}
/*# sourceMappingURL=radio.vue.map */
+.option-item + .option-item[data-v-307b4eb2] {
+ margin-top: 16px;
+}
+.option-item[data-v-307b4eb2] {
+ display: flex;
+ background: #fbfbfb;
+ border-radius: 6px;
+ padding-left: 16px;
+ cursor: pointer;
+ transition: all ease 0.3s;
+ border: 1px solid #fbfbfb;
+}
+.option-item.isActive[data-v-307b4eb2] {
+ border-color: #2e9adb;
+}
+.option-item .questionSeq[data-v-307b4eb2] {
+ padding: 8px 0;
+}
+.option-item.isTrue[data-v-307b4eb2] {
+ border: 1px solid #70b603;
+}
+.option-item.isTrue[data-v-307b4eb2] .el-checkbox__input.is-checked .el-checkbox__inner {
+ border-color: #70b603;
+ background: #70b603;
+}
+.option-item.isFalse[data-v-307b4eb2] {
+ border: 1px solid #d9001b;
+}
+.option-item.isFalse[data-v-307b4eb2] .el-checkbox__input.is-checked .el-checkbox__inner {
+ border-color: #d9001b;
+ background: #d9001b;
+}
+.option-item[data-v-307b4eb2]:hover {
+ background: #ddd;
+}
+.option-item[data-v-307b4eb2] .content {
+ cursor: pointer;
+}
+.option-item[data-v-307b4eb2] .stem-content.no-border {
+ padding: 8px 14px !important;
+ cursor: pointer;
+}
+
+/*# sourceMappingURL=checkbox.vue.map */
+.content[data-v-55ea6f92] {
+ width: 100%;
+}
+.content .stem-content[data-v-55ea6f92] {
+ width: 100%;
+ box-sizing: border-box;
+ padding: 5px 14px;
+ height: auto;
+ border: 1px solid #e7e7e7;
+ border-radius: 6px;
+ cursor: pointer;
+}
+.content .stem-content.no-border[data-v-55ea6f92] {
+ padding: 0;
+ border: none;
+ cursor: default;
+}
+.content .stem-content .placeholder[data-v-55ea6f92] {
+ color: #c0c4cc;
+ font-size: 14px;
+ cursor: pointer;
+ user-select: none;
+}
+
+/*# sourceMappingURL=common.vue.map */
.image-file[data-v-506f1aca] {
width: 218px;
object-fit: scale-down;
@@ -3088,6 +3257,74 @@
}
/*# sourceMappingURL=index.vue.map */
+.image-file[data-v-643cc5f7] {
+ width: 218px;
+ object-fit: scale-down;
+}
+.video-file[data-v-643cc5f7] {
+ width: 408px;
+}
+.file-render[data-v-643cc5f7] {
+ width: 100%;
+}
+.file-info[data-v-643cc5f7] {
+ flex: 1;
+ min-width: 0;
+}
+.file-info.videoHandler[data-v-643cc5f7] {
+ display: flex;
+ flex-direction: column;
+ justify-content: center;
+}
+.file-info.videoHandler .fileName[data-v-643cc5f7] {
+ font-size: 18px;
+ color: #333333;
+ margin-bottom: 19px;
+}
+.file-info.videoHandler .fileInfo[data-v-643cc5f7] {
+ font-size: 14px;
+ color: #666666;
+ margin-bottom: 19px;
+}
+
+/*# sourceMappingURL=index.vue.map */
+[data-v-7628e470] .el-dialog__header {
+ padding: 10px;
+}
+.video-content[data-v-7628e470] {
+ width: 180px;
+ height: 135px;
+ border-radius: 6px;
+ overflow: hidden;
+ position: relative;
+}
+.video-content .play[data-v-7628e470] {
+ position: absolute;
+ left: 50%;
+ top: 50%;
+ cursor: pointer;
+ transform: translateX(-50%) translateY(-50%);
+}
+.video-mask[data-v-7628e470] {
+ position: absolute;
+ left: 0;
+ top: 0;
+ width: 100%;
+ height: 100%;
+ background: rgba(0, 0, 0, 0.5);
+}
+.video-mask img[data-v-7628e470] {
+ position: absolute;
+ left: 50%;
+ top: 50%;
+ transform: translate(-50% -50%);
+ display: block;
+}
+.video-player[data-v-7628e470] {
+ width: 100%;
+}
+
+/*# sourceMappingURL=video-play.vue.map */
.audio .audio-icon[data-v-25355b9e] {
width: 36px;
height: 36px;
@@ -3147,24 +3384,83 @@
}
/*# sourceMappingURL=audio-play-new.vue.map */
-[data-v-7628e470] .el-dialog__header {
+.audio .audio-icon[data-v-160e520c] {
+ width: 36px;
+ height: 36px;
+ margin-right: 20px;
+}
+.audio .audio-icon img[data-v-160e520c] {
+ width: 100%;
+ height: 100%;
+ display: block;
+}
+.audio .audio-controls[data-v-160e520c] {
+ width: 100%;
+ max-width: 200px;
+ flex: 1;
+ height: 36px;
+}
+.audio .audio-controls .audio-controls--progress[data-v-160e520c], .audio .audio-controls .audio-controls--handler[data-v-160e520c] {
+ width: 100%;
+}
+.audio .audio-controls .audio-controls--handler[data-v-160e520c] {
+ line-height: 1;
+}
+.audio .audio-controls .audio-controls--handler .play[data-v-160e520c] {
+ font-size: 24px;
+}
+.audio .audio-controls .audio-controls--handler .play .play-handler[data-v-160e520c] {
+ width: 22px;
+ height: 22px;
+ display: block;
+ cursor: pointer;
+}
+.audio .audio-controls .audio-controls--handler .current-time[data-v-160e520c], .audio .audio-controls .audio-controls--handler .total-time[data-v-160e520c] {
+ font-size: 12px;
+ color: #333;
+}
+.play-handler.mobile[data-v-160e520c] {
+ width: 20px;
+ height: 20px;
+}
+.audio-component[data-v-160e520c] {
+ display: none;
+}
+[data-v-160e520c] .el-slider__runway {
+ margin: 0 0 4px 0;
+ background: #e3e3e3;
+ height: 4px;
+}
+[data-v-160e520c] .el-slider__bar {
+ height: 4px;
+}
+[data-v-160e520c] .el-slider__button {
+ width: 10px;
+ height: 10px;
+}
+[data-v-160e520c] .el-slider__button-wrapper {
+ top: -15px;
+}
+
+/*# sourceMappingURL=audio-play-new.vue.map */
+[data-v-7cccb5ec] .el-dialog__header {
padding: 10px;
}
-.video-content[data-v-7628e470] {
+.video-content[data-v-7cccb5ec] {
width: 180px;
height: 135px;
border-radius: 6px;
overflow: hidden;
position: relative;
}
-.video-content .play[data-v-7628e470] {
+.video-content .play[data-v-7cccb5ec] {
position: absolute;
left: 50%;
top: 50%;
cursor: pointer;
transform: translateX(-50%) translateY(-50%);
}
-.video-mask[data-v-7628e470] {
+.video-mask[data-v-7cccb5ec] {
position: absolute;
left: 0;
top: 0;
@@ -3172,14 +3468,14 @@
height: 100%;
background: rgba(0, 0, 0, 0.5);
}
-.video-mask img[data-v-7628e470] {
+.video-mask img[data-v-7cccb5ec] {
position: absolute;
left: 50%;
top: 50%;
transform: translate(-50% -50%);
display: block;
}
-.video-player[data-v-7628e470] {
+.video-player[data-v-7cccb5ec] {
width: 100%;
}
diff --git a/src/plugin/xml-digital-teaching/lib/index.js b/src/plugin/xml-digital-teaching/lib/index.js
index 10bdcf7..e33619f 100644
--- a/src/plugin/xml-digital-teaching/lib/index.js
+++ b/src/plugin/xml-digital-teaching/lib/index.js
@@ -1,6 +1,6 @@
/*
* XmlDigitalTeaching v0.0.1
-* Copyright ©Wed Jun 19 2024 19:48:48 GMT+0800 (中国标准时间) smile
+* Copyright ©Fri Jun 21 2024 13:16:29 GMT+0800 (中国标准时间) smile
* Released under the ISC License.
*/
import Vue from 'vue';
@@ -19768,7 +19768,7 @@ if (typeof window !== 'undefined' && window.Vue) {
//
//
-var script$4X = {
+var script$52 = {
//预览教材目录
name: 'PreviewCatalogRender',
props: {
@@ -19908,9 +19908,9 @@ function normalizeComponent(template, style, script, scopeId, isFunctionalTempla
}
/* script */
-const __vue_script__$4X = script$4X;
+const __vue_script__$52 = script$52;
/* template */
-var __vue_render__$4X = function () {
+var __vue_render__$52 = function () {
var _vm = this;
var _h = _vm.$createElement;
var _c = _vm._self._c || _h;
@@ -19945,17 +19945,17 @@ var __vue_render__$4X = function () {
1
)
};
-var __vue_staticRenderFns__$4X = [];
-__vue_render__$4X._withStripped = true;
+var __vue_staticRenderFns__$52 = [];
+__vue_render__$52._withStripped = true;
/* style */
- const __vue_inject_styles__$4X = undefined;
+ const __vue_inject_styles__$52 = undefined;
/* scoped */
- const __vue_scope_id__$4X = "data-v-7da5c6fc";
+ const __vue_scope_id__$52 = "data-v-7da5c6fc";
/* module identifier */
- const __vue_module_identifier__$4X = undefined;
+ const __vue_module_identifier__$52 = undefined;
/* functional template */
- const __vue_is_functional_template__$4X = false;
+ const __vue_is_functional_template__$52 = false;
/* style inject */
/* style inject SSR */
@@ -19964,13 +19964,13 @@ __vue_render__$4X._withStripped = true;
- const __vue_component__$4X = /*#__PURE__*/normalizeComponent(
- { render: __vue_render__$4X, staticRenderFns: __vue_staticRenderFns__$4X },
- __vue_inject_styles__$4X,
- __vue_script__$4X,
- __vue_scope_id__$4X,
- __vue_is_functional_template__$4X,
- __vue_module_identifier__$4X,
+ const __vue_component__$52 = /*#__PURE__*/normalizeComponent(
+ { render: __vue_render__$52, staticRenderFns: __vue_staticRenderFns__$52 },
+ __vue_inject_styles__$52,
+ __vue_script__$52,
+ __vue_scope_id__$52,
+ __vue_is_functional_template__$52,
+ __vue_module_identifier__$52,
false,
undefined,
undefined,
@@ -28953,7 +28953,7 @@ var jquery = createCommonjsModule(function (module) {
});
//
-var script$4W = {
+var script$51 = {
name: 'PreviewLooseLeafRender',
props: {
businessType: String,
@@ -29082,9 +29082,9 @@ var script$4W = {
};
/* script */
-const __vue_script__$4W = script$4W;
+const __vue_script__$51 = script$51;
/* template */
-var __vue_render__$4W = function () {
+var __vue_render__$51 = function () {
var _vm = this;
var _h = _vm.$createElement;
var _c = _vm._self._c || _h;
@@ -29173,17 +29173,17 @@ var __vue_render__$4W = function () {
),
])
};
-var __vue_staticRenderFns__$4W = [];
-__vue_render__$4W._withStripped = true;
+var __vue_staticRenderFns__$51 = [];
+__vue_render__$51._withStripped = true;
/* style */
- const __vue_inject_styles__$4W = undefined;
+ const __vue_inject_styles__$51 = undefined;
/* scoped */
- const __vue_scope_id__$4W = "data-v-25742cb8";
+ const __vue_scope_id__$51 = "data-v-25742cb8";
/* module identifier */
- const __vue_module_identifier__$4W = undefined;
+ const __vue_module_identifier__$51 = undefined;
/* functional template */
- const __vue_is_functional_template__$4W = false;
+ const __vue_is_functional_template__$51 = false;
/* style inject */
/* style inject SSR */
@@ -29192,13 +29192,13 @@ __vue_render__$4W._withStripped = true;
- const __vue_component__$4W = /*#__PURE__*/normalizeComponent(
- { render: __vue_render__$4W, staticRenderFns: __vue_staticRenderFns__$4W },
- __vue_inject_styles__$4W,
- __vue_script__$4W,
- __vue_scope_id__$4W,
- __vue_is_functional_template__$4W,
- __vue_module_identifier__$4W,
+ const __vue_component__$51 = /*#__PURE__*/normalizeComponent(
+ { render: __vue_render__$51, staticRenderFns: __vue_staticRenderFns__$51 },
+ __vue_inject_styles__$51,
+ __vue_script__$51,
+ __vue_scope_id__$51,
+ __vue_is_functional_template__$51,
+ __vue_module_identifier__$51,
false,
undefined,
undefined,
@@ -29248,11 +29248,11 @@ Array.prototype.Remove = function (item, all) {
}
return result ? this : void 0;
};
-var script$4V = {
+var script$50 = {
name: 'XmlRender',
components: {
- PreviewLooseLeafRender: __vue_component__$4W,
- PreviewCatalogRender: __vue_component__$4X
+ PreviewLooseLeafRender: __vue_component__$51,
+ PreviewCatalogRender: __vue_component__$52
},
props: {
uuid: {
@@ -29644,9 +29644,9 @@ var script$4V = {
};
/* script */
-const __vue_script__$4V = script$4V;
+const __vue_script__$50 = script$50;
/* template */
-var __vue_render__$4V = function () {
+var __vue_render__$50 = function () {
var _vm = this;
var _h = _vm.$createElement;
var _c = _vm._self._c || _h;
@@ -29829,17 +29829,17 @@ var __vue_render__$4V = function () {
: _c("div", { attrs: { id: "out" } }, [_vm._v("预览地址已失效")]),
])
};
-var __vue_staticRenderFns__$4V = [];
-__vue_render__$4V._withStripped = true;
+var __vue_staticRenderFns__$50 = [];
+__vue_render__$50._withStripped = true;
/* style */
- const __vue_inject_styles__$4V = undefined;
+ const __vue_inject_styles__$50 = undefined;
/* scoped */
- const __vue_scope_id__$4V = undefined;
+ const __vue_scope_id__$50 = undefined;
/* module identifier */
- const __vue_module_identifier__$4V = undefined;
+ const __vue_module_identifier__$50 = undefined;
/* functional template */
- const __vue_is_functional_template__$4V = false;
+ const __vue_is_functional_template__$50 = false;
/* style inject */
/* style inject SSR */
@@ -29848,23 +29848,23 @@ __vue_render__$4V._withStripped = true;
- const __vue_component__$4V = /*#__PURE__*/normalizeComponent(
- { render: __vue_render__$4V, staticRenderFns: __vue_staticRenderFns__$4V },
- __vue_inject_styles__$4V,
- __vue_script__$4V,
- __vue_scope_id__$4V,
- __vue_is_functional_template__$4V,
- __vue_module_identifier__$4V,
+ const __vue_component__$50 = /*#__PURE__*/normalizeComponent(
+ { render: __vue_render__$50, staticRenderFns: __vue_staticRenderFns__$50 },
+ __vue_inject_styles__$50,
+ __vue_script__$50,
+ __vue_scope_id__$50,
+ __vue_is_functional_template__$50,
+ __vue_module_identifier__$50,
false,
undefined,
undefined,
undefined
);
-__vue_component__$4V.install = (Vue, options = {}) => {
+__vue_component__$50.install = (Vue, options = {}) => {
Vue.component(createNamespace$1('render', {
prefix: options.prefix
- }), __vue_component__$4V);
+ }), __vue_component__$50);
};
const rnds8Pool = new Uint8Array(256); // # of random values to pre-allocate
@@ -30500,7 +30500,7 @@ const ObjectFit = {
FILL: 'fill',
SCALE_DOWN: 'scale-down'
};
-var script$4U = {
+var script$4$ = {
name: 'DesignPreviewImage',
mixins: [Locale],
inheritAttrs: false,
@@ -30765,13 +30765,17 @@ var script$4U = {
return;
}
if (this.clickEffect === 'dian-ji-fang-da') {
+ let imgList = [];
+ this.previewSrcList.map((item, index) => {
+ imgList.push({
+ url: item,
+ title: this.title[index]
+ });
+ });
this.$xmlImgPreview({
multiple: true,
- nowImgIndex: 0,
- imgList: [{
- url: this.previewSrcList[0],
- title: this.self.title
- }]
+ nowImgIndex: this.current,
+ imgList
});
}
if (isByTitle) {
@@ -30782,9 +30786,9 @@ var script$4U = {
};
/* script */
-const __vue_script__$4U = script$4U;
+const __vue_script__$4$ = script$4$;
/* template */
-var __vue_render__$4U = function () {
+var __vue_render__$4$ = function () {
var _vm = this;
var _h = _vm.$createElement;
var _c = _vm._self._c || _h;
@@ -30800,7 +30804,7 @@ var __vue_render__$4U = function () {
? _c(
"div",
{
- staticClass: "image-title--lay image-title--on",
+ staticClass: "xml-image-title image-title--lay image-title--on",
style: { textAlign: _vm.titleAlign || "left" },
},
[_vm._v("\n " + _vm._s(_vm.self.title) + "\n ")]
@@ -30861,7 +30865,8 @@ var __vue_render__$4U = function () {
? _c(
"div",
{
- staticClass: "image-title--fixed image-title--bottom",
+ staticClass:
+ "xml-image-title image-title--fixed image-title--bottom",
style: { textAlign: _vm.titleAlign || "left" },
on: {
click: function ($event) {
@@ -30877,7 +30882,8 @@ var __vue_render__$4U = function () {
? _c(
"div",
{
- staticClass: "image-title--fixed image-title--top",
+ staticClass:
+ "xml-image-title image-title--fixed image-title--top",
style: { textAlign: _vm.titleAlign || "left" },
on: {
click: function ($event) {
@@ -30896,7 +30902,8 @@ var __vue_render__$4U = function () {
? _c(
"div",
{
- staticClass: "image-title--lay image-title--under",
+ staticClass:
+ "xml-image-title image-title--lay image-title--under",
style: { textAlign: _vm.titleAlign || "left" },
},
[_vm._v("\n " + _vm._s(_vm.self.title) + "\n ")]
@@ -30906,17 +30913,17 @@ var __vue_render__$4U = function () {
2
)
};
-var __vue_staticRenderFns__$4U = [];
-__vue_render__$4U._withStripped = true;
+var __vue_staticRenderFns__$4$ = [];
+__vue_render__$4$._withStripped = true;
/* style */
- const __vue_inject_styles__$4U = undefined;
+ const __vue_inject_styles__$4$ = undefined;
/* scoped */
- const __vue_scope_id__$4U = "data-v-755c322e";
+ const __vue_scope_id__$4$ = "data-v-fb4f6862";
/* module identifier */
- const __vue_module_identifier__$4U = undefined;
+ const __vue_module_identifier__$4$ = undefined;
/* functional template */
- const __vue_is_functional_template__$4U = false;
+ const __vue_is_functional_template__$4$ = false;
/* style inject */
/* style inject SSR */
@@ -30925,13 +30932,13 @@ __vue_render__$4U._withStripped = true;
- const __vue_component__$4U = /*#__PURE__*/normalizeComponent(
- { render: __vue_render__$4U, staticRenderFns: __vue_staticRenderFns__$4U },
- __vue_inject_styles__$4U,
- __vue_script__$4U,
- __vue_scope_id__$4U,
- __vue_is_functional_template__$4U,
- __vue_module_identifier__$4U,
+ const __vue_component__$4$ = /*#__PURE__*/normalizeComponent(
+ { render: __vue_render__$4$, staticRenderFns: __vue_staticRenderFns__$4$ },
+ __vue_inject_styles__$4$,
+ __vue_script__$4$,
+ __vue_scope_id__$4$,
+ __vue_is_functional_template__$4$,
+ __vue_module_identifier__$4$,
false,
undefined,
undefined,
@@ -31112,7 +31119,7 @@ const Mode = {
}
};
const mousewheelEventName = isFirefox() ? 'DOMMouseScroll' : 'mousewheel';
-var script$4T = {
+var script$4_ = {
name: 'XmlImageViewer',
props: {
urlList: {
@@ -31458,10 +31465,10 @@ var script$4T = {
};
/* script */
-const __vue_script__$4T = script$4T;
+const __vue_script__$4_ = script$4_;
/* template */
-var __vue_render__$4T = function () {
+var __vue_render__$4_ = function () {
var _vm = this;
var _h = _vm.$createElement;
var _c = _vm._self._c || _h;
@@ -31674,17 +31681,17 @@ var __vue_render__$4T = function () {
),
])
};
-var __vue_staticRenderFns__$4T = [];
-__vue_render__$4T._withStripped = true;
+var __vue_staticRenderFns__$4_ = [];
+__vue_render__$4_._withStripped = true;
/* style */
- const __vue_inject_styles__$4T = undefined;
+ const __vue_inject_styles__$4_ = undefined;
/* scoped */
- const __vue_scope_id__$4T = undefined;
+ const __vue_scope_id__$4_ = undefined;
/* module identifier */
- const __vue_module_identifier__$4T = undefined;
+ const __vue_module_identifier__$4_ = undefined;
/* functional template */
- const __vue_is_functional_template__$4T = false;
+ const __vue_is_functional_template__$4_ = false;
/* style inject */
/* style inject SSR */
@@ -31693,13 +31700,13 @@ __vue_render__$4T._withStripped = true;
- const __vue_component__$4T = /*#__PURE__*/normalizeComponent(
- { render: __vue_render__$4T, staticRenderFns: __vue_staticRenderFns__$4T },
- __vue_inject_styles__$4T,
- __vue_script__$4T,
- __vue_scope_id__$4T,
- __vue_is_functional_template__$4T,
- __vue_module_identifier__$4T,
+ const __vue_component__$4_ = /*#__PURE__*/normalizeComponent(
+ { render: __vue_render__$4_, staticRenderFns: __vue_staticRenderFns__$4_ },
+ __vue_inject_styles__$4_,
+ __vue_script__$4_,
+ __vue_scope_id__$4_,
+ __vue_is_functional_template__$4_,
+ __vue_module_identifier__$4_,
false,
undefined,
undefined,
@@ -31707,18 +31714,18 @@ __vue_render__$4T._withStripped = true;
);
/* istanbul ignore next */
-__vue_component__$4U.install = function (Vue) {
- Vue.component(__vue_component__$4U.name, __vue_component__$4U);
+__vue_component__$4$.install = function (Vue) {
+ Vue.component(__vue_component__$4$.name, __vue_component__$4$);
};
//
/***
* 文本块
*/
-var script$4S = {
+var script$4Z = {
name: 'XmlImageRender',
components: {
- previewImageRender: __vue_component__$4U
+ previewImageRender: __vue_component__$4$
},
props: {
//模式:preview 预览 (默认),editor 编辑
@@ -31929,9 +31936,9 @@ var script$4S = {
};
/* script */
-const __vue_script__$4S = script$4S;
+const __vue_script__$4Z = script$4Z;
/* template */
-var __vue_render__$4S = function () {
+var __vue_render__$4Z = function () {
var _vm = this;
var _h = _vm.$createElement;
var _c = _vm._self._c || _h;
@@ -32354,17 +32361,17 @@ var __vue_render__$4S = function () {
2
)
};
-var __vue_staticRenderFns__$4S = [];
-__vue_render__$4S._withStripped = true;
+var __vue_staticRenderFns__$4Z = [];
+__vue_render__$4Z._withStripped = true;
/* style */
- const __vue_inject_styles__$4S = undefined;
+ const __vue_inject_styles__$4Z = undefined;
/* scoped */
- const __vue_scope_id__$4S = undefined;
+ const __vue_scope_id__$4Z = undefined;
/* module identifier */
- const __vue_module_identifier__$4S = undefined;
+ const __vue_module_identifier__$4Z = undefined;
/* functional template */
- const __vue_is_functional_template__$4S = false;
+ const __vue_is_functional_template__$4Z = false;
/* style inject */
/* style inject SSR */
@@ -32373,23 +32380,23 @@ __vue_render__$4S._withStripped = true;
- const __vue_component__$4S = /*#__PURE__*/normalizeComponent(
- { render: __vue_render__$4S, staticRenderFns: __vue_staticRenderFns__$4S },
- __vue_inject_styles__$4S,
- __vue_script__$4S,
- __vue_scope_id__$4S,
- __vue_is_functional_template__$4S,
- __vue_module_identifier__$4S,
+ const __vue_component__$4Z = /*#__PURE__*/normalizeComponent(
+ { render: __vue_render__$4Z, staticRenderFns: __vue_staticRenderFns__$4Z },
+ __vue_inject_styles__$4Z,
+ __vue_script__$4Z,
+ __vue_scope_id__$4Z,
+ __vue_is_functional_template__$4Z,
+ __vue_module_identifier__$4Z,
false,
undefined,
undefined,
undefined
);
-__vue_component__$4S.install = (Vue, options = {}) => {
+__vue_component__$4Z.install = (Vue, options = {}) => {
Vue.component(createNamespace$1('image-render', {
prefix: options.prefix
- }), __vue_component__$4S);
+ }), __vue_component__$4Z);
};
//
@@ -32561,7 +32568,7 @@ __vue_component__$4S.install = (Vue, options = {}) => {
//
// import "../block.scss"
-var script$4R = {
+var script$4Y = {
name: 'xmlHtmlRender',
components: {},
props: {
@@ -32670,10 +32677,10 @@ var script$4R = {
};
/* script */
-const __vue_script__$4R = script$4R;
+const __vue_script__$4Y = script$4Y;
/* template */
-var __vue_render__$4R = function () {
+var __vue_render__$4Y = function () {
var _vm = this;
var _h = _vm.$createElement;
var _c = _vm._self._c || _h;
@@ -32884,17 +32891,17 @@ var __vue_render__$4R = function () {
]
)
};
-var __vue_staticRenderFns__$4R = [];
-__vue_render__$4R._withStripped = true;
+var __vue_staticRenderFns__$4Y = [];
+__vue_render__$4Y._withStripped = true;
/* style */
- const __vue_inject_styles__$4R = undefined;
+ const __vue_inject_styles__$4Y = undefined;
/* scoped */
- const __vue_scope_id__$4R = undefined;
+ const __vue_scope_id__$4Y = undefined;
/* module identifier */
- const __vue_module_identifier__$4R = undefined;
+ const __vue_module_identifier__$4Y = undefined;
/* functional template */
- const __vue_is_functional_template__$4R = false;
+ const __vue_is_functional_template__$4Y = false;
/* style inject */
/* style inject SSR */
@@ -32903,23 +32910,23 @@ __vue_render__$4R._withStripped = true;
- const __vue_component__$4R = /*#__PURE__*/normalizeComponent(
- { render: __vue_render__$4R, staticRenderFns: __vue_staticRenderFns__$4R },
- __vue_inject_styles__$4R,
- __vue_script__$4R,
- __vue_scope_id__$4R,
- __vue_is_functional_template__$4R,
- __vue_module_identifier__$4R,
+ const __vue_component__$4Y = /*#__PURE__*/normalizeComponent(
+ { render: __vue_render__$4Y, staticRenderFns: __vue_staticRenderFns__$4Y },
+ __vue_inject_styles__$4Y,
+ __vue_script__$4Y,
+ __vue_scope_id__$4Y,
+ __vue_is_functional_template__$4Y,
+ __vue_module_identifier__$4Y,
false,
undefined,
undefined,
undefined
);
-__vue_component__$4R.install = (Vue, options = {}) => {
+__vue_component__$4Y.install = (Vue, options = {}) => {
Vue.component(createNamespace$1('html-render', {
prefix: options.prefix
- }), __vue_component__$4R);
+ }), __vue_component__$4Y);
};
//
@@ -32969,7 +32976,7 @@ __vue_component__$4R.install = (Vue, options = {}) => {
//
// import '../block.scss'
-var script$4Q = {
+var script$4X = {
name: 'XmlCatalogRender',
components: {},
inject: ['getCatalogList'],
@@ -33087,9 +33094,9 @@ var script$4Q = {
};
/* script */
-const __vue_script__$4Q = script$4Q;
+const __vue_script__$4X = script$4X;
/* template */
-var __vue_render__$4Q = function () {
+var __vue_render__$4X = function () {
var _vm = this;
var _h = _vm.$createElement;
var _c = _vm._self._c || _h;
@@ -33148,17 +33155,17 @@ var __vue_render__$4Q = function () {
1
)
};
-var __vue_staticRenderFns__$4Q = [];
-__vue_render__$4Q._withStripped = true;
+var __vue_staticRenderFns__$4X = [];
+__vue_render__$4X._withStripped = true;
/* style */
- const __vue_inject_styles__$4Q = undefined;
+ const __vue_inject_styles__$4X = undefined;
/* scoped */
- const __vue_scope_id__$4Q = "data-v-61c986fa";
+ const __vue_scope_id__$4X = "data-v-61c986fa";
/* module identifier */
- const __vue_module_identifier__$4Q = undefined;
+ const __vue_module_identifier__$4X = undefined;
/* functional template */
- const __vue_is_functional_template__$4Q = false;
+ const __vue_is_functional_template__$4X = false;
/* style inject */
/* style inject SSR */
@@ -33167,13 +33174,13 @@ __vue_render__$4Q._withStripped = true;
- const __vue_component__$4Q = /*#__PURE__*/normalizeComponent(
- { render: __vue_render__$4Q, staticRenderFns: __vue_staticRenderFns__$4Q },
- __vue_inject_styles__$4Q,
- __vue_script__$4Q,
- __vue_scope_id__$4Q,
- __vue_is_functional_template__$4Q,
- __vue_module_identifier__$4Q,
+ const __vue_component__$4X = /*#__PURE__*/normalizeComponent(
+ { render: __vue_render__$4X, staticRenderFns: __vue_staticRenderFns__$4X },
+ __vue_inject_styles__$4X,
+ __vue_script__$4X,
+ __vue_scope_id__$4X,
+ __vue_is_functional_template__$4X,
+ __vue_module_identifier__$4X,
false,
undefined,
undefined,
@@ -33181,10 +33188,10 @@ __vue_render__$4Q._withStripped = true;
);
// 提交
-__vue_component__$4Q.install = (Vue, options = {}) => {
+__vue_component__$4X.install = (Vue, options = {}) => {
Vue.component(createNamespace$1('catalog-render', {
prefix: options.prefix
- }), __vue_component__$4Q);
+ }), __vue_component__$4X);
};
//
@@ -33307,7 +33314,7 @@ __vue_component__$4Q.install = (Vue, options = {}) => {
//
//
-var script$4P = {
+var script$4W = {
name: 'XmlTextDialogRender',
props: {
content: {
@@ -33369,8 +33376,8 @@ var script$4P = {
var __$_require_static_images_leaflet_icons_scroll_png__ = "";
/* script */
-const __vue_script__$4P = script$4P;
-var __vue_render__$4P = function () {
+const __vue_script__$4W = script$4W;
+var __vue_render__$4W = function () {
var _vm = this;
var _h = _vm.$createElement;
var _c = _vm._self._c || _h;
@@ -33477,7 +33484,7 @@ var __vue_render__$4P = function () {
: _vm._e(),
])
};
-var __vue_staticRenderFns__$4P = [
+var __vue_staticRenderFns__$4W = [
function () {
var _vm = this;
var _h = _vm.$createElement;
@@ -33523,16 +33530,16 @@ var __vue_staticRenderFns__$4P = [
])
},
];
-__vue_render__$4P._withStripped = true;
+__vue_render__$4W._withStripped = true;
/* style */
- const __vue_inject_styles__$4P = undefined;
+ const __vue_inject_styles__$4W = undefined;
/* scoped */
- const __vue_scope_id__$4P = "data-v-0994a01b";
+ const __vue_scope_id__$4W = "data-v-0994a01b";
/* module identifier */
- const __vue_module_identifier__$4P = undefined;
+ const __vue_module_identifier__$4W = undefined;
/* functional template */
- const __vue_is_functional_template__$4P = false;
+ const __vue_is_functional_template__$4W = false;
/* style inject */
/* style inject SSR */
@@ -33541,13 +33548,13 @@ __vue_render__$4P._withStripped = true;
- const __vue_component__$4P = /*#__PURE__*/normalizeComponent(
- { render: __vue_render__$4P, staticRenderFns: __vue_staticRenderFns__$4P },
- __vue_inject_styles__$4P,
- __vue_script__$4P,
- __vue_scope_id__$4P,
- __vue_is_functional_template__$4P,
- __vue_module_identifier__$4P,
+ const __vue_component__$4W = /*#__PURE__*/normalizeComponent(
+ { render: __vue_render__$4W, staticRenderFns: __vue_staticRenderFns__$4W },
+ __vue_inject_styles__$4W,
+ __vue_script__$4W,
+ __vue_scope_id__$4W,
+ __vue_is_functional_template__$4W,
+ __vue_module_identifier__$4W,
false,
undefined,
undefined,
@@ -33741,1441 +33748,1083 @@ var recorder_mp3_min = createCommonjsModule(function (module) {
https://github.com/xiangyuecn/Recorder
src: recorder-core.js,engine/mp3.js,engine/mp3-engine.js
*/
-!function (e) {
- var t = "object" == typeof window && !!window.document,
- a = t ? window : Object;
- !function (e, w) {
+!function (y) {
- var S = function () {},
- f = function (e) {
- return "number" == typeof e;
- },
- N = function (e) {
- return new l(e);
- },
- M = N.LM = "2024-04-09 19:15",
- y = "https://github.com/xiangyuecn/Recorder",
- R = "Recorder",
- A = "getUserMedia",
- V = "srcSampleRate",
- D = "sampleRate",
- i = "bitRate",
- x = "catch",
- t = e[R];
- if (t && t.LM == M) return t.CLog(t.i18n.$T("K8zP::重复导入{1}", 0, R), 3);
- N.IsOpen = function () {
- var e = N.Stream;
- if (e) {
- var t = e.getTracks && e.getTracks() || e.audioTracks || [],
- a = t[0];
- if (a) {
- var n = a.readyState;
- return "live" == n || n == a.LIVE;
- }
- }
- return !1;
- }, N.BufferSize = 4096, N.Destroy = function () {
- for (var e in O(R + " Destroy"), L(), a) a[e]();
+ var v = function () {},
+ V = function (e) {
+ return new t(e);
};
- var a = {};
- N.BindDestroy = function (e, t) {
- a[e] = t;
- }, N.Support = function () {
- if (!w) return !1;
- var e = navigator.mediaDevices || {};
- return e[A] || (e = navigator)[A] || (e[A] = e.webkitGetUserMedia || e.mozGetUserMedia || e.msGetUserMedia), !!e[A] && (N.Scope = e, !!N.GetContext());
- }, N.GetContext = function (e) {
- if (!w) return null;
- var t = window.AudioContext;
- if (t || (t = window.webkitAudioContext), !t) return null;
- var a = N.Ctx;
- if (a && "closed" != a.state || (a = N.Ctx = new t(), N.NewCtxs = N.NewCtxs || [], N.BindDestroy("Ctx", function () {
- var e = N.Ctx;
- e && e.close && (s(e), N.Ctx = 0);
- var t = N.NewCtxs;
- N.NewCtxs = [];
- for (var a = 0; a < t.length; a++) s(t[a]);
- })), e && a.close) try {
- a = new t(), N.NewCtxs.push(a);
- } catch (e) {
- O("GetContext tryNew Error", 1, e);
+ V.LM = "2023-02-01 18:05";
+ var T = "Recorder",
+ d = "getUserMedia",
+ O = "srcSampleRate",
+ N = "sampleRate",
+ x = "catch";
+ V.IsOpen = function () {
+ var e = V.Stream;
+ if (e) {
+ var t = e.getTracks && e.getTracks() || e.audioTracks || [],
+ a = t[0];
+ if (a) {
+ var s = a.readyState;
+ return "live" == s || s == a.LIVE;
}
- return a;
- }, N.CloseNewCtx = function (e) {
- if (e && e != N.Ctx) {
- s(e);
- for (var t = N.NewCtxs || [], a = t.length, n = 0; n < t.length; n++) if (t[n] == e) {
- t.splice(n, 1);
- break;
- }
- O(z("mSxV::剩{1}个GetContext未close", 0, a + "-1=" + t.length), t.length ? 3 : 0);
- }
- };
- var s = function (e) {
- if (e && e.close) {
- e._isC = 1;
- try {
- e.close();
- } catch (e) {
- O("ctx close err", 1, e);
- }
- }
- },
- B = N.ResumeCtx = function (a, n, s, r) {
- var i = 0,
- o = 0,
- _ = 0,
- l = 0,
- f = "EventListener",
- c = "ResumeCtx ",
- u = function (e, t) {
- o && h(), i || (i = 1, e && r(e, l), t && s(l)), t && (!a._LsSC && a["add" + f] && a["add" + f]("statechange", b), a._LsSC = 1, _ = 1);
- },
- h = function (e) {
- if (!e || !o) {
- o = e ? 1 : 0;
- for (var t = ["focus", "mousedown", "mouseup", "touchstart", "touchend"], a = 0; a < t.length; a++) window[(e ? "add" : "remove") + f](t[a], b, !0);
- }
- },
- b = function () {
- var e = a.state,
- t = p(e);
- if (!i && !n(t ? ++l : l)) return u();
- t ? (_ && O(c + "sc " + e, 3), h(1), a.resume().then(function () {
- _ && O(c + "sc " + a.state), u(0, 1);
- })[x](function (e) {
- O(c + "error", 1, e), p(a.state) || u(e.message || "error");
- })) : "closed" == e ? (_ && !a._isC && O(c + "sc " + e, 1), u("ctx closed")) : u(0, 1);
- };
- b();
- },
- p = N.CtxSpEnd = function (e) {
- return "suspended" == e || "interrupted" == e;
- },
- k = function (e) {
- var t = e.state,
- a = "ctx.state=" + t;
- return p(t) && (a += z("nMIy::(注意:ctx不是running状态,rec.open和start至少要有一个在用户操作(触摸、点击等)时进行调用,否则将在rec.start时尝试进行ctx.resume,可能会产生兼容性问题(仅iOS),请参阅文档中runningContext配置)")), a;
- },
- T = "ConnectEnableWebM";
- N[T] = !0;
- var E = "ConnectEnableWorklet";
- N[E] = !1;
- var C = function (e, _) {
- var l = e.BufferSize || N.BufferSize,
- f = e.Stream,
- c = f._RC || f._c || N.GetContext(!0);
- f._c = c;
- var u,
- a,
- h,
- i = function (e) {
- var t = f._m = c.createMediaStreamSource(f),
- a = c.destination,
- n = "createMediaStreamDestination";
- c[n] && (a = f._d = c[n]()), t.connect(e), e.connect(a);
- },
- b = "",
- p = f._call,
- m = function (e) {
- for (var t in p) {
- for (var a = e.length, n = new Int16Array(a), s = 0, r = 0; r < a; r++) {
- var i = Math.max(-1, Math.min(1, e[r]));
- i = i < 0 ? 32768 * i : 32767 * i, n[r] = i, s += Math.abs(i);
- }
- for (var o in p) p[o](n, s);
- return;
- }
- },
- v = "ScriptProcessor",
- d = "audioWorklet",
- o = R + " " + d,
- g = "RecProc",
- w = "MediaRecorder",
- S = w + ".WebM.PCM",
- M = c.createScriptProcessor || c.createJavaScriptNode,
- y = z("ZGlf::。由于{1}内部1秒375次回调,在移动端可能会有性能问题导致回调丢失录音变短,PC端无影响,暂不建议开启{1}。", 0, d),
- A = function () {
- a = f.isWorklet = !1, n(f), O(z("7TU0::Connect采用老的{1},", 0, v) + Y.get(z(N[E] ? "JwCL::但已设置{1}尝试启用{2}" : "VGjB::可设置{1}尝试启用{2}", 2), [R + "." + E + "=true", d]) + b + y, 3);
- var e = f._p = M.call(c, l, 1, 1);
- i(e), e.onaudioprocess = function (e) {
- var t = e.inputBuffer.getChannelData(0);
- m(t);
- };
- },
- k = function () {
- u = f.isWebM = !1, I(f), a = f.isWorklet = !M || N[E];
- var t = window.AudioWorkletNode;
- if (a && c[d] && t) {
- var n = function () {
- return a && f._na;
- },
- s = f._na = function () {
- "" !== h && (clearTimeout(h), h = setTimeout(function () {
- h = 0, n() && (O(z("MxX1::{1}未返回任何音频,恢复使用{2}", 0, d, v), 3), M && A());
- }, 500));
- },
- r = function () {
- if (n()) {
- var e = f._n = new t(c, g, {
- processorOptions: {
- bufferSize: l
- }
- });
- i(e), e.port.onmessage = function (e) {
- h && (clearTimeout(h), h = ""), n() ? m(e.data.val) : a || O(z("XUap::{1}多余回调", 0, d), 3);
- }, O(z("yOta::Connect采用{1},设置{2}可恢复老式{3}", 0, d, R + "." + E + "=false", v) + b + y, 3);
- }
- },
- e = function () {
- if (n()) if (c[g]) r();else {
- var e,
- t,
- a = (t = "class " + g + " extends AudioWorkletProcessor{", t += "constructor " + (e = function (e) {
- return e.toString().replace(/^function|DEL_/g, "").replace(/\$RA/g, o);
- })(function (e) {
- DEL_super(e);
- var t = this,
- a = e.processorOptions.bufferSize;
- t.bufferSize = a, t.buffer = new Float32Array(2 * a), t.pos = 0, t.port.onmessage = function (e) {
- e.data.kill && (t.kill = !0, $C.log("$RA kill call"));
- }, $C.log("$RA .ctor call", e);
- }), t += "process " + e(function (e, t, a) {
- var n = this,
- s = n.bufferSize,
- r = n.buffer,
- i = n.pos;
- if ((e = (e[0] || [])[0] || []).length) {
- r.set(e, i);
- var o = ~~((i += e.length) / s) * s;
- if (o) {
- this.port.postMessage({
- val: r.slice(0, o)
- });
- var _ = r.subarray(o, i);
- (r = new Float32Array(2 * s)).set(_), i = _.length, n.buffer = r;
- }
- n.pos = i;
- }
- return !n.kill;
- }), t = (t += '}try{registerProcessor("' + g + '", ' + g + ')}catch(e){$C.error("' + o + ' Reg Error",e)}').replace(/\$C\./g, "console."), "data:text/javascript;base64," + btoa(unescape(encodeURIComponent(t))));
- c[d].addModule(a).then(function (e) {
- n() && (c[g] = 1, r(), h && s());
- })[x](function (e) {
- O(d + ".addModule Error", 1, e), n() && A();
- });
- }
- };
- B(c, function () {
- return n();
- }, e, e);
- } else A();
- };
- !function () {
- var e = window[w],
- t = "ondataavailable",
- a = "audio/webm; codecs=pcm";
- u = f.isWebM = N[T];
- var n = e && t in e.prototype && e.isTypeSupported(a);
- if (b = n ? "" : z("VwPd::(此浏览器不支持{1})", 0, S), !_ || !u || !n) return k();
- var s = function () {
- return u && f._ra;
- },
- r = (f._ra = function () {
- "" !== h && (clearTimeout(h), h = setTimeout(function () {
- s() && (O(z("vHnb::{1}未返回任何音频,降级使用{2}", 0, w, d), 3), k());
- }, 500));
- }, Object.assign({
- mimeType: a
- }, N.ConnectWebMOptions)),
- i = f._r = new e(f, r),
- o = f._rd = {
- sampleRate: c[D]
- };
- i[t] = function (e) {
- var t = new FileReader();
- t.onloadend = function () {
- if (s()) {
- var e = P(new Uint8Array(t.result), o);
- if (!e) return;
- if (-1 == e) return void k();
- h && (clearTimeout(h), h = ""), m(e);
- } else u || O(z("O9P7::{1}多余回调", 0, w), 3);
- }, t.readAsArrayBuffer(e.data);
- }, i.start(~~(l / 48)), O(z("LMEm::Connect采用{1},设置{2}可恢复使用{3}或老式{4}", 0, S, R + "." + T + "=false", d, v));
- }();
- },
- r = function (e) {
- e._na && e._na(), e._ra && e._ra();
- },
- n = function (e) {
- e._na = null, e._n && (e._n.port.postMessage({
- kill: !0
- }), e._n.disconnect(), e._n = null);
- },
- I = function (e) {
- if (e._ra = null, e._r) {
- try {
- e._r.stop();
- } catch (e) {
- O("mr stop err", 1, e);
- }
- e._r = null;
- }
- },
- L = function (e) {
- var t = (e = e || N) == N,
- a = e.Stream;
- a && (a._m && (a._m.disconnect(), a._m = null), !a._RC && a._c && N.CloseNewCtx(a._c), a._RC = null, a._c = null, a._d && (o(a._d.stream), a._d = null), a._p && (a._p.disconnect(), a._p.onaudioprocess = a._p = null), n(a), I(a), t && o(a)), e.Stream = 0;
- },
- o = N.StopS_ = function (e) {
- for (var t = e.getTracks && e.getTracks() || e.audioTracks || [], a = 0; a < t.length; a++) {
- var n = t[a];
- n.stop && n.stop();
- }
- e.stop && e.stop();
- };
- N.SampleData = function (e, t, a, n, s) {
- var r = "SampleData";
- n || (n = {});
- var i = n.index || 0,
- o = n.offset || 0,
- _ = n.filter;
- if (_ && _.fn && _.sr != t && (_ = null, O(z("d48C::{1}的filter采样率变了,重设滤波", 0, r), 3)), !_) {
- var l = 3 * t / 4 < a ? 0 : a / 2 * 3 / 4;
- _ = {
- fn: l ? N.IIRFilter(!0, t, l) : 0
- };
- }
- _.sr = t;
- var f = _.fn,
- c = n.frameNext || [];
- s || (s = {});
- var u = s.frameSize || 1;
- s.frameType && (u = "mp3" == s.frameType ? 1152 : 1);
- var h = e.length;
- h + 1 < i && O(z("tlbC::{1}似乎传入了未重置chunk {2}", 0, r, i + ">" + h), 3);
- for (var b = 0, p = i; p < h; p++) b += e[p].length;
- b = Math.max(0, b - Math.floor(o));
- var m = t / a;
- 1 < m ? b = Math.floor(b / m) : (m = 1, a = t), b += c.length;
- for (var v = new Int16Array(b), d = 0, p = 0; p < c.length; p++) v[d] = c[p], d++;
- for (; i < h; i++) {
- for (var g = e[i], p = o, w = g.length, S = f && f.Embed, M = 0, y = 0, A = 0, k = 0, R = 0, x = 0; R < w; R++, x++) if (x < w && (S ? (A = g[x], k = S.b0 * A + S.b1 * S.x1 + S.b0 * S.x2 - S.a1 * S.y1 - S.a2 * S.y2, S.x2 = S.x1, S.x1 = A, S.y2 = S.y1, S.y1 = k) : k = f ? f(g[x]) : g[x]), M = y, y = k, 0 != x) {
- var B = Math.floor(p);
- if (R == B) {
- var T = Math.ceil(p),
- E = p - B,
- C = M,
- I = T < w ? y : C,
- L = C + (I - C) * E;
- 32767 < L ? L = 32767 : L < -32768 && (L = -32768), v[d] = L, d++, p += m;
- }
- } else R--;
- o = Math.max(0, p - w);
- }
- c = null;
- var P = v.length % u;
- if (0 < P) {
- var H = 2 * (v.length - P);
- c = new Int16Array(v.buffer.slice(H)), v = new Int16Array(v.buffer.slice(0, H));
- }
- return {
- index: i,
- offset: o,
- filter: _,
- frameNext: c,
- sampleRate: a,
- data: v
- };
- }, N.IIRFilter = function (e, t, a) {
- var n = 2 * Math.PI * a / t,
- s = Math.sin(n),
- r = Math.cos(n),
- i = s / 2,
- o = 1 + i,
- _ = -2 * r / o,
- l = (1 - i) / o;
- if (e) var f = (1 - r) / 2 / o,
- c = (1 - r) / o;else var f = (1 + r) / 2 / o,
- c = -(1 + r) / o;
- var u = 0,
- h = 0,
- b = 0,
- p = 0,
- m = 0,
- v = function (e) {
- return b = f * e + c * u + f * h - _ * p - l * m, h = u, u = e, m = p, p = b;
- };
- return v.Embed = {
- x1: 0,
- x2: 0,
- y1: 0,
- y2: 0,
- b0: f,
- b1: c,
- a1: _,
- a2: l
- }, v;
- }, N.PowerLevel = function (e, t) {
- var a = e / t || 0;
- return a < 1251 ? Math.round(a / 1250 * 10) : Math.round(Math.min(100, Math.max(0, 100 * (1 + Math.log(a / 1e4) / Math.log(10)))));
- }, N.PowerDBFS = function (e) {
- var t = Math.max(.1, e || 0);
- return t = Math.min(t, 32767), t = 20 * Math.log(t / 32767) / Math.log(10), Math.max(-100, Math.round(t));
- }, N.CLog = function (e, t) {
- if ("object" == typeof console) {
- var a = new Date(),
- n = ("0" + a.getMinutes()).substr(-2) + ":" + ("0" + a.getSeconds()).substr(-2) + "." + ("00" + a.getMilliseconds()).substr(-3),
- s = this && this.envIn && this.envCheck && this.id,
- r = ["[" + n + " " + R + (s ? ":" + s : "") + "]" + e],
- i = arguments,
- o = N.CLog,
- _ = 2,
- l = o.log || console.log;
- for (f(t) ? l = 1 == t ? o.error || console.error : 3 == t ? o.warn || console.warn : l : _ = 1; _ < i.length; _++) r.push(i[_]);
- c ? l && l("[IsLoser]" + r[0], 1 < r.length ? r : "") : l.apply(console, r);
- }
- };
- var O = function () {
- N.CLog.apply(this, arguments);
- },
- c = !0;
- try {
- c = !console.log.apply;
- } catch (e) {}
- var _ = 0;
- function l(e) {
- var t = this;
- t.id = ++_, u();
- var a = {
- type: "mp3",
- onProcess: S
- };
- for (var n in e) a[n] = e[n];
- var s = (t.set = a)[i],
- r = a[D];
- (s && !f(s) || r && !f(r)) && t.CLog(z.G("IllegalArgs-1", [z("VtS4::{1}和{2}必须是数值", 0, D, i)]), 1, e), a[i] = +s || 16, a[D] = +r || 16e3, t.state = 0, t._S = 9, t.Sync = {
- O: 9,
- C: 9
- };
}
- N.Sync = {
+ return !1;
+ }, V.BufferSize = 4096, V.Destroy = function () {
+ for (var e in H(T + " Destroy"), S(), a) a[e]();
+ };
+ var a = {};
+ V.BindDestroy = function (e, t) {
+ a[e] = t;
+ }, V.Support = function () {
+ var e = navigator.mediaDevices || {};
+ return e[d] || (e = navigator)[d] || (e[d] = e.webkitGetUserMedia || e.mozGetUserMedia || e.msGetUserMedia), !!e[d] && (V.Scope = e, !!V.GetContext());
+ }, V.GetContext = function () {
+ var e = y.AudioContext;
+ return e || (e = y.webkitAudioContext), e ? (V.Ctx && "closed" != V.Ctx.state || (V.Ctx = new e(), V.BindDestroy("Ctx", function () {
+ var e = V.Ctx;
+ e && e.close && (e.close(), V.Ctx = 0);
+ })), V.Ctx) : null;
+ };
+ var E = "ConnectEnableWebM";
+ V[E] = !0;
+ var P = "ConnectEnableWorklet";
+ V[P] = !1;
+ var g = function (e, _) {
+ var l,
+ i,
+ f,
+ c = e.BufferSize || V.BufferSize,
+ h = V.Ctx,
+ u = e.Stream,
+ o = function (e) {
+ var t = u._m = h.createMediaStreamSource(u),
+ a = h.destination,
+ s = "createMediaStreamDestination";
+ h[s] && (a = h[s]()), t.connect(e), e.connect(a);
+ },
+ m = "",
+ p = u._call,
+ b = function (e) {
+ for (var t in p) {
+ for (var a = e.length, s = new Int16Array(a), n = 0, r = 0; r < a; r++) {
+ var i = Math.max(-1, Math.min(1, e[r]));
+ i = i < 0 ? 32768 * i : 32767 * i, s[r] = i, n += Math.abs(i);
+ }
+ for (var o in p) p[o](s, n);
+ return;
+ }
+ },
+ v = "ScriptProcessor",
+ d = "audioWorklet",
+ g = T + " " + d,
+ S = "RecProc",
+ M = "MediaRecorder",
+ w = M + ".WebM.PCM",
+ R = h.createScriptProcessor || h.createJavaScriptNode,
+ A = "。由于" + d + "内部1秒375次回调,在移动端可能会有性能问题导致回调丢失录音变短,PC端无影响,暂不建议开启" + d + "。",
+ B = function () {
+ i = u.isWorklet = !1, L(u), H("Connect采用老的" + v + "," + (V[P] ? "但已" : "可") + "设置" + T + "." + P + "=true尝试启用" + d + m + A, 3);
+ var e = u._p = R.call(h, c, 1, 1);
+ o(e);
+ var t = "_D220626",
+ a = V[t];
+ a && H("Use " + T + "." + t, 3), e.onaudioprocess = function (e) {
+ var t = e.inputBuffer.getChannelData(0);
+ a ? (t = new Float32Array(t), setTimeout(function () {
+ b(t);
+ })) : b(t);
+ };
+ },
+ k = function () {
+ l = u.isWebM = !1, I(u), i = u.isWorklet = !R || V[P];
+ var t = y.AudioWorkletNode;
+ if (i && h[d] && t) {
+ var s = function () {
+ return i && u._na;
+ },
+ n = u._na = function () {
+ "" !== f && (clearTimeout(f), f = setTimeout(function () {
+ f = 0, s() && (H(d + "未返回任何音频,恢复使用" + v, 3), R && B());
+ }, 500));
+ },
+ r = function () {
+ if (s()) {
+ var e = u._n = new t(h, S, {
+ processorOptions: {
+ bufferSize: c
+ }
+ });
+ o(e), e.port.onmessage = function (e) {
+ f && (clearTimeout(f), f = ""), s() ? b(e.data.val) : i || H(d + "多余回调", 3);
+ }, H("Connect采用" + d + ",设置" + T + "." + P + "=false可恢复老式" + v + m + A, 3);
+ }
+ };
+ h.resume()[p && "finally"](function () {
+ if (s()) if (h[S]) r();else {
+ var e,
+ t,
+ a = (t = "class " + S + " extends AudioWorkletProcessor{", t += "constructor " + (e = function (e) {
+ return e.toString().replace(/^function|DEL_/g, "").replace(/\$RA/g, g);
+ })(function (e) {
+ DEL_super(e);
+ var t = this,
+ a = e.processorOptions.bufferSize;
+ t.bufferSize = a, t.buffer = new Float32Array(2 * a), t.pos = 0, t.port.onmessage = function (e) {
+ e.data.kill && (t.kill = !0, console.log("$RA kill call"));
+ }, console.log("$RA .ctor call", e);
+ }), t += "process " + e(function (e, t, a) {
+ var s = this,
+ n = s.bufferSize,
+ r = s.buffer,
+ i = s.pos;
+ if ((e = (e[0] || [])[0] || []).length) {
+ r.set(e, i);
+ var o = ~~((i += e.length) / n) * n;
+ if (o) {
+ this.port.postMessage({
+ val: r.slice(0, o)
+ });
+ var _ = r.subarray(o, i);
+ (r = new Float32Array(2 * n)).set(_), i = _.length, s.buffer = r;
+ }
+ s.pos = i;
+ }
+ return !s.kill;
+ }), t += '}try{registerProcessor("' + S + '", ' + S + ')}catch(e){console.error("' + g + '注册失败",e)}', "data:text/javascript;base64," + btoa(unescape(encodeURIComponent(t))));
+ h[d].addModule(a).then(function (e) {
+ s() && (h[S] = 1, r(), f && n());
+ })[x](function (e) {
+ H(d + ".addModule失败", 1, e), s() && B();
+ });
+ }
+ });
+ } else B();
+ };
+ !function () {
+ var e = y[M],
+ t = "ondataavailable",
+ a = "audio/webm; codecs=pcm";
+ l = u.isWebM = V[E];
+ var s = e && t in e.prototype && e.isTypeSupported(a);
+ if (m = s ? "" : "(此浏览器不支持" + w + ")", !_ || !l || !s) return k();
+ var n = function () {
+ return l && u._ra;
+ },
+ r = (u._ra = function () {
+ "" !== f && (clearTimeout(f), f = setTimeout(function () {
+ n() && (H(M + "未返回任何音频,降级使用" + d, 3), k());
+ }, 500));
+ }, Object.assign({
+ mimeType: a
+ }, V.ConnectWebMOptions)),
+ i = u._r = new e(u, r),
+ o = u._rd = {
+ sampleRate: h[N]
+ };
+ i[t] = function (e) {
+ var t = new FileReader();
+ t.onloadend = function () {
+ if (n()) {
+ var e = C(new Uint8Array(t.result), o);
+ if (!e) return;
+ if (-1 == e) return void k();
+ f && (clearTimeout(f), f = ""), b(e);
+ } else l || H(M + "多余回调", 3);
+ }, t.readAsArrayBuffer(e.data);
+ }, i.start(~~(c / 48)), H("Connect采用" + w + ",设置" + T + "." + E + "=false可恢复使用" + d + "或老式" + v);
+ }();
+ },
+ L = function (e) {
+ e._na = null, e._n && (e._n.port.postMessage({
+ kill: !0
+ }), e._n.disconnect(), e._n = null);
+ },
+ I = function (e) {
+ e._ra = null, e._r && (e._r.stop(), e._r = null);
+ },
+ S = function (e) {
+ var t = (e = e || V) == V,
+ a = e.Stream;
+ if (a && (a._m && (a._m.disconnect(), a._m = null), a._p && (a._p.disconnect(), a._p.onaudioprocess = a._p = null), L(a), I(a), t)) {
+ for (var s = a.getTracks && a.getTracks() || a.audioTracks || [], n = 0; n < s.length; n++) {
+ var r = s[n];
+ r.stop && r.stop();
+ }
+ a.stop && a.stop();
+ }
+ e.Stream = 0;
+ };
+ V.SampleData = function (e, t, a, s, n) {
+ s || (s = {});
+ var r = s.index || 0,
+ i = s.offset || 0,
+ o = s.frameNext || [];
+ n || (n = {});
+ var _ = n.frameSize || 1;
+ n.frameType && (_ = "mp3" == n.frameType ? 1152 : 1);
+ var l = e.length;
+ l + 1 < r && H("SampleData似乎传入了未重置chunk " + r + ">" + l, 3);
+ for (var f = 0, c = r; c < l; c++) f += e[c].length;
+ f = Math.max(0, f - Math.floor(i));
+ var h = t / a;
+ 1 < h ? f = Math.floor(f / h) : (h = 1, a = t), f += o.length;
+ for (var u = new Int16Array(f), m = 0, c = 0; c < o.length; c++) u[m] = o[c], m++;
+ for (; r < l; r++) {
+ for (var p = e[r], c = i, b = p.length; c < b;) {
+ var v = Math.floor(c),
+ d = Math.ceil(c),
+ g = c - v,
+ S = p[v],
+ M = d < b ? p[d] : (e[r + 1] || [S])[0] || 0;
+ u[m] = S + (M - S) * g, m++, c += h;
+ }
+ i = c - b;
+ }
+ o = null;
+ var w = u.length % _;
+ if (0 < w) {
+ var R = 2 * (u.length - w);
+ o = new Int16Array(u.buffer.slice(R)), u = new Int16Array(u.buffer.slice(0, R));
+ }
+ return {
+ index: r,
+ offset: i,
+ frameNext: o,
+ sampleRate: a,
+ data: u
+ };
+ }, V.PowerLevel = function (e, t) {
+ var a = e / t || 0;
+ return a < 1251 ? Math.round(a / 1250 * 10) : Math.round(Math.min(100, Math.max(0, 100 * (1 + Math.log(a / 1e4) / Math.log(10)))));
+ }, V.PowerDBFS = function (e) {
+ var t = Math.max(.1, e || 0);
+ return t = Math.min(t, 32767), t = 20 * Math.log(t / 32767) / Math.log(10), Math.max(-100, Math.round(t));
+ }, V.CLog = function (e, t) {
+ var a = new Date(),
+ s = ("0" + a.getMinutes()).substr(-2) + ":" + ("0" + a.getSeconds()).substr(-2) + "." + ("00" + a.getMilliseconds()).substr(-3),
+ n = this && this.envIn && this.envCheck && this.id,
+ r = ["[" + s + " " + T + (n ? ":" + n : "") + "]" + e],
+ i = arguments,
+ o = y.console || {},
+ _ = 2,
+ l = o.log;
+ for ("number" == typeof t ? l = 1 == t ? o.error : 3 == t ? o.warn : l : _ = 1; _ < i.length; _++) r.push(i[_]);
+ f ? l && l("[IsLoser]" + r[0], 1 < r.length ? r : "") : l.apply(o, r);
+ };
+ var H = function () {
+ V.CLog.apply(this, arguments);
+ },
+ f = !0;
+ try {
+ f = !console.log.apply;
+ } catch (e) {}
+ var s = 0;
+ function t(e) {
+ this.id = ++s, r();
+ var t = {
+ type: "mp3",
+ bitRate: 16,
+ sampleRate: 16e3,
+ onProcess: v
+ };
+ for (var a in e) t[a] = e[a];
+ this.set = t, this._S = 9, this.Sync = {
O: 9,
C: 9
- }, N.prototype = l.prototype = {
- CLog: O,
- _streamStore: function () {
- return this.set.sourceStream ? this : N;
- },
- _streamCtx: function () {
- var e = this._streamStore().Stream;
- return e && e._c;
- },
- open: function (e, a) {
- var n = this,
- s = n.set,
- r = n._streamStore(),
- i = 0;
- e = e || S;
- var o = function (e, t) {
- t = !!t, n.CLog(z("5tWi::录音open失败:") + e + ",isUserNotAllow:" + t, 1), i && N.CloseNewCtx(i), a && a(e, t);
- };
- n._streamTag = A;
- var _ = function () {
- n.CLog("open ok, id:" + n.id + " stream:" + n._streamTag), e(), n._SO = 0;
- },
- l = r.Sync,
- f = ++l.O,
- c = l.C;
- n._O = n._O_ = f, n._SO = n._S;
- if (w) {
- var t = n.envCheck({
- envName: "H5",
- canProcess: !0
- });
- if (t) o(z("A5bm::不能录音:") + t);else if (s.sourceStream) {
- if (n._streamTag = "set.sourceStream", !N.GetContext()) return void o(z("1iU7::不支持此浏览器从流中获取录音"));
- L(r);
- var u = n.Stream = s.sourceStream;
- u._RC = s.runningContext, u._call = {};
- try {
- C(r);
- } catch (e) {
- return L(r), void o(z("BTW2::从流中打开录音失败:") + e.message);
- }
- _();
- } else {
- var h = function (e, t) {
- try {
- window.top.a;
- } catch (e) {
- return void o(z("Nclz::无权录音(跨域,请尝试给iframe添加麦克风访问策略,如{1})", 0, 'allow="camera;microphone"'));
- }
- /Permission|Allow/i.test(e) ? o(z("gyO5::用户拒绝了录音权限"), !0) : !1 === window.isSecureContext ? o(z("oWNo::浏览器禁止不安全页面录音,可开启https解决")) : /Found/i.test(e) ? o(t + z("jBa9::,无可用麦克风")) : o(t);
- };
- if (N.IsOpen()) _();else if (N.Support()) {
- var b = s.runningContext;
- b || (b = i = N.GetContext(!0));
- var p = function (t) {
- setTimeout(function () {
- t._call = {};
- var e = N.Stream;
- e && (L(), t._call = e._call), (N.Stream = t)._c = b, t._RC = s.runningContext, function () {
- if (c != l.C || !n._O) {
- var e = z("dFm8::open被取消");
- return f == l.O ? n.close() : e = z("VtJO::open被中断"), o(e), !0;
- }
- }() || (N.IsOpen() ? (e && n.CLog(z("upb8::发现同时多次调用open"), 1), C(r, 1), _()) : o(z("Q1GA::录音功能无效:无音频流")));
- }, 100);
- },
- m = function (e) {
- var t = e.name || e.message || e.code + ":" + e;
- n.CLog(z("xEQR::请求录音权限错误"), 1, e), h(t, z("bDOG::无法录音:") + t);
- },
- v = s.audioTrackSet || {};
- v[D] = b[D];
- var d = {
- audio: v
- };
- try {
- var g = N.Scope[A](d, p, m);
- } catch (e) {
- n.CLog(A, 3, e), d = {
- audio: !0
- }, g = N.Scope[A](d, p, m);
- }
- n.CLog(A + "(" + JSON.stringify(d) + ") " + k(b) + z("RiWe::,未配置noiseSuppression和echoCancellation时浏览器可能会自动打开降噪和回声消除,移动端可能会降低系统播放音量(关闭录音后可恢复),请参阅文档中audioTrackSet配置") + "(" + y + ") LM:" + M + " UA:" + navigator.userAgent), g && g.then && g.then(p)[x](m);
- } else h("", z("COxc::此浏览器不支持录音"));
- }
- } else o(z.G("NonBrowser-1", ["open"]) + z("EMJq::,可尝试使用RecordApp解决方案") + "(" + y + "/tree/master/app-support-sample)");
- },
- close: function (e) {
- e = e || S;
- var t = this,
- a = t._streamStore();
- t._stop();
- var n = " stream:" + t._streamTag,
- s = a.Sync;
- if (t._O = 0, t._O_ != s.O) return t.CLog(z("hWVz::close被忽略(因为同时open了多个rec,只有最后一个会真正close)") + n, 3), void e();
- s.C++, L(a), t.CLog("close," + n), e();
- },
- mock: function (e, t) {
- var a = this;
- return a._stop(), a.isMock = 1, a.mockEnvInfo = null, a.buffers = [e], a.recSize = e.length, a._setSrcSR(t), a._streamTag = "mock", a;
- },
- _setSrcSR: function (e) {
- var t = this.set,
- a = t[D];
- e < a ? t[D] = e : a = 0, this[V] = e, this.CLog(V + ": " + e + " set." + D + ": " + t[D] + (a ? " " + z("UHvm::忽略") + ": " + a : ""), a ? 3 : 0);
- },
- envCheck: function (e) {
- var t,
- a = this.set,
- n = "CPU_BE";
- if (t || N[n] || "function" != typeof Int8Array || new Int8Array(new Int32Array([1]).buffer)[0] || (u(n), t = z("Essp::不支持{1}架构", 0, n)), !t) {
- var s = a.type,
- r = this[s + "_envCheck"];
- a.takeoffEncodeChunk && (r ? e.canProcess || (t = z("7uMV::{1}环境不支持实时处理", 0, e.envName)) : t = z("2XBl::{1}类型不支持设置takeoffEncodeChunk", 0, s) + (this[s] ? "" : z("LG7e::(未加载编码器)"))), !t && r && (t = this[s + "_envCheck"](e, a));
+ };
+ }
+ V.Sync = {
+ O: 9,
+ C: 9
+ }, V.prototype = t.prototype = {
+ CLog: H,
+ _streamStore: function () {
+ return this.set.sourceStream ? this : V;
+ },
+ open: function (e, a) {
+ var s = this,
+ n = s._streamStore();
+ e = e || v;
+ var r = function (e, t) {
+ t = !!t, s.CLog("录音open失败:" + e + ",isUserNotAllow:" + t, 1), a && a(e, t);
+ },
+ i = function () {
+ s.CLog("open ok id:" + s.id), e(), s._SO = 0;
+ },
+ o = n.Sync,
+ _ = ++o.O,
+ l = o.C;
+ s._O = s._O_ = _, s._SO = s._S;
+ var t = s.envCheck({
+ envName: "H5",
+ canProcess: !0
+ });
+ if (t) r("不能录音:" + t);else if (s.set.sourceStream) {
+ if (!V.GetContext()) return void r("不支持此浏览器从流中获取录音");
+ S(n), s.Stream = s.set.sourceStream, s.Stream._call = {};
+ try {
+ g(n);
+ } catch (e) {
+ return void r("从流中打开录音失败:" + e.message);
}
- return t || "";
- },
- envStart: function (e, t) {
- var a = this,
- n = a.set;
- if (a.isMock = e ? 1 : 0, a.mockEnvInfo = e, a.buffers = [], a.recSize = 0, e && (a._streamTag = "env$" + e.envName), a.state = 1, a.envInLast = 0, a.envInFirst = 0, a.envInFix = 0, a.envInFixTs = [], a._setSrcSR(t), a.engineCtx = 0, a[n.type + "_start"]) {
- var s = a.engineCtx = a[n.type + "_start"](n);
- s && (s.pcmDatas = [], s.pcmSize = 0);
- }
- },
- envResume: function () {
- this.envInFixTs = [];
- },
- envIn: function (e, t) {
- var s = this,
- r = s.set,
- i = s.engineCtx;
- if (1 == s.state) {
- var a = s[V],
- n = e.length,
- o = N.PowerLevel(t, n),
- _ = s.buffers,
- l = _.length;
- _.push(e);
- var f = _,
- c = l,
- u = Date.now(),
- h = Math.round(n / a * 1e3);
- s.envInLast = u, 1 == s.buffers.length && (s.envInFirst = u - h);
- var b = s.envInFixTs;
- b.splice(0, 0, {
- t: u,
- d: h
- });
- for (var p = u, m = 0, v = 0; v < b.length; v++) {
- var d = b[v];
- if (3e3 < u - d.t) {
- b.length = v;
- break;
- }
- p = d.t, m += d.d;
- }
- var g = b[1],
- w = u - p,
- S = w - m;
- if (w / 3 < S && (g && 1e3 < w || 6 <= b.length)) {
- var M = u - g.t - h;
- if (h / 5 < M) {
- var y = !r.disableEnvInFix;
- if (s.CLog("[" + u + "]" + Y.get(z(y ? "4Kfd::补偿{1}ms" : "bM5i::未补偿{1}ms", 1), [M]), 3), s.envInFix += M, y) {
- var A = new Int16Array(M * a / 1e3);
- n += A.length, _.push(A);
- }
- }
- }
- var k = s.recSize,
- R = n,
- x = k + R;
- if (s.recSize = x, i) {
- var B = N.SampleData(_, a, r[D], i.chunkInfo);
- i.chunkInfo = B, k = i.pcmSize, R = B.data.length, x = k + R, i.pcmSize = x, _ = i.pcmDatas, l = _.length, _.push(B.data), a = B[D];
- }
- var T = Math.round(x / a * 1e3),
- E = _.length,
- C = f.length,
- I = function () {
- for (var e = L ? 0 : -R, t = null == _[0], a = l; a < E; a++) {
- var n = _[a];
- null == n ? t = 1 : (e += n.length, i && n.length && s[r.type + "_encode"](i, n));
- }
- if (t && i) {
- var a = c;
- for (f[0] && (a = 0); a < C; a++) f[a] = null;
- }
- t && (e = L ? R : 0, _[0] = null), i ? i.pcmSize += e : s.recSize += e;
- },
- L = 0,
- P = "rec.set.onProcess";
+ i();
+ } else {
+ var f = function (e, t) {
try {
- L = r.onProcess(_, o, T, a, l, I);
+ y.top.a;
} catch (e) {
- console.error(P + z("gFUF::回调出错是不允许的,需保证不会抛异常"), e);
+ return void r('无权录音(跨域,请尝试给iframe添加麦克风访问策略,如allow="camera;microphone")');
}
- var H = Date.now() - u;
- if (10 < H && 1e3 < s.envInFirst - u && s.CLog(P + z("2ghS::低性能,耗时{1}ms", 0, H), 3), !0 === L) {
- for (var O = 0, v = l; v < E; v++) null == _[v] ? O = 1 : _[v] = new Int16Array(0);
- O ? s.CLog(z("ufqH::未进入异步前不能清除buffers"), 3) : i ? i.pcmSize -= R : s.recSize -= R;
- } else I();
- } else s.state || s.CLog("envIn at state=0", 3);
- },
- start: function () {
- var t = this,
- e = 1;
- if (t.set.sourceStream ? t.Stream || (e = 0) : N.IsOpen() || (e = 0), e) {
- var a = t._streamCtx();
- if (t.CLog(z("kLDN::start 开始录音,") + k(a) + " stream:" + t._streamTag), t._stop(), t.envStart(null, a[D]), t.state = 3, t._SO && t._SO + 1 != t._S) t.CLog(z("Bp2y::start被中断"), 3);else {
- t._SO = 0;
- var n = function () {
- 3 == t.state && (t.state = 1, t.resume());
- },
- s = "AudioContext resume: ";
- B(a, function (e) {
- return e && t.CLog(s + "wait..."), 3 == t.state;
- }, function (e) {
- e && t.CLog(s + a.state), n();
- }, function (e) {
- t.CLog(s + a.state + z("upkE::,可能无法录音:") + e, 1), n();
- });
+ /Permission|Allow/i.test(e) ? r("用户拒绝了录音权限", !0) : !1 === y.isSecureContext ? r("浏览器禁止不安全页面录音,可开启https解决") : /Found/i.test(e) ? r(t + ",无可用麦克风") : r(t);
+ };
+ if (V.IsOpen()) i();else if (V.Support()) {
+ var c = function (t) {
+ setTimeout(function () {
+ t._call = {};
+ var e = V.Stream;
+ e && (S(), t._call = e._call), V.Stream = t, function () {
+ if (l != o.C || !s._O) {
+ var e = "open被取消";
+ return _ == o.O ? s.close() : e = "open被中断", r(e), !0;
+ }
+ }() || (V.IsOpen() ? (e && s.CLog("发现同时多次调用open", 1), g(n, 1), i()) : r("录音功能无效:无音频流"));
+ }, 100);
+ },
+ h = function (e) {
+ var t = e.name || e.message || e.code + ":" + e;
+ s.CLog("请求录音权限错误", 1, e), f(t, "无法录音:" + t);
+ },
+ u = {
+ noiseSuppression: !1,
+ echoCancellation: !1
+ },
+ m = s.set.audioTrackSet;
+ for (var p in m) u[p] = m[p];
+ u.sampleRate = V.Ctx.sampleRate;
+ try {
+ var b = V.Scope[d]({
+ audio: u
+ }, c, h);
+ } catch (e) {
+ s.CLog(d, 3, e), b = V.Scope[d]({
+ audio: !0
+ }, c, h);
}
- } else t.CLog(z("6WmN::start失败:未open"), 1);
- },
- pause: function () {
- var e = this,
- t = e._streamStore().Stream;
- e.state && (e.state = 2, e.CLog("pause"), t && delete t._call[e.id]);
- },
- resume: function () {
- var a = this,
- t = a._streamStore().Stream,
- n = "resume(wait ctx)";
- if (3 == a.state) a.CLog(n);else if (a.state) {
- a.state = 1, a.CLog("resume"), a.envResume(), t && (t._call[a.id] = function (e, t) {
- 1 == a.state && a.envIn(e, t);
- }, r(t));
- var s = a._streamCtx();
- s && B(s, function (e) {
- return e && a.CLog(n + "..."), 1 == a.state;
- }, function (e) {
- e && a.CLog(n + s.state), r(t);
- }, function (e) {
- a.CLog(n + s.state + "[err]" + e, 1);
- });
+ b && b.then && b.then(c)[x](h);
+ } else f("", "此浏览器不支持录音");
+ }
+ },
+ close: function (e) {
+ e = e || v;
+ var t = this,
+ a = t._streamStore();
+ t._stop();
+ var s = a.Sync;
+ if (t._O = 0, t._O_ != s.O) return t.CLog("close被忽略(因为同时open了多个rec,只有最后一个会真正close)", 3), void e();
+ s.C++, S(a), t.CLog("close"), e();
+ },
+ mock: function (e, t) {
+ var a = this;
+ return a._stop(), a.isMock = 1, a.mockEnvInfo = null, a.buffers = [e], a.recSize = e.length, a[O] = t, a;
+ },
+ envCheck: function (e) {
+ var t,
+ a = this.set,
+ s = "CPU_BE";
+ if (t || V[s] || !y.Int8Array || new Int8Array(new Int32Array([1]).buffer)[0] || (r(s), t = "不支持CPU_BE架构"), !t) {
+ var n = a.type;
+ this[n + "_envCheck"] ? t = this[n + "_envCheck"](e, a) : a.takeoffEncodeChunk && (t = n + "类型" + (this[n] ? "" : "(未加载编码器)") + "不支持设置takeoffEncodeChunk");
+ }
+ return t || "";
+ },
+ envStart: function (e, t) {
+ var a = this,
+ s = a.set;
+ a.isMock = e ? 1 : 0, a.mockEnvInfo = e, a.buffers = [], a.recSize = 0, a.envInLast = 0, a.envInFirst = 0, a.envInFix = 0, a.envInFixTs = [];
+ var n = s[N];
+ if (t < n ? s[N] = t : n = 0, a[O] = t, a.CLog(O + ": " + t + " set." + N + ": " + s[N] + (n ? " 忽略" + n : ""), n ? 3 : 0), a.engineCtx = 0, a[s.type + "_start"]) {
+ var r = a.engineCtx = a[s.type + "_start"](s);
+ r && (r.pcmDatas = [], r.pcmSize = 0);
+ }
+ },
+ envResume: function () {
+ this.envInFixTs = [];
+ },
+ envIn: function (e, t) {
+ var n = this,
+ r = n.set,
+ i = n.engineCtx,
+ a = n[O],
+ s = e.length,
+ o = V.PowerLevel(t, s),
+ _ = n.buffers,
+ l = _.length;
+ _.push(e);
+ var f = _,
+ c = l,
+ h = Date.now(),
+ u = Math.round(s / a * 1e3);
+ n.envInLast = h, 1 == n.buffers.length && (n.envInFirst = h - u);
+ var m = n.envInFixTs;
+ m.splice(0, 0, {
+ t: h,
+ d: u
+ });
+ for (var p = h, b = 0, v = 0; v < m.length; v++) {
+ var d = m[v];
+ if (3e3 < h - d.t) {
+ m.length = v;
+ break;
}
- },
- _stop: function (e) {
- var t = this,
- a = t.set;
- t.isMock || t._S++, t.state && (t.pause(), t.state = 0), !e && t[a.type + "_stop"] && (t[a.type + "_stop"](t.engineCtx), t.engineCtx = 0);
- },
- stop: function (c, t, e) {
- var u,
- h = this,
- b = h.set,
- a = h.envInLast - h.envInFirst,
- n = a && h.buffers.length;
- h.CLog(z("Xq4s::stop 和start时差:") + (a ? a + "ms " + z("3CQP::补偿:") + h.envInFix + "ms envIn:" + n + " fps:" + (n / a * 1e3).toFixed(1) : "-") + " stream:" + h._streamTag + " (" + y + ") LM:" + M);
- var p = function () {
- h._stop(), e && h.close();
- },
- m = function (e) {
- h.CLog(z("u8JG::结束录音失败:") + e, 1), t && t(e), p();
- },
- s = function (e, t, a) {
- var n = "arraybuffer",
- s = "dataType",
- r = "DefaultDataType",
- i = h[s] || N[r] || "blob",
- o = s + "=" + i,
- _ = e instanceof ArrayBuffer,
- l = 0,
- f = _ ? e.byteLength : e.size;
- if (i == n ? _ || (l = 1) : "blob" == i ? "function" != typeof Blob ? l = z.G("NonBrowser-1", [o]) + z("1skY::,请设置{1}", 0, R + "." + r + '="' + n + '"') : (_ && (e = new Blob([e], {
- type: t
- })), e instanceof Blob || (l = 1), t = e.type || t) : l = z.G("NotSupport-1", [o]), h.CLog(z("Wv7l::结束录音 编码花{1}ms 音频时长{2}ms 文件大小{3}b", 0, Date.now() - u, a, f) + " " + o + "," + t), l) m(1 != l ? l : z("Vkbd::{1}编码器返回的不是{2}", 0, b.type, i) + ", " + o);else {
- if (b.takeoffEncodeChunk) h.CLog(z("QWnr::启用takeoffEncodeChunk后stop返回的blob长度为0不提供音频数据"), 3);else if (f < Math.max(50, a / 5)) return void m(z("Sz2H::生成的{1}无效", 0, b.type));
- c && c(e, a, t), p();
- }
+ p = d.t, b += d.d;
+ }
+ var g = m[1],
+ S = h - p;
+ if (S / 3 < S - b && (g && 1e3 < S || 6 <= m.length)) {
+ var M = h - g.t - u;
+ if (u / 5 < M) {
+ var w = !r.disableEnvInFix;
+ if (n.CLog("[" + h + "]" + (w ? "" : "未") + "补偿" + M + "ms", 3), n.envInFix += M, w) {
+ var R = new Int16Array(M * a / 1e3);
+ s += R.length, _.push(R);
+ }
+ }
+ }
+ var A = n.recSize,
+ B = s,
+ k = A + B;
+ if (n.recSize = k, i) {
+ var y = V.SampleData(_, a, r[N], i.chunkInfo);
+ i.chunkInfo = y, k = (A = i.pcmSize) + (B = y.data.length), i.pcmSize = k, _ = i.pcmDatas, l = _.length, _.push(y.data), a = y[N];
+ }
+ var T = Math.round(k / a * 1e3),
+ x = _.length,
+ E = f.length,
+ P = function () {
+ for (var e = L ? 0 : -B, t = null == _[0], a = l; a < x; a++) {
+ var s = _[a];
+ null == s ? t = 1 : (e += s.length, i && s.length && n[r.type + "_encode"](i, s));
+ }
+ if (t && i) for (a = c, f[0] && (a = 0); a < E; a++) f[a] = null;
+ t && (e = L ? B : 0, _[0] = null), i ? i.pcmSize += e : n.recSize += e;
+ },
+ L = 0,
+ I = "rec.set.onProcess";
+ try {
+ L = r.onProcess(_, o, T, a, l, P);
+ } catch (e) {
+ console.error(I + "回调出错是不允许的,需保证不会抛异常", e);
+ }
+ var H = Date.now() - h;
+ if (10 < H && 1e3 < n.envInFirst - h && n.CLog(I + "低性能,耗时" + H + "ms", 3), !0 === L) {
+ var C = 0;
+ for (v = l; v < x; v++) null == _[v] ? C = 1 : _[v] = new Int16Array(0);
+ C ? n.CLog("未进入异步前不能清除buffers", 3) : i ? i.pcmSize -= B : n.recSize -= B;
+ } else P();
+ },
+ start: function () {
+ var t = this,
+ a = V.Ctx,
+ e = 1;
+ if (t.set.sourceStream ? t.Stream || (e = 0) : V.IsOpen() || (e = 0), e) {
+ if (t.CLog("开始录音"), t._stop(), t.state = 3, t.envStart(null, a[N]), t._SO && t._SO + 1 != t._S) t.CLog("start被中断", 3);else {
+ t._SO = 0;
+ var s = function () {
+ 3 == t.state && (t.state = 1, t.resume());
};
- if (!h.isMock) {
- var r = 3 == h.state;
- if (!h.state || r) return void m(z("wf9t::未开始录音") + (r ? z("Dl2c::,开始录音前无用户交互导致AudioContext未运行") : ""));
+ if ("suspended" == a.state) {
+ var n = "AudioContext resume: ";
+ t.CLog(n + "wait..."), a.resume().then(function () {
+ t.CLog(n + a.state), s();
+ })[x](function (e) {
+ t.CLog(n + a.state + " 可能无法录音:" + e.message, 1, e), s();
+ });
+ } else s();
}
- h._stop(!0);
- var i = h.recSize;
- if (i) {
- if (h[b.type]) {
- if (h.isMock) {
- var o = h.envCheck(h.mockEnvInfo || {
+ } else t.CLog("未open", 1);
+ },
+ pause: function () {
+ var e = this;
+ e.state && (e.state = 2, e.CLog("pause"), delete e._streamStore().Stream._call[e.id]);
+ },
+ resume: function () {
+ var e,
+ a = this;
+ if (a.state) {
+ a.state = 1, a.CLog("resume"), a.envResume();
+ var t = a._streamStore().Stream;
+ t._call[a.id] = function (e, t) {
+ 1 == a.state && a.envIn(e, t);
+ }, (e = t)._na && e._na(), e._ra && e._ra();
+ }
+ },
+ _stop: function (e) {
+ var t = this,
+ a = t.set;
+ t.isMock || t._S++, t.state && (t.pause(), t.state = 0), !e && t[a.type + "_stop"] && (t[a.type + "_stop"](t.engineCtx), t.engineCtx = 0);
+ },
+ stop: function (a, t, e) {
+ var s,
+ n = this,
+ r = n.set,
+ i = n.envInLast - n.envInFirst,
+ o = i && n.buffers.length;
+ n.CLog("stop 和start时差" + (i ? i + "ms 补偿" + n.envInFix + "ms envIn:" + o + " fps:" + (o / i * 1e3).toFixed(1) : "-"));
+ var _ = function () {
+ n._stop(), e && n.close();
+ },
+ l = function (e) {
+ n.CLog("结束录音失败:" + e, 1), t && t(e), _();
+ },
+ f = function (e, t) {
+ if (n.CLog("结束录音 编码花" + (Date.now() - s) + "ms 音频时长" + t + "ms 文件大小" + e.size + "b"), r.takeoffEncodeChunk) n.CLog("启用takeoffEncodeChunk后stop返回的blob长度为0不提供音频数据", 3);else if (e.size < Math.max(100, t / 2)) return void l("生成的" + r.type + "无效");
+ a && a(e, t), _();
+ };
+ if (!n.isMock) {
+ var c = 3 == n.state;
+ if (!n.state || c) return void l("未开始录音" + (c ? ",开始录音前无用户交互导致AudioContext未运行" : ""));
+ n._stop(!0);
+ }
+ var h = n.recSize;
+ if (h) {
+ if (n.buffers[0]) {
+ if (n[r.type]) {
+ if (n.isMock) {
+ var u = n.envCheck(n.mockEnvInfo || {
envName: "mock",
canProcess: !1
});
- if (o) return void m(z("AxOH::录音错误:") + o);
+ if (u) return void l("录音错误:" + u);
}
- var _ = h.engineCtx;
- if (h[b.type + "_complete"] && _) {
- var l = Math.round(_.pcmSize / b[D] * 1e3);
- return u = Date.now(), void h[b.type + "_complete"](_, function (e, t) {
- s(e, t, l);
- }, m);
+ var m = n.engineCtx;
+ if (n[r.type + "_complete"] && m) {
+ var p = Math.round(m.pcmSize / r[N] * 1e3);
+ return s = Date.now(), void n[r.type + "_complete"](m, function (e) {
+ f(e, p);
+ }, l);
}
- if (u = Date.now(), h.buffers[0]) {
- var f = N.SampleData(h.buffers, h[V], b[D]);
- b[D] = f[D];
- var v = f.data,
- l = Math.round(v.length / b[D] * 1e3);
- h.CLog(z("CxeT::采样:{1} 花:{2}ms", 0, i + "->" + v.length, Date.now() - u)), setTimeout(function () {
- u = Date.now(), h[b.type](v, function (e, t) {
- s(e, t, l);
- }, function (e) {
- m(e);
- });
+ s = Date.now();
+ var b = V.SampleData(n.buffers, n[O], r[N]);
+ r[N] = b[N];
+ var v = b.data;
+ p = Math.round(v.length / r[N] * 1e3), n.CLog("采样" + h + "->" + v.length + " 花:" + (Date.now() - s) + "ms"), setTimeout(function () {
+ s = Date.now(), n[r.type](v, function (e) {
+ f(e, p);
+ }, function (e) {
+ l(e);
});
- } else m(z("xkKd::音频buffers被释放"));
- } else m(z("xGuI::未加载{1}编码器,请尝试到{2}的src/engine内找到{1}的编码器并加载", 0, b.type, R));
- } else m(z("Ltz3::未采集到录音"));
- }
- };
- var P = function (e, t) {
- t.pos || (t.pos = [0], t.tracks = {}, t.bytes = []);
- var a = t.tracks,
- n = [t.pos[0]],
- s = function () {
- t.pos[0] = n[0];
- },
- r = t.bytes.length,
- i = new Uint8Array(r + e.length);
- if (i.set(t.bytes), i.set(e, r), t.bytes = i, !t._ht) {
- if (j(i, n), X(i, n), !H(j(i, n), [24, 83, 128, 103])) return;
- for (j(i, n); n[0] < i.length;) {
- var o = j(i, n),
- _ = X(i, n),
- l = [0],
- f = 0;
- if (!_) return;
- if (H(o, [22, 84, 174, 107])) {
- for (; l[0] < _.length;) {
- var c = j(_, l),
- u = X(_, l),
- h = [0],
- b = {
- channels: 0,
- sampleRate: 0
- };
- if (H(c, [174])) for (; h[0] < u.length;) {
- var p = j(u, h),
- m = X(u, h),
- v = [0];
- if (H(p, [215])) {
- var d = F(m);
- b.number = d, a[d] = b;
- } else if (H(p, [131])) {
- var d = F(m);
- 1 == d ? b.type = "video" : 2 == d ? (b.type = "audio", f || (t.track0 = b), b.idx = f++) : b.type = "Type-" + d;
- } else if (H(p, [134])) {
- for (var g = "", w = 0; w < m.length; w++) g += String.fromCharCode(m[w]);
- b.codec = g;
- } else if (H(p, [225])) for (; v[0] < m.length;) {
- var S = j(m, v),
- M = X(m, v);
- if (H(S, [181])) {
- var d = 0,
- y = new Uint8Array(M.reverse()).buffer;
- 4 == M.length ? d = new Float32Array(y)[0] : 8 == M.length ? d = new Float64Array(y)[0] : O("WebM Track !Float", 1, M), b[D] = Math.round(d);
- } else H(S, [98, 100]) ? b.bitDepth = F(M) : H(S, [159]) && (b.channels = F(M));
- }
+ });
+ } else l("未加载" + r.type + "编码器");
+ } else l("音频buffers被释放");
+ } else l("未采集到录音");
+ }
+ }, y[T] && (H("重复引入" + T, 3), y[T].Destroy()), y[T] = V;
+ var C = function (e, t) {
+ t.pos || (t.pos = [0], t.tracks = {}, t.bytes = []);
+ var a = t.tracks,
+ s = [t.pos[0]],
+ n = function () {
+ t.pos[0] = s[0];
+ },
+ r = t.bytes.length,
+ i = new Uint8Array(r + e.length);
+ if (i.set(t.bytes), i.set(e, r), t.bytes = i, !t._ht) {
+ if (X(i, s), q(i, s), !D(X(i, s), [24, 83, 128, 103])) return;
+ for (X(i, s); s[0] < i.length;) {
+ var o = X(i, s),
+ _ = q(i, s),
+ l = [0],
+ f = 0;
+ if (!_) return;
+ if (D(o, [22, 84, 174, 107])) {
+ for (; l[0] < _.length;) {
+ var c = X(_, l),
+ h = q(_, l),
+ u = [0],
+ m = {
+ channels: 0,
+ sampleRate: 0
+ };
+ if (D(c, [174])) for (; u[0] < h.length;) {
+ var p = X(h, u),
+ b = q(h, u),
+ v = [0];
+ if (D(p, [215])) {
+ var d = Y(b);
+ m.number = d, a[d] = m;
+ } else if (D(p, [131])) {
+ var d = Y(b);
+ 1 == d ? m.type = "video" : 2 == d ? (m.type = "audio", f || (t.track0 = m), m.idx = f++) : m.type = "Type-" + d;
+ } else if (D(p, [134])) {
+ for (var g = "", S = 0; S < b.length; S++) g += String.fromCharCode(b[S]);
+ m.codec = g;
+ } else if (D(p, [225])) for (; v[0] < b.length;) {
+ var M = X(b, v),
+ w = q(b, v);
+ if (D(M, [181])) {
+ var d = 0,
+ R = new Uint8Array(w.reverse()).buffer;
+ 4 == w.length ? d = new Float32Array(R)[0] : 8 == w.length ? d = new Float64Array(R)[0] : H("WebM Track !Float", 1, w), m[N] = Math.round(d);
+ } else D(M, [98, 100]) ? m.bitDepth = Y(w) : D(M, [159]) && (m.channels = Y(w));
}
}
- t._ht = 1, O("WebM Tracks", a), s();
- break;
}
- }
- }
- var A = t.track0;
- if (A) {
- if (16 == A.bitDepth && /FLOAT/i.test(A.codec) && (A.bitDepth = 32, O("WebM 16->32 bit", 3)), A[D] != t[D] || 32 != A.bitDepth || A.channels < 1 || !/(\b|_)PCM\b/i.test(A.codec)) return t.bytes = [], t.bad || O("WebM Track Unexpected", 3, t), -(t.bad = 1);
- for (var k = [], R = 0; n[0] < i.length;) {
- var c = j(i, n),
- u = X(i, n);
- if (!u) break;
- if (H(c, [163])) {
- var x = 15 & u[0],
- b = a[x];
- if (b) {
- if (0 === b.idx) {
- for (var B = new Uint8Array(u.length - 4), w = 4; w < u.length; w++) B[w - 4] = u[w];
- k.push(B), R += B.length;
- }
- } else O("WebM !Track" + x, 1, a);
- }
- s();
- }
- if (R) {
- var T = new Uint8Array(i.length - t.pos[0]);
- T.set(i.subarray(t.pos[0])), t.bytes = T, t.pos[0] = 0;
- for (var B = new Uint8Array(R), w = 0, E = 0; w < k.length; w++) B.set(k[w], E), E += k[w].length;
- var y = new Float32Array(B.buffer);
- if (1 < A.channels) {
- for (var C = [], w = 0; w < y.length;) C.push(y[w]), w += A.channels;
- y = new Float32Array(C);
- }
- return y;
- }
- }
- },
- H = function (e, t) {
- if (!e || e.length != t.length) return !1;
- if (1 == e.length) return e[0] == t[0];
- for (var a = 0; a < e.length; a++) if (e[a] != t[a]) return !1;
- return !0;
- },
- F = function (e) {
- for (var t = "", a = 0; a < e.length; a++) {
- var n = e[a];
- t += (n < 16 ? "0" : "") + n.toString(16);
- }
- return parseInt(t, 16) || 0;
- },
- j = function (e, t, a) {
- var n = t[0];
- if (!(n >= e.length)) {
- var s = e[n],
- r = ("0000000" + s.toString(2)).substr(-8),
- i = /^(0*1)(\d*)$/.exec(r);
- if (i) {
- var o = i[1].length,
- _ = [];
- if (!(n + o > e.length)) {
- for (var l = 0; l < o; l++) _[l] = e[n], n++;
- return a && (_[0] = parseInt(i[2] || "0", 2)), t[0] = n, _;
- }
- }
- }
- },
- X = function (e, t) {
- var a = j(e, t, 1);
- if (a) {
- var n = F(a),
- s = t[0],
- r = [];
- if (n < 2147483647) {
- if (s + n > e.length) return;
- for (var i = 0; i < n; i++) r[i] = e[s], s++;
- }
- return t[0] = s, r;
- }
- },
- Y = N.i18n = {
- lang: "zh-CN",
- alias: {
- "zh-CN": "zh",
- "en-US": "en"
- },
- locales: {},
- data: {},
- put: function (e, t) {
- var a = R + ".i18n.put: ",
- n = e.overwrite;
- n = null == n || n;
- var s = e.lang;
- if (!(s = Y.alias[s] || s)) throw new Error(a + "set.lang?");
- var r = Y.locales[s];
- r || (r = {}, Y.locales[s] = r);
- for (var i, o = /^([\w\-]+):/, _ = 0; _ < t.length; _++) {
- var l = t[_];
- if (i = o.exec(l)) {
- var f = i[1],
- l = l.substr(f.length + 1);
- !n && r[f] || (r[f] = l);
- } else O(a + "'key:'? " + l, 3, e);
- }
- },
- get: function () {
- return Y.v_G.apply(null, arguments);
- },
- v_G: function (n, s, e) {
- s = s || [], e = e || Y.lang, e = Y.alias[e] || e;
- var t = Y.locales[e],
- r = t && t[n] || "";
- return r || "zh" == e ? (Y.lastLang = e, "=Empty" == r ? "" : r.replace(/\{(\d+)(\!?)\}/g, function (e, t, a) {
- return e = s[(t = +t || 0) - 1], (t < 1 || t > s.length) && (e = "{?}", O("i18n[" + n + "] no {" + t + "}: " + r, 3)), a ? "" : e;
- })) : "en" == e ? Y.v_G(n, s, "zh") : Y.v_G(n, s, "en");
- },
- $T: function () {
- return Y.v_T.apply(null, arguments);
- },
- v_T: function () {
- for (var e, t = arguments, a = "", n = [], s = 0, r = R + ".i18n.$T:", i = /^([\w\-]*):/, o = 0; o < t.length; o++) {
- var _ = t[o];
- if (0 == o) {
- if (e = i.exec(_), !(a = e && e[1])) throw new Error(r + "0 'key:'?");
- _ = _.substr(a.length + 1);
- }
- if (-1 === s) n.push(_);else {
- if (s) throw new Error(r + " bad args");
- if (0 === _) s = -1;else if (f(_)) {
- if (_ < 1) throw new Error(r + " bad args");
- s = _;
- } else {
- var l = 1 == o ? "en" : o ? "" : "zh";
- if ((e = i.exec(_)) && (l = e[1] || l, _ = _.substr(e[1].length + 1)), !e || !l) throw new Error(r + o + " 'lang:'?");
- Y.put({
- lang: l,
- overwrite: !1
- }, [a + ":" + _]);
- }
- }
- }
- return a ? 0 < s ? a : Y.v_G(a, n) : "";
- }
- },
- z = Y.$T;
- z.G = Y.get, z("NonBrowser-1::非浏览器环境,不支持{1}", 1), z("IllegalArgs-1::参数错误:{1}", 1), z("NeedImport-2::调用{1}需要先导入{2}", 2), z("NotSupport-1::不支持:{1}", 1), N.TrafficImgUrl = "//ia.51.la/go1?id=20469973&pvFlag=1";
- var u = N.Traffic = function (e) {
- if (w) {
- e = e ? "/" + R + "/Report/" + e : "";
- var t = N.TrafficImgUrl;
- if (t) {
- var a = N.Traffic,
- n = /^(https?:..[^\/#]*\/?)[^#]*/i.exec(location.href) || [],
- s = n[1] || "http://file/",
- r = (n[0] || s) + e;
- if (0 == t.indexOf("//") && (t = /^https:/i.test(r) ? "https:" + t : "http:" + t), e && (t = t + "&cu=" + encodeURIComponent(s + e)), !a[r]) {
- a[r] = 1;
- var i = new Image();
- i.src = t, O("Traffic Analysis Image: " + (e || R + ".TrafficImgUrl=" + N.TrafficImgUrl));
+ t._ht = 1, H("WebM Tracks", a), n();
+ break;
}
}
}
+ var A = t.track0;
+ if (A) {
+ if (16 == A.bitDepth && /FLOAT/i.test(A.codec) && (A.bitDepth = 32, H("WebM 16改32位", 3)), A[N] != t[N] || 32 != A.bitDepth || A.channels < 1 || !/(\b|_)PCM\b/i.test(A.codec)) return t.bytes = [], t.bad || H("WebM Track非预期", 3, t), -(t.bad = 1);
+ for (var B = [], k = 0; s[0] < i.length;) {
+ var c = X(i, s),
+ h = q(i, s);
+ if (!h) break;
+ if (D(c, [163])) {
+ var y = 15 & h[0],
+ m = a[y];
+ if (m) {
+ if (0 === m.idx) {
+ for (var T = new Uint8Array(h.length - 4), S = 4; S < h.length; S++) T[S - 4] = h[S];
+ B.push(T), k += T.length;
+ }
+ } else H("WebM !Track" + y, 1, a);
+ }
+ n();
+ }
+ if (k) {
+ var x = new Uint8Array(i.length - t.pos[0]);
+ x.set(i.subarray(t.pos[0])), t.bytes = x, t.pos[0] = 0;
+ for (var T = new Uint8Array(k), S = 0, E = 0; S < B.length; S++) T.set(B[S], E), E += B[S].length;
+ var R = new Float32Array(T.buffer);
+ if (1 < A.channels) {
+ for (var P = [], S = 0; S < R.length;) P.push(R[S]), S += A.channels;
+ R = new Float32Array(P);
+ }
+ return R;
+ }
+ }
+ },
+ D = function (e, t) {
+ if (!e || e.length != t.length) return !1;
+ if (1 == e.length) return e[0] == t[0];
+ for (var a = 0; a < e.length; a++) if (e[a] != t[a]) return !1;
+ return !0;
+ },
+ Y = function (e) {
+ for (var t = "", a = 0; a < e.length; a++) {
+ var s = e[a];
+ t += (s < 16 ? "0" : "") + s.toString(16);
+ }
+ return parseInt(t, 16) || 0;
+ },
+ X = function (e, t, a) {
+ var s = t[0];
+ if (!(s >= e.length)) {
+ var n = e[s],
+ r = ("0000000" + n.toString(2)).substr(-8),
+ i = /^(0*1)(\d*)$/.exec(r);
+ if (i) {
+ var o = i[1].length,
+ _ = [];
+ if (!(s + o > e.length)) {
+ for (var l = 0; l < o; l++) _[l] = e[s], s++;
+ return a && (_[0] = parseInt(i[2] || "0", 2)), t[0] = s, _;
+ }
+ }
+ }
+ },
+ q = function (e, t) {
+ var a = X(e, t, 1);
+ if (a) {
+ var s = Y(a),
+ n = t[0],
+ r = [];
+ if (s < 2147483647) {
+ if (n + s > e.length) return;
+ for (var i = 0; i < s; i++) r[i] = e[n], n++;
+ }
+ return t[0] = n, r;
+ }
};
- t && (O(z("8HO5::覆盖导入{1}", 0, R), 1), t.Destroy());
- e[R] = N;
- }(a, t), module.exports && (module.exports = a.Recorder);
-}(), function (e) {
- var t = "object" == typeof window && !!window.document,
- a = (t ? window : Object).Recorder,
- n = a.i18n;
- !function (m, e, u, t) {
+ V.TrafficImgUrl = "//ia.51.la/go1?id=20469973&pvFlag=1";
+ var r = V.Traffic = function (e) {
+ e = e ? "/" + T + "/Report/" + e : "";
+ var t = V.TrafficImgUrl;
+ if (t) {
+ var a = V.Traffic,
+ s = /^(https?:..[^\/#]*\/?)[^#]*/i.exec(location.href) || [],
+ n = s[1] || "http://file/",
+ r = (s[0] || n) + e;
+ if (0 == t.indexOf("//") && (t = /^https:/i.test(r) ? "https:" + t : "http:" + t), e && (t = t + "&cu=" + encodeURIComponent(n + e)), !a[r]) {
+ a[r] = 1;
+ var i = new Image();
+ i.src = t, H("Traffic Analysis Image: " + (e || T + ".TrafficImgUrl=" + V.TrafficImgUrl));
+ }
+ }
+ };
+}(window), module.exports && (module.exports = Recorder), function () {
- var o = "48000, 44100, 32000, 24000, 22050, 16000, 12000, 11025, 8000",
- _ = "8, 16, 24, 32, 40, 48, 56, 64, 80, 96, 112, 128, 144, 160, 192, 224, 256, 320";
- m.prototype.enc_mp3 = {
- stable: !0,
- takeEC: "full",
- getTestMsg: function () {
- return u("Zm7L::采样率范围:{1};比特率范围:{2}(不同比特率支持的采样率范围不同,小于32kbps时采样率需小于32000)", 0, o, _);
- }
- };
- var h,
- v = function (e) {
- var t = e.bitRate,
- a = e.sampleRate,
- n = a;
- if (-1 == (" " + _ + ",").indexOf(" " + t + ",") && m.CLog(u("eGB9::{1}不在mp3支持的取值范围:{2}", 0, "bitRate=" + t, _), 3), -1 == (" " + o + ",").indexOf(" " + a + ",")) {
- for (var s = o.split(", "), r = [], i = 0; i < s.length; i++) r.push({
- v: +s[i],
- s: Math.abs(s[i] - a)
- });
- r.sort(function (e, t) {
- return e.s - t.s;
- }), n = r[0].v, e.sampleRate = n, m.CLog(u("zLTa::sampleRate已更新为{1},因为{2}不在mp3支持的取值范围:{3}", 0, n, a, o), 3);
+ var i;
+ Recorder.prototype.enc_mp3 = {
+ stable: !0,
+ testmsg: "采样率范围48000, 44100, 32000, 24000, 22050, 16000, 12000, 11025, 8000"
+ }, Recorder.prototype.mp3 = function (a, s, e) {
+ var n = this.set,
+ r = a.length,
+ t = this.mp3_start(n);
+ if (t) return this.mp3_encode(t, a), void this.mp3_complete(t, s, e, 1);
+ var i = new Recorder.lamejs.Mp3Encoder(1, n.sampleRate, n.bitRate),
+ o = [],
+ _ = 0,
+ l = 0,
+ f = function () {
+ if (_ < r) {
+ 0 < (e = i.encodeBuffer(a.subarray(_, _ + 57600))).length && (l += e.buffer.byteLength, o.push(e.buffer)), _ += 57600, setTimeout(f);
+ } else {
+ var e;
+ 0 < (e = i.flush()).length && (l += e.buffer.byteLength, o.push(e.buffer));
+ var t = c.fn(o, l, r, n.sampleRate);
+ h(t, n), s(new Blob(o, {
+ type: "audio/mp3"
+ }));
}
- },
- n = function () {
- return u.G("NeedImport-2", ["mp3.js", "src/engine/mp3-engine.js"]);
- },
- d = t && "function" == typeof Worker;
- m.prototype.mp3 = function (r, i, o) {
- var e = this,
- _ = e.set,
- l = r.length;
- if (m.lamejs) {
- if (d) {
- var t = e.mp3_start(_);
- if (t) {
- if (t.isW) return e.mp3_encode(t, r), void e.mp3_complete(t, i, o, 1);
- e.mp3_stop(t);
- }
- }
- v(_);
- var f = new m.lamejs.Mp3Encoder(1, _.sampleRate, _.bitRate),
- c = new Int8Array(5e5),
- u = 0,
- h = 0,
- b = 0,
- p = function () {
- try {
- if (h < l) var e = f.encodeBuffer(r.subarray(h, h + 57600));else {
- b = 1;
- var e = f.flush();
- }
- } catch (e) {
- if (console.error(e), !b) try {
- f.flush();
- } catch (e) {
- console.error(e);
- }
- return void o("MP3 Encoder: " + e.message);
- }
- var t = e.length;
- if (0 < t) {
- if (u + t > c.length) {
- var a = new Int8Array(c.length + Math.max(5e5, t));
- a.set(c.subarray(0, u)), c = a;
- }
- c.set(e, u), u += t;
- }
- if (h < l) h += 57600, setTimeout(p);else {
- var n = [c.buffer.slice(0, u)],
- s = g.fn(n, u, l, _.sampleRate);
- w(s, _), i(n[0] || new ArrayBuffer(0), "audio/mp3");
- }
- };
- p();
- } else o(n());
- }, m.BindDestroy("mp3Worker", function () {
- h && (m.CLog("mp3Worker Destroy"), h.terminate(), h = null);
- }), m.prototype.mp3_envCheck = function (e, t) {
- var a = "";
- return t.takeoffEncodeChunk && (p() || (a = u("yhUs::当前浏览器版本太低,无法实时处理"))), a || m.lamejs || (a = n()), a;
- }, m.prototype.mp3_start = function (e) {
- return p(e);
- };
- var b = {
- id: 0
- },
- p = function (t, e) {
- var f,
- a = function (e) {
+ };
+ f();
+ }, Recorder.BindDestroy("mp3Worker", function () {
+ Recorder.CLog("mp3Worker Destroy"), i && i.terminate(), i = null;
+ }), Recorder.prototype.mp3_envCheck = function (e, t) {
+ var a = "";
+ return t.takeoffEncodeChunk && (e.canProcess ? s() || (a = "当前浏览器版本太低,无法实时处理") : a = e.envName + "环境不支持实时处理"), a;
+ }, Recorder.prototype.mp3_start = function (e) {
+ return s(e);
+ };
+ var o = {
+ id: 0
+ },
+ s = function (e) {
+ var t = i;
+ try {
+ if (!t) {
+ var a = ");wk_lame();var wk_ctxs={};self.onmessage=" + function (e) {
var t = e.data,
- a = f.wkScope.wk_ctxs,
- n = f.wkScope.wk_lame,
- s = f.wkScope.wk_mp3TrimFix,
- r = a[t.id];
- if ("init" == t.action) a[t.id] = {
+ a = wk_ctxs[t.id];
+ if ("init" == t.action) wk_ctxs[t.id] = {
sampleRate: t.sampleRate,
bitRate: t.bitRate,
takeoff: t.takeoff,
+ mp3Size: 0,
pcmSize: 0,
- memory: new Int8Array(5e5),
- mOffset: 0,
- encObj: new n.Mp3Encoder(1, t.sampleRate, t.bitRate)
- };else if (!r) return;
- var i = function (e) {
- var t = e.length;
- if (r.mOffset + t > r.memory.length) {
- var a = new Int8Array(r.memory.length + Math.max(5e5, t));
- a.set(r.memory.subarray(0, r.mOffset)), r.memory = a;
- }
- r.memory.set(e, r.mOffset), r.mOffset += t;
- };
+ encArr: [],
+ encObj: new wk_lame.Mp3Encoder(1, t.sampleRate, t.bitRate)
+ };else if (!a) return;
switch (t.action) {
case "stop":
- if (!r.isCp) try {
- r.encObj.flush();
- } catch (e) {
- console.error(e);
- }
- r.encObj = null, delete a[t.id];
+ a.encObj = null, delete wk_ctxs[t.id];
break;
case "encode":
- if (r.isCp) break;
- r.pcmSize += t.pcm.length;
- try {
- var o = r.encObj.encodeBuffer(t.pcm);
- } catch (e) {
- r.err = e, console.error(e);
- }
- o && 0 < o.length && (r.takeoff ? c.onmessage({
+ a.pcmSize += t.pcm.length, 0 < (s = a.encObj.encodeBuffer(t.pcm)).length && (a.takeoff ? self.postMessage({
action: "takeoff",
id: t.id,
- chunk: o
- }) : i(o));
+ chunk: s
+ }) : (a.mp3Size += s.buffer.byteLength, a.encArr.push(s.buffer)));
break;
case "complete":
- r.isCp = 1;
- try {
- var o = r.encObj.flush();
- } catch (e) {
- r.err = e, console.error(e);
- }
- if (o && 0 < o.length && (r.takeoff ? c.onmessage({
+ var s;
+ 0 < (s = a.encObj.flush()).length && (a.takeoff ? self.postMessage({
action: "takeoff",
id: t.id,
- chunk: o
- }) : i(o)), r.err) {
- c.onmessage({
- action: t.action,
- id: t.id,
- err: "MP3 Encoder: " + r.err.message
- });
- break;
- }
- var _ = [r.memory.buffer.slice(0, r.mOffset)],
- l = s.fn(_, r.mOffset, r.pcmSize, r.sampleRate);
- c.onmessage({
+ chunk: s
+ }) : (a.mp3Size += s.buffer.byteLength, a.encArr.push(s.buffer)));
+ var n = wk_mp3TrimFix.fn(a.encArr, a.mp3Size, a.pcmSize, a.sampleRate);
+ self.postMessage({
action: t.action,
id: t.id,
- blob: _[0] || new ArrayBuffer(0),
- meta: l
+ blob: new Blob(a.encArr, {
+ type: "audio/mp3"
+ }),
+ meta: n
});
}
- },
- n = function (n) {
- c.onmessage = function (e) {
- var t = e;
- n && (t = e.data);
- var a = b[t.id];
- a && ("takeoff" == t.action ? a.set.takeoffEncodeChunk(new Uint8Array(t.chunk.buffer)) : (a.call && a.call(t), a.call = null));
- };
- },
- s = function () {
- var e = {
- worker: c,
- set: t
- };
- return t ? (e.id = ++b.id, b[e.id] = e, v(t), c.postMessage({
- action: "init",
- id: e.id,
- sampleRate: t.sampleRate,
- bitRate: t.bitRate,
- takeoff: !!t.takeoffEncodeChunk,
- x: new Int16Array(5)
- })) : c.postMessage({
- x: new Int16Array(5)
- }), e;
- },
- c = h;
- if (e || !d) return m.CLog(u("k9PT::当前环境不支持Web Worker,mp3实时编码器运行在主线程中"), 3), c = {
- postMessage: function (e) {
- a({
- data: e
- });
- }
- }, f = {
- wkScope: {
- wk_ctxs: {},
- wk_lame: m.lamejs,
- wk_mp3TrimFix: g
- }
- }, n(), s();
- try {
- if (!c) {
- var r = (a + "").replace(/[\w\$]+\.onmessage/g, "self.postMessage"),
- i = ");wk_lame();self.onmessage=" + (r = r.replace(/[\w\$]+\.wkScope/g, "wkScope"));
- i += ";var wkScope={ wk_ctxs:{},wk_lame:wk_lame", i += ",wk_mp3TrimFix:{rm:" + g.rm + ",fn:" + g.fn + "} }";
- var o = m.lamejs.toString(),
- _ = (window.URL || webkitURL).createObjectURL(new Blob(["var wk_lame=(", o, i], {
- type: "text/javascript"
- }));
- c = new Worker(_), setTimeout(function () {
- (window.URL || webkitURL).revokeObjectURL(_);
- }, 1e4), n(1);
- }
- var l = s();
- return l.isW = 1, h = c, l;
- } catch (e) {
- return c && c.terminate(), console.error(e), p(t, 1);
- }
- };
- m.prototype.mp3_stop = function (e) {
- if (e && e.worker) {
- e.worker.postMessage({
- action: "stop",
- id: e.id
- }), e.worker = null, delete b[e.id];
- var t = -1;
- for (var a in b) t++;
- t && m.CLog(u("fT6M::mp3 worker剩{1}个未stop", 0, t), 3);
- }
- }, m.prototype.mp3_encode = function (e, t) {
- e && e.worker && e.worker.postMessage({
- action: "encode",
- id: e.id,
- pcm: t
- });
- }, m.prototype.mp3_complete = function (t, a, n, s) {
- var r = this;
- t && t.worker ? (t.call = function (e) {
- s && r.mp3_stop(t), e.err ? n(e.err) : (w(e.meta, t.set), a(e.blob, "audio/mp3"));
- }, t.worker.postMessage({
- action: "complete",
- id: t.id
- })) : n(u("mPxH::mp3编码器未start"));
- }, m.mp3ReadMeta = function (e, t) {
- var a = "undefined" != typeof window && window.parseInt || "undefined" != typeof self && self.parseInt || parseInt,
- n = new Uint8Array(e[0] || []);
- if (n.length < 4) return null;
- var s = function (e, t) {
- return ("0000000" + ((t || n)[e] || 0).toString(2)).substr(-8);
- },
- r = s(0) + s(1),
- i = s(2) + s(3);
- if (!/^1{11}/.test(r)) return null;
- var o = {
- "00": 2.5,
- 10: 2,
- 11: 1
- }[r.substr(11, 2)],
- _ = {
- "01": 3
- }[r.substr(13, 2)],
- l = {
- 1: [44100, 48e3, 32e3],
- 2: [22050, 24e3, 16e3],
- 2.5: [11025, 12e3, 8e3]
- }[o];
- l && (l = l[a(i.substr(4, 2), 2)]);
- var f = [[0, 8, 16, 24, 32, 40, 48, 56, 64, 80, 96, 112, 128, 144, 160], [0, 32, 40, 48, 56, 64, 80, 96, 112, 128, 160, 192, 224, 256, 320]][1 == o ? 1 : 0][a(i.substr(0, 4), 2)];
- if (!(o && _ && f && l)) return null;
- for (var c = Math.round(8 * t / f), u = 1 == _ ? 384 : 2 == _ ? 1152 : 1 == o ? 1152 : 576, h = u / l * 1e3, b = Math.floor(u * f / 8 / l * 1e3), p = 0, m = 0, v = 0; v < e.length; v++) {
- var d = e[v];
- if (m += d.byteLength, b + 3 <= m) {
- var g = new Uint8Array(d),
- w = d.byteLength - (m - (b + 3) + 1),
- S = s(w, g);
- p = "1" == S.charAt(6);
- break;
- }
- }
- return p && b++, {
- version: o,
- layer: _,
- sampleRate: l,
- bitRate: f,
- duration: c,
- size: t,
- hasPadding: p,
- frameSize: b,
- frameDurationFloat: h
- };
- };
- var g = {
- rm: m.mp3ReadMeta,
- fn: function (e, t, a, n) {
- var s = this.rm(e, t);
- if (!s) return {
- err: "mp3 unknown format"
};
- var r = Math.round(a / n * 1e3),
- i = Math.floor((s.duration - r) / s.frameDurationFloat);
- if (0 < i) {
- var o = i * s.frameSize - (s.hasPadding ? 1 : 0);
- t -= o;
- for (var _ = 0, l = [], f = 0; f < e.length; f++) {
- var c = e[f];
- if (o <= 0) break;
- o >= c.byteLength ? (o -= c.byteLength, l.push(c), e.splice(f, 1), f--) : (e[f] = c.slice(o), _ = c, o = 0);
- }
- var u = this.rm(e, t);
- if (!u) {
- _ && (e[0] = _);
- for (var f = 0; f < l.length; f++) e.splice(f, 0, l[f]);
- s.err = "mp3 fix error: 已还原,错误原因不明";
- }
- var h = s.trimFix = {};
- h.remove = i, h.removeDuration = Math.round(i * s.frameDurationFloat), h.duration = Math.round(8 * t / s.bitRate);
- }
- return s;
+ a += ";var wk_mp3TrimFix={rm:" + c.rm + ",fn:" + c.fn + "}";
+ var s = Recorder.lamejs.toString(),
+ n = (window.URL || webkitURL).createObjectURL(new Blob(["var wk_lame=(", s, a], {
+ type: "text/javascript"
+ }));
+ t = new Worker(n), setTimeout(function () {
+ (window.URL || webkitURL).revokeObjectURL(n);
+ }, 1e4), t.onmessage = function (e) {
+ var t = e.data,
+ a = o[t.id];
+ a && ("takeoff" == t.action ? a.set.takeoffEncodeChunk(new Uint8Array(t.chunk.buffer)) : (a.call && a.call(t), a.call = null));
+ };
}
+ var r = {
+ worker: t,
+ set: e,
+ takeoffQueue: []
+ };
+ return e ? (r.id = ++o.id, o[r.id] = r, t.postMessage({
+ action: "init",
+ id: r.id,
+ sampleRate: e.sampleRate,
+ bitRate: e.bitRate,
+ takeoff: !!e.takeoffEncodeChunk,
+ x: new Int16Array(5)
+ })) : t.postMessage({
+ x: new Int16Array(5)
+ }), i = t, r;
+ } catch (e) {
+ return t && t.terminate(), console.error(e), null;
+ }
+ };
+ Recorder.prototype.mp3_stop = function (e) {
+ if (e && e.worker) {
+ e.worker.postMessage({
+ action: "stop",
+ id: e.id
+ }), e.worker = null, delete o[e.id];
+ var t = -1;
+ for (var a in o) t++;
+ t && Recorder.CLog("mp3 worker剩" + t + "个在串行等待", 3);
+ }
+ }, Recorder.prototype.mp3_encode = function (e, t) {
+ e && e.worker && e.worker.postMessage({
+ action: "encode",
+ id: e.id,
+ pcm: t
+ });
+ }, Recorder.prototype.mp3_complete = function (t, a, e, s) {
+ var n = this;
+ t && t.worker ? (t.call = function (e) {
+ h(e.meta, t.set), a(e.blob), s && n.mp3_stop(t);
+ }, t.worker.postMessage({
+ action: "complete",
+ id: t.id
+ })) : e("mp3编码器未打开");
+ }, Recorder.mp3ReadMeta = function (e, t) {
+ var a = "object" == typeof window ? window.parseInt : self.parseInt,
+ s = new Uint8Array(e[0] || []);
+ if (s.length < 4) return null;
+ var n = function (e, t) {
+ return ("0000000" + ((t || s)[e] || 0).toString(2)).substr(-8);
},
- w = function (e, t) {
- var a = "MP3 Info: ";
- (e.sampleRate && e.sampleRate != t.sampleRate || e.bitRate && e.bitRate != t.bitRate) && (m.CLog(a + u("uY9i::和设置的不匹配{1},已更新成{2}", 0, "set:" + t.bitRate + "kbps " + t.sampleRate + "hz", "set:" + e.bitRate + "kbps " + e.sampleRate + "hz"), 3, t), t.sampleRate = e.sampleRate, t.bitRate = e.bitRate);
- var n = e.trimFix;
- n ? (a += u("iMSm::Fix移除{1}帧", 0, n.remove) + " " + n.removeDuration + "ms -> " + n.duration + "ms", 2 < n.remove && (e.err = (e.err ? e.err + ", " : "") + u("b9zm::移除帧数过多"))) : a += (e.duration || "-") + "ms", e.err ? m.CLog(a, 1, e.err, e) : m.CLog(a, e);
- };
- }(a, 0, n.$T, t);
-}(), function (e) {
+ r = n(0) + n(1),
+ i = n(2) + n(3);
+ if (!/^1{11}/.test(r)) return null;
+ var o = {
+ "00": 2.5,
+ 10: 2,
+ 11: 1
+ }[r.substr(11, 2)],
+ _ = {
+ "01": 3
+ }[r.substr(13, 2)],
+ l = {
+ 1: [44100, 48e3, 32e3],
+ 2: [22050, 24e3, 16e3],
+ 2.5: [11025, 12e3, 8e3]
+ }[o];
+ l && (l = l[a(i.substr(4, 2), 2)]);
+ var f = [[0, 8, 16, 24, 32, 40, 48, 56, 64, 80, 96, 112, 128, 144, 160], [0, 32, 40, 48, 56, 64, 80, 96, 112, 128, 160, 192, 224, 256, 320]][1 == o ? 1 : 0][a(i.substr(0, 4), 2)];
+ if (!(o && _ && f && l)) return null;
+ for (var c = Math.round(8 * t / f), h = 1 == _ ? 384 : 2 == _ ? 1152 : 1 == o ? 1152 : 576, u = h / l * 1e3, m = Math.floor(h * f / 8 / l * 1e3), p = 0, b = 0, v = 0; v < e.length; v++) {
+ var d = e[v];
+ if (m + 3 <= (b += d.byteLength)) {
+ var g = new Uint8Array(d);
+ p = "1" == n(d.byteLength - (b - (m + 3) + 1), g).charAt(6);
+ break;
+ }
+ }
+ return p && m++, {
+ version: o,
+ layer: _,
+ sampleRate: l,
+ bitRate: f,
+ duration: c,
+ size: t,
+ hasPadding: p,
+ frameSize: m,
+ frameDurationFloat: u
+ };
+ };
+ var c = {
+ rm: Recorder.mp3ReadMeta,
+ fn: function (e, t, a, s) {
+ var n = this.rm(e, t);
+ if (!n) return {
+ err: "mp3非预定格式"
+ };
+ var r = Math.round(a / s * 1e3),
+ i = Math.floor((n.duration - r) / n.frameDurationFloat);
+ if (0 < i) {
+ var o = i * n.frameSize - (n.hasPadding ? 1 : 0);
+ t -= o;
+ for (var _ = 0, l = [], f = 0; f < e.length; f++) {
+ var c = e[f];
+ if (o <= 0) break;
+ o >= c.byteLength ? (o -= c.byteLength, l.push(c), e.splice(f, 1), f--) : (e[f] = c.slice(o), _ = c, o = 0);
+ }
+ if (!this.rm(e, t)) {
+ _ && (e[0] = _);
+ for (f = 0; f < l.length; f++) e.splice(f, 0, l[f]);
+ n.err = "fix后数据错误,已还原,错误原因不明";
+ }
+ var h = n.trimFix = {};
+ h.remove = i, h.removeDuration = Math.round(i * n.frameDurationFloat), h.duration = Math.round(8 * t / n.bitRate);
+ }
+ return n;
+ }
+ },
+ h = function (e, t) {
+ var a = "MP3信息 ";
+ (e.sampleRate && e.sampleRate != t.sampleRate || e.bitRate && e.bitRate != t.bitRate) && (Recorder.CLog(a + "和设置的不匹配set:" + t.bitRate + "kbps " + t.sampleRate + "hz,已更新set:" + e.bitRate + "kbps " + e.sampleRate + "hz", 3, t), t.sampleRate = e.sampleRate, t.bitRate = e.bitRate);
+ var s = e.trimFix;
+ s ? (a += "Fix移除" + s.remove + "帧" + s.removeDuration + "ms -> " + s.duration + "ms", 2 < s.remove && (e.err = (e.err ? e.err + ", " : "") + "移除帧数过多")) : a += (e.duration || "-") + "ms", e.err ? Recorder.CLog(a, 1, e.err, e) : Recorder.CLog(a, e);
+ };
+}(), function () {
function t() {
- var d = function (e) {
- return Math.log(e) / Math.log(10);
- },
- me = function (e) {
- throw new Error("abort(" + e + ")");
- };
- function S(e) {
+ var B = function (e) {
+ return Math.log(e) / Math.log(10);
+ };
+ function A(e) {
return new Int8Array(e);
}
- function s(e) {
+ function n(e) {
return new Int16Array(e);
}
- function ve(e) {
+ function Ae(e) {
return new Int32Array(e);
}
- function de(e) {
+ function Be(e) {
return new Float32Array(e);
}
- function n(e) {
+ function s(e) {
return new Float64Array(e);
}
- function ge(e) {
- if (1 == e.length) return de(e[0]);
+ function ke(e) {
+ if (1 == e.length) return Be(e[0]);
var t = e[0];
e = e.slice(1);
- for (var a = [], n = 0; n < t; n++) a.push(ge(e));
+ for (var a = [], s = 0; s < t; s++) a.push(ke(e));
return a;
}
- function w(e) {
- if (1 == e.length) return ve(e[0]);
+ function Y(e) {
+ if (1 == e.length) return Ae(e[0]);
var t = e[0];
e = e.slice(1);
- for (var a = [], n = 0; n < t; n++) a.push(w(e));
+ for (var a = [], s = 0; s < t; s++) a.push(Y(e));
return a;
}
- function M(e) {
- if (1 == e.length) return s(e[0]);
+ function p(e) {
+ if (1 == e.length) return n(e[0]);
var t = e[0];
e = e.slice(1);
- for (var a = [], n = 0; n < t; n++) a.push(M(e));
+ for (var a = [], s = 0; s < t; s++) a.push(p(e));
return a;
}
- function E(e) {
+ function O(e) {
if (1 == e.length) return new Array(e[0]);
var t = e[0];
e = e.slice(1);
- for (var a = [], n = 0; n < t; n++) a.push(E(e));
+ for (var a = [], s = 0; s < t; s++) a.push(O(e));
return a;
}
- var we = {
- fill: function (e, t, a, n) {
- if (2 == arguments.length) for (var s = 0; s < e.length; s++) e[s] = t;else for (var s = t; s < a; s++) e[s] = n;
+ var ye = {
+ fill: function (e, t, a, s) {
+ if (2 == arguments.length) for (var n = 0; n < e.length; n++) e[n] = t;else for (n = t; n < a; n++) e[n] = s;
}
},
- I = {
- arraycopy: function (e, t, a, n, s) {
- for (var r = t + s; t < r;) a[n++] = e[t++];
+ $ = {
+ arraycopy: function (e, t, a, s, n) {
+ for (var r = t + n; t < r;) a[s++] = e[t++];
}
},
- V = {};
- function Se(e) {
+ ee = {};
+ function Te(e) {
this.ordinal = e;
}
- V.SQRT2 = 1.4142135623730951, V.FAST_LOG10 = function (e) {
- return d(e);
- }, V.FAST_LOG10_X = function (e, t) {
- return d(e) * t;
- }, Se.short_block_allowed = new Se(0), Se.short_block_coupled = new Se(1), Se.short_block_dispensed = new Se(2), Se.short_block_forced = new Se(3);
- var D = {};
- function Me(e) {
+ ee.SQRT2 = 1.4142135623730951, ee.FAST_LOG10 = function (e) {
+ return B(e);
+ }, ee.FAST_LOG10_X = function (e, t) {
+ return B(e) * t;
+ }, Te.short_block_allowed = new Te(0), Te.short_block_coupled = new Te(1), Te.short_block_dispensed = new Te(2), Te.short_block_forced = new Te(3);
+ var K = {};
+ function xe(e) {
this.ordinal = e;
}
- function ye(e) {
+ K.MAX_VALUE = 3.4028235e38, xe.vbr_off = new xe(0), xe.vbr_mt = new xe(1), xe.vbr_rh = new xe(2), xe.vbr_abr = new xe(3), xe.vbr_mtrh = new xe(4), xe.vbr_default = xe.vbr_mtrh;
+ function Ee(e) {
var t = e;
this.ordinal = function () {
return t;
};
}
- function A() {
- var S = null;
+ function k() {
+ var M = null;
function v(e) {
this.bits = 0 | e;
}
this.qupvt = null, this.setModules = function (e) {
- this.qupvt = e, S = e;
+ this.qupvt = e, M = e;
};
- var s = [[0, 0], [0, 0], [0, 0], [0, 0], [0, 0], [0, 1], [1, 1], [1, 1], [1, 2], [2, 2], [2, 3], [2, 3], [3, 4], [3, 4], [3, 4], [4, 5], [4, 5], [4, 6], [5, 6], [5, 6], [5, 7], [6, 7], [6, 7]];
- function M(e, t, a, n, s, r) {
+ var n = [[0, 0], [0, 0], [0, 0], [0, 0], [0, 0], [0, 1], [1, 1], [1, 1], [1, 2], [2, 2], [2, 3], [2, 3], [3, 4], [3, 4], [3, 4], [4, 5], [4, 5], [4, 6], [5, 6], [5, 6], [5, 7], [6, 7], [6, 7]];
+ function w(e, t, a, s, n, r) {
var i = .5946 / t;
- for (e >>= 1; 0 != e--;) s[r++] = i > a[n++] ? 0 : 1, s[r++] = i > a[n++] ? 0 : 1;
+ for (e >>= 1; 0 != e--;) n[r++] = i > a[s++] ? 0 : 1, n[r++] = i > a[s++] ? 0 : 1;
}
- function y(e, t, a, n, s, r) {
+ function R(e, t, a, s, n, r) {
var i = (e >>= 1) % 2;
for (e >>= 1; 0 != e--;) {
- var o, _, l, f, c, u, h, b;
- o = a[n++] * t, _ = a[n++] * t, c = 0 | o, l = a[n++] * t, u = 0 | _, f = a[n++] * t, h = 0 | l, o += S.adj43[c], b = 0 | f, _ += S.adj43[u], s[r++] = 0 | o, l += S.adj43[h], s[r++] = 0 | _, f += S.adj43[b], s[r++] = 0 | l, s[r++] = 0 | f;
+ var o, _, l, f, c, h, u, m;
+ o = a[s++] * t, _ = a[s++] * t, c = 0 | o, l = a[s++] * t, h = 0 | _, f = a[s++] * t, u = 0 | l, o += M.adj43[c], m = 0 | f, _ += M.adj43[h], n[r++] = 0 | o, l += M.adj43[u], n[r++] = 0 | _, f += M.adj43[m], n[r++] = 0 | l, n[r++] = 0 | f;
}
- 0 != i && (o = a[n++] * t, _ = a[n++] * t, c = 0 | o, u = 0 | _, o += S.adj43[c], _ += S.adj43[u], s[r++] = 0 | o, s[r++] = 0 | _);
+ 0 != i && (c = 0 | (o = a[s++] * t), h = 0 | (_ = a[s++] * t), o += M.adj43[c], _ += M.adj43[h], n[r++] = 0 | o, n[r++] = 0 | _);
}
var o = [1, 2, 5, 7, 7, 10, 10, 13, 13, 13, 13, 13, 13, 13, 13];
- function d(e, t, a, n) {
- var s = function (e, t, a) {
- var n = 0,
- s = 0;
+ function d(e, t, a, s) {
+ var n = function (e, t, a) {
+ var s = 0,
+ n = 0;
do {
var r = e[t++],
i = e[t++];
- n < r && (n = r), s < i && (s = i);
+ s < r && (s = r), n < i && (n = i);
} while (t < a);
- return n < s && (n = s), n;
+ return s < n && (s = n), s;
}(e, t, a);
- switch (s) {
+ switch (n) {
case 0:
- return s;
+ return n;
case 1:
- return function (e, t, a, n) {
- var s = 0,
- r = k.ht[1].hlen;
+ return function (e, t, a, s) {
+ var n = 0,
+ r = F.ht[1].hlen;
do {
var i = 2 * e[t + 0] + e[t + 1];
- t += 2, s += r[i];
+ t += 2, n += r[i];
} while (t < a);
- return n.bits += s, 1;
- }(e, t, a, n);
+ return s.bits += n, 1;
+ }(e, t, a, s);
case 2:
case 3:
- return function (e, t, a, n, s) {
+ return function (e, t, a, s, n) {
var r,
i,
o = 0,
- _ = k.ht[n].xlen;
- i = 2 == n ? k.table23 : k.table56;
+ _ = F.ht[s].xlen;
+ i = 2 == s ? F.table23 : F.table56;
do {
var l = e[t + 0] * _ + e[t + 1];
t += 2, o += i[l];
} while (t < a);
- return (r = 65535 & o) < (o >>= 16) && (o = r, n++), s.bits += o, n;
- }(e, t, a, o[s - 1], n);
+ return (r = 65535 & o) < (o >>= 16) && (o = r, s++), n.bits += o, s;
+ }(e, t, a, o[n - 1], s);
case 4:
case 5:
case 6:
@@ -35188,84 +34837,86 @@ src: recorder-core.js,engine/mp3.js,engine/mp3-engine.js
case 13:
case 14:
case 15:
- return function (e, t, a, n, s) {
+ return function (e, t, a, s, n) {
var r = 0,
i = 0,
o = 0,
- _ = k.ht[n].xlen,
- l = k.ht[n].hlen,
- f = k.ht[n + 1].hlen,
- c = k.ht[n + 2].hlen;
+ _ = F.ht[s].xlen,
+ l = F.ht[s].hlen,
+ f = F.ht[s + 1].hlen,
+ c = F.ht[s + 2].hlen;
do {
- var u = e[t + 0] * _ + e[t + 1];
- t += 2, r += l[u], i += f[u], o += c[u];
+ var h = e[t + 0] * _ + e[t + 1];
+ t += 2, r += l[h], i += f[h], o += c[h];
} while (t < a);
- var h = n;
- return i < r && (r = i, h++), o < r && (r = o, h = n + 2), s.bits += r, h;
- }(e, t, a, o[s - 1], n);
+ var u = s;
+ return i < r && (r = i, u++), o < r && (r = o, u = s + 2), n.bits += r, u;
+ }(e, t, a, o[n - 1], s);
default:
+ if (x.IXMAX_VAL < n) return s.bits = x.LARGE_BITS, -1;
var r, i;
- for (T.IXMAX_VAL < s && me(), s -= 15, r = 24; r < 32 && !(k.ht[r].linmax >= s); r++);
- for (i = r - 8; i < 24 && !(k.ht[i].linmax >= s); i++);
- return function (e, t, a, n, s, r) {
+ for (n -= 15, r = 24; r < 32 && !(F.ht[r].linmax >= n); r++);
+ for (i = r - 8; i < 24 && !(F.ht[i].linmax >= n); i++);
+ return function (e, t, a, s, n, r) {
var i,
- o = 65536 * k.ht[n].xlen + k.ht[s].xlen,
+ o = 65536 * F.ht[s].xlen + F.ht[n].xlen,
_ = 0;
do {
var l = e[t++],
f = e[t++];
- 0 != l && (14 < l && (l = 15, _ += o), l *= 16), 0 != f && (14 < f && (f = 15, _ += o), l += f), _ += k.largetbl[l];
+ 0 != l && (14 < l && (l = 15, _ += o), l *= 16), 0 != f && (14 < f && (f = 15, _ += o), l += f), _ += F.largetbl[l];
} while (t < a);
- return (i = 65535 & _) < (_ >>= 16) && (_ = i, n = s), r.bits += _, n;
- }(e, t, a, i, r, n);
+ return (i = 65535 & _) < (_ >>= 16) && (_ = i, s = n), r.bits += _, s;
+ }(e, t, a, i, r, s);
}
}
- function h(e, t, a, n, s, r, i, o) {
- for (var _ = t.big_values, l = 2; l < Ae.SBMAX_l + 1; l++) {
+ function u(e, t, a, s, n, r, i, o) {
+ for (var _ = t.big_values, l = 2; l < Pe.SBMAX_l + 1; l++) {
var f = e.scalefac_band.l[l];
if (_ <= f) break;
- var c = s[l - 2] + t.count1bits;
+ var c = n[l - 2] + t.count1bits;
if (a.part2_3_length <= c) break;
- var u = new v(c),
- h = d(n, f, _, u);
- c = u.bits, a.part2_3_length <= c || (a.assign(t), a.part2_3_length = c, a.region0_count = r[l - 2], a.region1_count = l - 2 - r[l - 2], a.table_select[0] = i[l - 2], a.table_select[1] = o[l - 2], a.table_select[2] = h);
+ var h = new v(c),
+ u = d(s, f, _, h);
+ c = h.bits, a.part2_3_length <= c || (a.assign(t), a.part2_3_length = c, a.region0_count = r[l - 2], a.region1_count = l - 2 - r[l - 2], a.table_select[0] = i[l - 2], a.table_select[1] = o[l - 2], a.table_select[2] = u);
}
}
this.noquant_count_bits = function (e, t, a) {
- var n = t.l3_enc,
- s = Math.min(576, t.max_nonzero_coeff + 2 >> 1 << 1);
- for (null != a && (a.sfb_count1 = 0); 1 < s && 0 == (n[s - 1] | n[s - 2]); s -= 2);
- t.count1 = s;
- for (var r = 0, i = 0; 3 < s; s -= 4) {
+ var s = t.l3_enc,
+ n = Math.min(576, t.max_nonzero_coeff + 2 >> 1 << 1);
+ for (null != a && (a.sfb_count1 = 0); 1 < n && 0 == (s[n - 1] | s[n - 2]); n -= 2);
+ t.count1 = n;
+ for (var r = 0, i = 0; 3 < n; n -= 4) {
var o;
- if (1 < (2147483647 & (n[s - 1] | n[s - 2] | n[s - 3] | n[s - 4]))) break;
- o = 2 * (2 * (2 * n[s - 4] + n[s - 3]) + n[s - 2]) + n[s - 1], r += k.t32l[o], i += k.t33l[o];
+ if (1 < (2147483647 & (s[n - 1] | s[n - 2] | s[n - 3] | s[n - 4]))) break;
+ o = 2 * (2 * (2 * s[n - 4] + s[n - 3]) + s[n - 2]) + s[n - 1], r += F.t32l[o], i += F.t33l[o];
}
var _ = r;
- if (t.count1table_select = 0, i < r && (_ = i, t.count1table_select = 1), t.count1bits = _, 0 == (t.big_values = s)) return _;
- if (t.block_type == Ae.SHORT_TYPE) (r = 3 * e.scalefac_band.s[3]) > t.big_values && (r = t.big_values), i = t.big_values;else if (t.block_type == Ae.NORM_TYPE) {
- if (r = t.region0_count = e.bv_scf[s - 2], i = t.region1_count = e.bv_scf[s - 1], i = e.scalefac_band.l[r + i + 2], r = e.scalefac_band.l[r + 1], i < s) {
+ if (t.count1table_select = 0, i < r && (_ = i, t.count1table_select = 1), t.count1bits = _, 0 == (t.big_values = n)) return _;
+ if (t.block_type == Pe.SHORT_TYPE) (r = 3 * e.scalefac_band.s[3]) > t.big_values && (r = t.big_values), i = t.big_values;else if (t.block_type == Pe.NORM_TYPE) {
+ if (r = t.region0_count = e.bv_scf[n - 2], i = t.region1_count = e.bv_scf[n - 1], i = e.scalefac_band.l[r + i + 2], r = e.scalefac_band.l[r + 1], i < n) {
var l = new v(_);
- t.table_select[2] = d(n, i, s, l), _ = l.bits;
+ t.table_select[2] = d(s, i, n, l), _ = l.bits;
}
- } else t.region0_count = 7, t.region1_count = Ae.SBMAX_l - 1 - 7 - 1, r = e.scalefac_band.l[8], (i = s) < r && (r = i);
- if (r = Math.min(r, s), i = Math.min(i, s), 0 < r) {
- var l = new v(_);
- t.table_select[0] = d(n, 0, r, l), _ = l.bits;
+ } else t.region0_count = 7, t.region1_count = Pe.SBMAX_l - 1 - 7 - 1, (i = n) < (r = e.scalefac_band.l[8]) && (r = i);
+ if (r = Math.min(r, n), i = Math.min(i, n), 0 < r) {
+ l = new v(_);
+ t.table_select[0] = d(s, 0, r, l), _ = l.bits;
}
if (r < i) {
- var l = new v(_);
- t.table_select[1] = d(n, r, i, l), _ = l.bits;
+ l = new v(_);
+ t.table_select[1] = d(s, r, i, l), _ = l.bits;
}
- if (2 == e.use_best_huffman && me(), null != a && t.block_type == Ae.NORM_TYPE) {
+ if (2 == e.use_best_huffman && (t.part2_3_length = _, best_huffman_divide(e, t), _ = t.part2_3_length), null != a && t.block_type == Pe.NORM_TYPE) {
for (var f = 0; e.scalefac_band.l[f] < t.big_values;) f++;
a.sfb_count1 = f;
}
return _;
- }, this.count_bits = function (e, t, a, n) {
- var s = a.l3_enc,
- r = T.IXMAX_VAL / S.IPOW20(a.global_gain);
- return a.xrpow_max > r ? T.LARGE_BITS : (function (e, t, a, n, s) {
+ }, this.count_bits = function (e, t, a, s) {
+ var n = a.l3_enc,
+ r = x.IXMAX_VAL / M.IPOW20(a.global_gain);
+ if (a.xrpow_max > r) return x.LARGE_BITS;
+ if (function (e, t, a, s, n) {
var r,
i,
o,
@@ -35273,123 +34924,127 @@ src: recorder-core.js,engine/mp3.js,engine/mp3-engine.js
l = 0,
f = 0,
c = 0,
- u = t,
- h = 0,
- b = u,
+ h = t,
+ u = 0,
+ m = h,
p = 0,
- m = e,
+ b = e,
v = 0;
- for (o = null != s && n.global_gain == s.global_gain, i = n.block_type == Ae.SHORT_TYPE ? 38 : 21, r = 0; r <= i; r++) {
+ for (o = null != n && s.global_gain == n.global_gain, i = s.block_type == Pe.SHORT_TYPE ? 38 : 21, r = 0; r <= i; r++) {
var d = -1;
- if ((o || n.block_type == Ae.NORM_TYPE) && (d = n.global_gain - (n.scalefac[r] + (0 != n.preflag ? S.pretab[r] : 0) << n.scalefac_scale + 1) - 8 * n.subblock_gain[n.window[r]]), o && s.step[r] == d) 0 != l && (y(l, a, m, v, b, p), l = 0), 0 != f && me();else {
+ if ((o || s.block_type == Pe.NORM_TYPE) && (d = s.global_gain - (s.scalefac[r] + (0 != s.preflag ? M.pretab[r] : 0) << s.scalefac_scale + 1) - 8 * s.subblock_gain[s.window[r]]), o && n.step[r] == d) 0 != l && (R(l, a, b, v, m, p), l = 0), 0 != f && (w(f, a, b, v, m, p), f = 0);else {
var g,
- w = n.width[r];
- if (_ + n.width[r] > n.max_nonzero_coeff && (g = n.max_nonzero_coeff - _ + 1, we.fill(t, n.max_nonzero_coeff, 576, 0), (w = g) < 0 && (w = 0), r = i + 1), 0 == l && 0 == f && (b = u, p = h, m = e, v = c), null != s && 0 < s.sfb_count1 && r >= s.sfb_count1 && 0 < s.step[r] && d >= s.step[r] ? (0 != l && (y(l, a, m, v, b, p), l = 0, b = u, p = h, m = e, v = c), f += w) : (0 != f && (M(f, a, m, v, b, p), f = 0, b = u, p = h, m = e, v = c), l += w), w <= 0) {
- 0 != f && me(), 0 != l && me();
+ S = s.width[r];
+ if (_ + s.width[r] > s.max_nonzero_coeff && (g = s.max_nonzero_coeff - _ + 1, ye.fill(t, s.max_nonzero_coeff, 576, 0), (S = g) < 0 && (S = 0), r = i + 1), 0 == l && 0 == f && (m = h, p = u, b = e, v = c), null != n && 0 < n.sfb_count1 && r >= n.sfb_count1 && 0 < n.step[r] && d >= n.step[r] ? (0 != l && (R(l, a, b, v, m, p), l = 0, m = h, p = u, b = e, v = c), f += S) : (0 != f && (w(f, a, b, v, m, p), f = 0, m = h, p = u, b = e, v = c), l += S), S <= 0) {
+ 0 != f && (w(f, a, b, v, m, p), f = 0), 0 != l && (R(l, a, b, v, m, p), l = 0);
break;
}
}
- r <= i && (h += n.width[r], c += n.width[r], _ += n.width[r]);
+ r <= i && (u += s.width[r], c += s.width[r], _ += s.width[r]);
}
- 0 != l && (y(l, a, m, v, b, p), l = 0), 0 != f && me();
- }(t, s, S.IPOW20(a.global_gain), a, n), 0 != (2 & e.substep_shaping) && me(), this.noquant_count_bits(e, a, n));
+ 0 != l && (R(l, a, b, v, m, p), l = 0), 0 != f && (w(f, a, b, v, m, p), f = 0);
+ }(t, n, M.IPOW20(a.global_gain), a, s), 0 != (2 & e.substep_shaping)) for (var i = 0, o = a.global_gain + a.scalefac_scale, _ = .634521682242439 / M.IPOW20(o), l = 0; l < a.sfbmax; l++) {
+ var f,
+ c = a.width[l];
+ if (0 == e.pseudohalf[l]) i += c;else for (f = i, i += c; f < i; ++f) n[f] = t[f] >= _ ? n[f] : 0;
+ }
+ return this.noquant_count_bits(e, a, s);
}, this.best_huffman_divide = function (e, t) {
- var a = new B(),
- n = t.l3_enc,
- s = ve(23),
- r = ve(23),
- i = ve(23),
- o = ve(23);
- if (t.block_type != Ae.SHORT_TYPE || 1 != e.mode_gr) {
- a.assign(t), t.block_type == Ae.NORM_TYPE && (function (e, t, a, n, s, r, i) {
- for (var o = t.big_values, _ = 0; _ <= 22; _++) n[_] = T.LARGE_BITS;
- for (var _ = 0; _ < 16; _++) {
+ var a = new T(),
+ s = t.l3_enc,
+ n = Ae(23),
+ r = Ae(23),
+ i = Ae(23),
+ o = Ae(23);
+ if (t.block_type != Pe.SHORT_TYPE || 1 != e.mode_gr) {
+ a.assign(t), t.block_type == Pe.NORM_TYPE && (!function (e, t, a, s, n, r, i) {
+ for (var o = t.big_values, _ = 0; _ <= 22; _++) s[_] = x.LARGE_BITS;
+ for (_ = 0; _ < 16; _++) {
var l = e.scalefac_band.l[_ + 1];
if (o <= l) break;
var f = 0,
c = new v(f),
- u = d(a, 0, l, c);
+ h = d(a, 0, l, c);
f = c.bits;
- for (var h = 0; h < 8; h++) {
- var b = e.scalefac_band.l[_ + h + 2];
- if (o <= b) break;
- var p = f;
- c = new v(p);
- var m = d(a, l, b, c);
- p = c.bits, n[_ + h] > p && (n[_ + h] = p, s[_ + h] = _, r[_ + h] = u, i[_ + h] = m);
+ for (var u = 0; u < 8; u++) {
+ var m = e.scalefac_band.l[_ + u + 2];
+ if (o <= m) break;
+ var p = f,
+ b = d(a, l, m, c = new v(p));
+ p = c.bits, s[_ + u] > p && (s[_ + u] = p, r[(n[_ + u] = _) + u] = h, i[_ + u] = b);
}
}
- }(e, t, n, s, r, i, o), h(e, a, t, n, s, r, i, o));
+ }(e, t, s, n, r, i, o), u(e, a, t, s, n, r, i, o));
var _ = a.big_values;
- if (!(0 == _ || 1 < (n[_ - 2] | n[_ - 1]) || 576 < (_ = t.count1 + 2))) {
+ if (!(0 == _ || 1 < (s[_ - 2] | s[_ - 1]) || 576 < (_ = t.count1 + 2))) {
a.assign(t), a.count1 = _;
for (var l = 0, f = 0; _ > a.big_values; _ -= 4) {
- var c = 2 * (2 * (2 * n[_ - 4] + n[_ - 3]) + n[_ - 2]) + n[_ - 1];
- l += k.t32l[c], f += k.t33l[c];
+ var c = 2 * (2 * (2 * s[_ - 4] + s[_ - 3]) + s[_ - 2]) + s[_ - 1];
+ l += F.t32l[c], f += F.t33l[c];
}
- if (a.big_values = _, a.count1table_select = 0, f < l && (l = f, a.count1table_select = 1), a.count1bits = l, a.block_type == Ae.NORM_TYPE) h(e, a, t, n, s, r, i, o);else {
- if (a.part2_3_length = l, l = e.scalefac_band.l[8], _ < l && (l = _), 0 < l) {
- var u = new v(a.part2_3_length);
- a.table_select[0] = d(n, 0, l, u), a.part2_3_length = u.bits;
+ if (a.big_values = _, a.count1table_select = 0, f < l && (l = f, a.count1table_select = 1), a.count1bits = l, a.block_type == Pe.NORM_TYPE) u(e, a, t, s, n, r, i, o);else {
+ if (a.part2_3_length = l, _ < (l = e.scalefac_band.l[8]) && (l = _), 0 < l) {
+ var h = new v(a.part2_3_length);
+ a.table_select[0] = d(s, 0, l, h), a.part2_3_length = h.bits;
}
if (l < _) {
- var u = new v(a.part2_3_length);
- a.table_select[1] = d(n, l, _, u), a.part2_3_length = u.bits;
+ h = new v(a.part2_3_length);
+ a.table_select[1] = d(s, l, _, h), a.part2_3_length = h.bits;
}
t.part2_3_length > a.part2_3_length && t.assign(a);
}
}
}
};
- var u = [1, 1, 1, 1, 8, 2, 2, 2, 4, 4, 4, 8, 8, 8, 16, 16],
- b = [1, 2, 4, 8, 1, 2, 4, 8, 2, 4, 8, 2, 4, 8, 4, 8],
+ var h = [1, 1, 1, 1, 8, 2, 2, 2, 4, 4, 4, 8, 8, 8, 16, 16],
+ m = [1, 2, 4, 8, 1, 2, 4, 8, 2, 4, 8, 2, 4, 8, 4, 8],
p = [0, 0, 0, 0, 3, 1, 1, 1, 2, 2, 2, 3, 3, 3, 4, 4],
- m = [0, 1, 2, 3, 0, 1, 2, 3, 1, 2, 3, 1, 2, 3, 2, 3];
- A.slen1_tab = p, A.slen2_tab = m, this.best_scalefac_store = function (e, t, a, n) {
- var s,
+ b = [0, 1, 2, 3, 0, 1, 2, 3, 1, 2, 3, 1, 2, 3, 2, 3];
+ k.slen1_tab = p, k.slen2_tab = b, this.best_scalefac_store = function (e, t, a, s) {
+ var n,
r,
i,
o,
- _ = n.tt[t][a],
+ _ = s.tt[t][a],
l = 0;
- for (s = i = 0; s < _.sfbmax; s++) {
- var f = _.width[s];
+ for (n = i = 0; n < _.sfbmax; n++) {
+ var f = _.width[n];
for (i += f, o = -f; o < 0 && 0 == _.l3_enc[o + i]; o++);
- 0 == o && (_.scalefac[s] = l = -2);
+ 0 == o && (_.scalefac[n] = l = -2);
}
if (0 == _.scalefac_scale && 0 == _.preflag) {
var c = 0;
- for (s = 0; s < _.sfbmax; s++) 0 < _.scalefac[s] && (c |= _.scalefac[s]);
+ for (n = 0; n < _.sfbmax; n++) 0 < _.scalefac[n] && (c |= _.scalefac[n]);
if (0 == (1 & c) && 0 != c) {
- for (s = 0; s < _.sfbmax; s++) 0 < _.scalefac[s] && (_.scalefac[s] >>= 1);
+ for (n = 0; n < _.sfbmax; n++) 0 < _.scalefac[n] && (_.scalefac[n] >>= 1);
_.scalefac_scale = l = 1;
}
}
- if (0 == _.preflag && _.block_type != Ae.SHORT_TYPE && 2 == e.mode_gr) {
- for (s = 11; s < Ae.SBPSY_l && !(_.scalefac[s] < S.pretab[s] && -2 != _.scalefac[s]); s++);
- if (s == Ae.SBPSY_l) {
- for (s = 11; s < Ae.SBPSY_l; s++) 0 < _.scalefac[s] && (_.scalefac[s] -= S.pretab[s]);
+ if (0 == _.preflag && _.block_type != Pe.SHORT_TYPE && 2 == e.mode_gr) {
+ for (n = 11; n < Pe.SBPSY_l && !(_.scalefac[n] < M.pretab[n] && -2 != _.scalefac[n]); n++);
+ if (n == Pe.SBPSY_l) {
+ for (n = 11; n < Pe.SBPSY_l; n++) 0 < _.scalefac[n] && (_.scalefac[n] -= M.pretab[n]);
_.preflag = l = 1;
}
}
- for (r = 0; r < 4; r++) n.scfsi[a][r] = 0;
- for (2 == e.mode_gr && 1 == t && n.tt[0][a].block_type != Ae.SHORT_TYPE && n.tt[1][a].block_type != Ae.SHORT_TYPE && (function (e, t) {
- for (var a, n = t.tt[1][e], s = t.tt[0][e], r = 0; r < k.scfsi_band.length - 1; r++) {
- for (a = k.scfsi_band[r]; a < k.scfsi_band[r + 1] && !(s.scalefac[a] != n.scalefac[a] && 0 <= n.scalefac[a]); a++);
- if (a == k.scfsi_band[r + 1]) {
- for (a = k.scfsi_band[r]; a < k.scfsi_band[r + 1]; a++) n.scalefac[a] = -1;
+ for (r = 0; r < 4; r++) s.scfsi[a][r] = 0;
+ for (2 == e.mode_gr && 1 == t && s.tt[0][a].block_type != Pe.SHORT_TYPE && s.tt[1][a].block_type != Pe.SHORT_TYPE && (!function (e, t) {
+ for (var a, s = t.tt[1][e], n = t.tt[0][e], r = 0; r < F.scfsi_band.length - 1; r++) {
+ for (a = F.scfsi_band[r]; a < F.scfsi_band[r + 1] && !(n.scalefac[a] != s.scalefac[a] && 0 <= s.scalefac[a]); a++);
+ if (a == F.scfsi_band[r + 1]) {
+ for (a = F.scfsi_band[r]; a < F.scfsi_band[r + 1]; a++) s.scalefac[a] = -1;
t.scfsi[e][r] = 1;
}
}
var i = 0,
o = 0;
- for (a = 0; a < 11; a++) -1 != n.scalefac[a] && (o++, i < n.scalefac[a] && (i = n.scalefac[a]));
- for (var _ = 0, l = 0; a < Ae.SBPSY_l; a++) -1 != n.scalefac[a] && (l++, _ < n.scalefac[a] && (_ = n.scalefac[a]));
- for (var r = 0; r < 16; r++) if (i < u[r] && _ < b[r]) {
- var f = p[r] * o + m[r] * l;
- n.part2_length > f && (n.part2_length = f, n.scalefac_compress = r);
+ for (a = 0; a < 11; a++) -1 != s.scalefac[a] && (o++, i < s.scalefac[a] && (i = s.scalefac[a]));
+ for (var _ = 0, l = 0; a < Pe.SBPSY_l; a++) -1 != s.scalefac[a] && (l++, _ < s.scalefac[a] && (_ = s.scalefac[a]));
+ for (r = 0; r < 16; r++) if (i < h[r] && _ < m[r]) {
+ var f = p[r] * o + b[r] * l;
+ s.part2_length > f && (s.part2_length = f, s.scalefac_compress = r);
}
- }(a, n), l = 0), s = 0; s < _.sfbmax; s++) -2 == _.scalefac[s] && (_.scalefac[s] = 0);
+ }(a, s), l = 0), n = 0; n < _.sfbmax; n++) -2 == _.scalefac[n] && (_.scalefac[n] = 0);
0 != l && (2 == e.mode_gr ? this.scale_bitcount(_) : this.scale_bitcount_lsf(e, _));
};
var _ = [0, 18, 36, 54, 54, 36, 54, 72, 54, 72, 90, 72, 90, 108, 108, 126],
@@ -35398,458 +35053,476 @@ src: recorder-core.js,engine/mp3.js,engine/mp3-engine.js
this.scale_bitcount = function (e) {
var t,
a,
- n,
- s = 0,
+ s,
+ n = 0,
r = 0,
i = e.scalefac;
- if (e.block_type == Ae.SHORT_TYPE) n = _, 0 != e.mixed_block_flag && (n = l);else if (n = f, 0 == e.preflag) {
- for (a = 11; a < Ae.SBPSY_l && !(i[a] < S.pretab[a]); a++);
- if (a == Ae.SBPSY_l) for (e.preflag = 1, a = 11; a < Ae.SBPSY_l; a++) i[a] -= S.pretab[a];
+ if (e.block_type == Pe.SHORT_TYPE) s = _, 0 != e.mixed_block_flag && (s = l);else if (s = f, 0 == e.preflag) {
+ for (a = 11; a < Pe.SBPSY_l && !(i[a] < M.pretab[a]); a++);
+ if (a == Pe.SBPSY_l) for (e.preflag = 1, a = 11; a < Pe.SBPSY_l; a++) i[a] -= M.pretab[a];
}
- for (a = 0; a < e.sfbdivide; a++) s < i[a] && (s = i[a]);
+ for (a = 0; a < e.sfbdivide; a++) n < i[a] && (n = i[a]);
for (; a < e.sfbmax; a++) r < i[a] && (r = i[a]);
- for (e.part2_length = T.LARGE_BITS, t = 0; t < 16; t++) s < u[t] && r < b[t] && e.part2_length > n[t] && (e.part2_length = n[t], e.scalefac_compress = t);
- return e.part2_length == T.LARGE_BITS;
+ for (e.part2_length = x.LARGE_BITS, t = 0; t < 16; t++) n < h[t] && r < m[t] && e.part2_length > s[t] && (e.part2_length = s[t], e.scalefac_compress = t);
+ return e.part2_length == x.LARGE_BITS;
};
var g = [[15, 15, 7, 7], [15, 15, 7, 0], [7, 3, 0, 0], [15, 31, 31, 0], [7, 7, 7, 0], [3, 3, 0, 0]];
this.scale_bitcount_lsf = function (e, t) {
var a,
- n,
s,
+ n,
r,
i,
o,
_,
l,
- f = ve(4),
+ f = Ae(4),
c = t.scalefac;
for (a = 0 != t.preflag ? 2 : 0, _ = 0; _ < 4; _++) f[_] = 0;
- if (t.block_type == Ae.SHORT_TYPE) {
- n = 1;
- var u = S.nr_of_sfb_block[a][n];
- for (s = l = 0; s < 4; s++) for (r = u[s] / 3, _ = 0; _ < r; _++, l++) for (i = 0; i < 3; i++) c[3 * l + i] > f[s] && (f[s] = c[3 * l + i]);
+ if (t.block_type == Pe.SHORT_TYPE) {
+ s = 1;
+ var h = M.nr_of_sfb_block[a][s];
+ for (n = l = 0; n < 4; n++) for (r = h[n] / 3, _ = 0; _ < r; _++, l++) for (i = 0; i < 3; i++) c[3 * l + i] > f[n] && (f[n] = c[3 * l + i]);
} else {
- n = 0;
- var u = S.nr_of_sfb_block[a][n];
- for (s = l = 0; s < 4; s++) for (r = u[s], _ = 0; _ < r; _++, l++) c[l] > f[s] && (f[s] = c[l]);
+ s = 0;
+ h = M.nr_of_sfb_block[a][s];
+ for (n = l = 0; n < 4; n++) for (r = h[n], _ = 0; _ < r; _++, l++) c[l] > f[n] && (f[n] = c[l]);
}
- for (o = !1, s = 0; s < 4; s++) f[s] > g[a][s] && (o = !0);
+ for (o = !1, n = 0; n < 4; n++) f[n] > g[a][n] && (o = !0);
if (!o) {
- var h, b, p, m;
- for (t.sfb_partition_table = S.nr_of_sfb_block[a][n], s = 0; s < 4; s++) t.slen[s] = w[f[s]];
- switch (h = t.slen[0], b = t.slen[1], p = t.slen[2], m = t.slen[3], a) {
+ var u, m, p, b;
+ for (t.sfb_partition_table = M.nr_of_sfb_block[a][s], n = 0; n < 4; n++) t.slen[n] = S[f[n]];
+ switch (u = t.slen[0], m = t.slen[1], p = t.slen[2], b = t.slen[3], a) {
case 0:
- t.scalefac_compress = (5 * h + b << 4) + (p << 2) + m;
+ t.scalefac_compress = (5 * u + m << 4) + (p << 2) + b;
break;
case 1:
- t.scalefac_compress = 400 + (5 * h + b << 2) + p;
+ t.scalefac_compress = 400 + (5 * u + m << 2) + p;
break;
case 2:
- t.scalefac_compress = 500 + 3 * h + b;
+ t.scalefac_compress = 500 + 3 * u + m;
+ break;
+ default:
+ $.err.printf("intensity stereo not implemented yet\n");
}
}
- if (!o) for (t.part2_length = 0, s = 0; s < 4; s++) t.part2_length += t.slen[s] * t.sfb_partition_table[s];
+ if (!o) for (n = t.part2_length = 0; n < 4; n++) t.part2_length += t.slen[n] * t.sfb_partition_table[n];
return o;
};
- var w = [0, 1, 2, 2, 3, 3, 3, 3, 4, 4, 4, 4, 4, 4, 4, 4];
+ var S = [0, 1, 2, 2, 3, 3, 3, 3, 4, 4, 4, 4, 4, 4, 4, 4];
this.huffman_init = function (e) {
for (var t = 2; t <= 576; t += 2) {
- for (var a, n = 0; e.scalefac_band.l[++n] < t;);
- for (a = s[n][0]; e.scalefac_band.l[a + 1] > t;) a--;
- for (a < 0 && (a = s[n][0]), e.bv_scf[t - 2] = a, a = s[n][1]; e.scalefac_band.l[a + e.bv_scf[t - 2] + 2] > t;) a--;
- a < 0 && (a = s[n][1]), e.bv_scf[t - 1] = a;
+ for (var a, s = 0; e.scalefac_band.l[++s] < t;);
+ for (a = n[s][0]; e.scalefac_band.l[a + 1] > t;) a--;
+ for (a < 0 && (a = n[s][0]), e.bv_scf[t - 2] = a, a = n[s][1]; e.scalefac_band.l[a + e.bv_scf[t - 2] + 2] > t;) a--;
+ a < 0 && (a = n[s][1]), e.bv_scf[t - 1] = a;
}
};
}
- function O() {}
- function y() {
- this.setModules = function (e, t, a) {};
+ function X() {}
+ function M() {
+ this.setModules = function (e, t, a) {
+ };
var o = [0, 49345, 49537, 320, 49921, 960, 640, 49729, 50689, 1728, 1920, 51009, 1280, 50625, 50305, 1088, 52225, 3264, 3456, 52545, 3840, 53185, 52865, 3648, 2560, 51905, 52097, 2880, 51457, 2496, 2176, 51265, 55297, 6336, 6528, 55617, 6912, 56257, 55937, 6720, 7680, 57025, 57217, 8e3, 56577, 7616, 7296, 56385, 5120, 54465, 54657, 5440, 55041, 6080, 5760, 54849, 53761, 4800, 4992, 54081, 4352, 53697, 53377, 4160, 61441, 12480, 12672, 61761, 13056, 62401, 62081, 12864, 13824, 63169, 63361, 14144, 62721, 13760, 13440, 62529, 15360, 64705, 64897, 15680, 65281, 16320, 16e3, 65089, 64001, 15040, 15232, 64321, 14592, 63937, 63617, 14400, 10240, 59585, 59777, 10560, 60161, 11200, 10880, 59969, 60929, 11968, 12160, 61249, 11520, 60865, 60545, 11328, 58369, 9408, 9600, 58689, 9984, 59329, 59009, 9792, 8704, 58049, 58241, 9024, 57601, 8640, 8320, 57409, 40961, 24768, 24960, 41281, 25344, 41921, 41601, 25152, 26112, 42689, 42881, 26432, 42241, 26048, 25728, 42049, 27648, 44225, 44417, 27968, 44801, 28608, 28288, 44609, 43521, 27328, 27520, 43841, 26880, 43457, 43137, 26688, 30720, 47297, 47489, 31040, 47873, 31680, 31360, 47681, 48641, 32448, 32640, 48961, 32e3, 48577, 48257, 31808, 46081, 29888, 30080, 46401, 30464, 47041, 46721, 30272, 29184, 45761, 45953, 29504, 45313, 29120, 28800, 45121, 20480, 37057, 37249, 20800, 37633, 21440, 21120, 37441, 38401, 22208, 22400, 38721, 21760, 38337, 38017, 21568, 39937, 23744, 23936, 40257, 24320, 40897, 40577, 24128, 23040, 39617, 39809, 23360, 39169, 22976, 22656, 38977, 34817, 18624, 18816, 35137, 19200, 35777, 35457, 19008, 19968, 36545, 36737, 20288, 36097, 19904, 19584, 35905, 17408, 33985, 34177, 17728, 34561, 18368, 18048, 34369, 33281, 17088, 17280, 33601, 16640, 33217, 32897, 16448];
- this.updateMusicCRC = function (e, t, a, n) {
- for (var s = 0; s < n; ++s) e[0] = (r = t[a + s], i = (i = e[0]) >> 8 ^ o[255 & (i ^ r)]);
+ this.updateMusicCRC = function (e, t, a, s) {
+ for (var n = 0; n < s; ++n) e[0] = (r = t[a + n], i = (i = e[0]) >> 8 ^ o[255 & (i ^ r)]);
var r, i;
};
}
- function N() {
- var i = this,
+ function q() {
+ var _ = this,
+ s = 32773,
+ c = null,
+ h = null,
r = null,
- o = null;
- this.setModules = function (e, t, a, n) {
- r = a, o = n;
+ u = null;
+ this.setModules = function (e, t, a, s) {
+ c = e, h = t, r = a, u = s;
};
- var _ = null,
+ var m = null,
l = 0,
- f = 0,
- c = 0;
+ p = 0,
+ b = 0;
function v(e, t, a) {
for (; 0 < a;) {
- var n;
- 0 == c && (c = 8, f++, e.header[e.w_ptr].write_timing == l && (s = e, I.arraycopy(s.header[s.w_ptr].buf, 0, _, f, s.sideinfo_len), f += s.sideinfo_len, l += 8 * s.sideinfo_len, s.w_ptr = s.w_ptr + 1 & j.MAX_HEADER_BUF - 1), _[f] = 0), n = Math.min(a, c), a -= n, c -= n, _[f] |= t >> a << c, l += n;
+ var s;
+ 0 == b && (b = 8, p++, e.header[e.w_ptr].write_timing == l && (n = e, $.arraycopy(n.header[n.w_ptr].buf, 0, m, p, n.sideinfo_len), p += n.sideinfo_len, l += 8 * n.sideinfo_len, n.w_ptr = n.w_ptr + 1 & Z.MAX_HEADER_BUF - 1), m[p] = 0), a -= s = Math.min(a, b), b -= s, m[p] |= t >> a << b, l += s;
}
- var s;
+ var n;
}
- function u(e, t) {
+ function i(e, t, a) {
+ for (; 0 < a;) {
+ var s;
+ 0 == b && (b = 8, m[++p] = 0), a -= s = Math.min(a, b), b -= s, m[p] |= t >> a << b, l += s;
+ }
+ }
+ function o(e, t) {
var a,
- n = e.internal_flags;
- if (8 <= t && (v(n, 76, 8), t -= 8), 8 <= t && (v(n, 65, 8), t -= 8), 8 <= t && (v(n, 77, 8), t -= 8), 8 <= t && (v(n, 69, 8), t -= 8), 32 <= t) {
- var s = r.getLameShortVersion();
- if (32 <= t) for (a = 0; a < s.length && 8 <= t; ++a) t -= 8, v(n, s.charCodeAt(a), 8);
+ s = e.internal_flags;
+ if (8 <= t && (v(s, 76, 8), t -= 8), 8 <= t && (v(s, 65, 8), t -= 8), 8 <= t && (v(s, 77, 8), t -= 8), 8 <= t && (v(s, 69, 8), t -= 8), 32 <= t) {
+ var n = r.getLameShortVersion();
+ if (32 <= t) for (a = 0; a < n.length && 8 <= t; ++a) t -= 8, v(s, n.charCodeAt(a), 8);
}
- for (; 1 <= t; t -= 1) v(n, n.ancillary_flag, 1), n.ancillary_flag ^= e.disable_reservoir ? 0 : 1;
+ for (; 1 <= t; t -= 1) v(s, s.ancillary_flag, 1), s.ancillary_flag ^= e.disable_reservoir ? 0 : 1;
}
- function h(e, t, a) {
- for (var n = e.header[e.h_ptr].ptr; 0 < a;) {
- var s = Math.min(a, 8 - (7 & n));
- a -= s, e.header[e.h_ptr].buf[n >> 3] |= t >> a << 8 - (7 & n) - s, n += s;
+ function f(e, t, a) {
+ for (var s = e.header[e.h_ptr].ptr; 0 < a;) {
+ var n = Math.min(a, 8 - (7 & s));
+ a -= n, e.header[e.h_ptr].buf[s >> 3] |= t >> a << 8 - (7 & s) - n, s += n;
}
- e.header[e.h_ptr].ptr = n;
+ e.header[e.h_ptr].ptr = s;
}
- function m(e, t) {
+ function n(e, t) {
+ e <<= 8;
+ for (var a = 0; a < 8; a++) 0 != (65536 & ((t <<= 1) ^ (e <<= 1))) && (t ^= s);
+ return t;
+ }
+ function d(e, t) {
var a,
- n = k.ht[t.count1table_select + 32],
- s = 0,
+ s = F.ht[t.count1table_select + 32],
+ n = 0,
r = t.big_values,
i = t.big_values;
for (a = (t.count1 - t.big_values) / 4; 0 < a; --a) {
var o = 0,
_ = 0;
- 0 != t.l3_enc[r + 0] && (_ += 8, t.xr[i + 0] < 0 && o++), 0 != t.l3_enc[r + 1] && (_ += 4, o *= 2, t.xr[i + 1] < 0 && o++), 0 != t.l3_enc[r + 2] && (_ += 2, o *= 2, t.xr[i + 2] < 0 && o++), 0 != t.l3_enc[r + 3] && (_++, o *= 2, t.xr[i + 3] < 0 && o++), r += 4, i += 4, v(e, o + n.table[_], n.hlen[_]), s += n.hlen[_];
+ 0 != t.l3_enc[r + 0] && (_ += 8, t.xr[i + 0] < 0 && o++), 0 != t.l3_enc[r + 1] && (_ += 4, o *= 2, t.xr[i + 1] < 0 && o++), 0 != t.l3_enc[r + 2] && (_ += 2, o *= 2, t.xr[i + 2] < 0 && o++), 0 != t.l3_enc[r + 3] && (_++, o *= 2, t.xr[i + 3] < 0 && o++), r += 4, i += 4, v(e, o + s.table[_], s.hlen[_]), n += s.hlen[_];
}
- return s;
+ return n;
}
- function b(e, t, a, n, s) {
- var r = k.ht[t],
+ function g(e, t, a, s, n) {
+ var r = F.ht[t],
i = 0;
if (0 == t) return i;
- for (var o = a; o < n; o += 2) {
+ for (var o = a; o < s; o += 2) {
var _ = 0,
l = 0,
f = r.xlen,
c = r.xlen,
- u = 0,
- h = s.l3_enc[o],
- b = s.l3_enc[o + 1];
- if (0 != h && (s.xr[o] < 0 && u++, _--), 15 < t) {
- if (14 < h) {
- var p = h - 15;
- u |= p << 1, l = f, h = 15;
- }
- if (14 < b) {
- var m = b - 15;
- u <<= f, u |= m, l += f, b = 15;
- }
+ h = 0,
+ u = n.l3_enc[o],
+ m = n.l3_enc[o + 1];
+ if (0 != u && (n.xr[o] < 0 && h++, _--), 15 < t) {
+ if (14 < u) h |= u - 15 << 1, l = f, u = 15;
+ if (14 < m) h <<= f, h |= m - 15, l += f, m = 15;
c = 16;
}
- 0 != b && (u <<= 1, s.xr[o + 1] < 0 && u++, _--), h = h * c + b, l -= _, _ += r.hlen[h], v(e, r.table[h], _), v(e, u, l), i += _ + l;
+ 0 != m && (h <<= 1, n.xr[o + 1] < 0 && h++, _--), u = u * c + m, l -= _, _ += r.hlen[u], v(e, r.table[u], _), v(e, h, l), i += _ + l;
}
return i;
}
- function d(e, t) {
+ function S(e, t) {
var a = 3 * e.scalefac_band.s[3];
a > t.big_values && (a = t.big_values);
- var n = b(e, t.table_select[0], 0, a, t);
- return n += b(e, t.table_select[1], a, t.big_values, t);
+ var s = g(e, t.table_select[0], 0, a, t);
+ return s += g(e, t.table_select[1], a, t.big_values, t);
}
- function g(e, t) {
- var a, n, s, r;
+ function M(e, t) {
+ var a, s, n, r;
a = t.big_values;
var i = t.region0_count + 1;
- return s = e.scalefac_band.l[i], i += t.region1_count + 1, r = e.scalefac_band.l[i], a < s && (s = a), a < r && (r = a), n = b(e, t.table_select[0], 0, s, t), n += b(e, t.table_select[1], s, r, t), n += b(e, t.table_select[2], r, a, t);
+ return n = e.scalefac_band.l[i], i += t.region1_count + 1, a < n && (n = a), a < (r = e.scalefac_band.l[i]) && (r = a), s = g(e, t.table_select[0], 0, n, t), s += g(e, t.table_select[1], n, r, t), s += g(e, t.table_select[2], r, a, t);
}
- function p() {
+ function w() {
this.total = 0;
}
- function w(e, t) {
+ function R(e, t) {
var a,
- n,
s,
- r = e.internal_flags;
- return r.w_ptr, -1 == (s = r.h_ptr - 1) && (s = j.MAX_HEADER_BUF - 1), a = r.header[s].write_timing - l, 0 <= (t.total = a) && me(), n = i.getframebits(e), a += n, t.total += n, t.total % 8 != 0 ? t.total = 1 + t.total / 8 : t.total = t.total / 8, t.total += f + 1, a;
+ n,
+ r,
+ i,
+ o = e.internal_flags;
+ return i = o.w_ptr, -1 == (r = o.h_ptr - 1) && (r = Z.MAX_HEADER_BUF - 1), a = o.header[r].write_timing - l, 0 <= (t.total = a) && (s = 1 + r - i, r < i && (s = 1 + r - i + Z.MAX_HEADER_BUF), a -= 8 * s * o.sideinfo_len), a += n = _.getframebits(e), t.total += n, t.total % 8 != 0 ? t.total = 1 + t.total / 8 : t.total = t.total / 8, t.total += p + 1, a < 0 && $.err.println("strange error flushing buffer ... \n"), a;
}
this.getframebits = function (e) {
var t,
a = e.internal_flags;
- t = 0 != a.bitrate_index ? k.bitrate_table[e.version][a.bitrate_index] : e.brate;
- var n = 0 | 72e3 * (e.version + 1) * t / e.out_samplerate + a.padding;
- return 8 * n;
+ return t = 0 != a.bitrate_index ? F.bitrate_table[e.version][a.bitrate_index] : e.brate, 8 * (0 | 72e3 * (e.version + 1) * t / e.out_samplerate + a.padding);
+ }, this.CRC_writeheader = function (e, t) {
+ var a = 65535;
+ a = n(255 & t[2], a), a = n(255 & t[3], a);
+ for (var s = 6; s < e.sideinfo_len; s++) a = n(255 & t[s], a);
+ t[4] = byte(a >> 8), t[5] = byte(255 & a);
}, this.flush_bitstream = function (e) {
var t,
a,
- n = e.internal_flags;
- n.h_ptr - 1;
- t = n.l3_side, (a = w(e, new p())) < 0 || (u(e, a), n.ResvSize = 0, t.main_data_begin = 0, n.findReplayGain && me(), n.findPeakSample && me());
+ s = e.internal_flags;
+ s.h_ptr - 1;
+ if (t = s.l3_side, !((a = R(e, new w())) < 0)) {
+ if (o(e, a), s.ResvSize = 0, t.main_data_begin = 0, s.findReplayGain) {
+ var r = c.GetTitleGain(s.rgdata);
+ s.RadioGain = 0 | Math.floor(10 * r + .5);
+ }
+ s.findPeakSample && (s.noclipGainChange = 0 | Math.ceil(20 * B(s.PeakSample / 32767) * 10), 0 < s.noclipGainChange && (EQ(e.scale, 1) || EQ(e.scale, 0)) ? s.noclipScale = Math.floor(32767 / s.PeakSample * 100) / 100 : s.noclipScale = -1);
+ }
+ }, this.add_dummy_byte = function (e, t, a) {
+ for (var s, n = e.internal_flags; 0 < a--;) for (i(0, t, 8), s = 0; s < Z.MAX_HEADER_BUF; ++s) n.header[s].write_timing += 8;
}, this.format_bitstream = function (e) {
var t,
a = e.internal_flags;
t = a.l3_side;
- var n = this.getframebits(e);
- u(e, t.resvDrain_pre), function (e, t) {
+ var s = this.getframebits(e);
+ o(e, t.resvDrain_pre), function (e, t) {
var a,
- n,
s,
+ n,
r = e.internal_flags;
- if (a = r.l3_side, r.header[r.h_ptr].ptr = 0, we.fill(r.header[r.h_ptr].buf, 0, r.sideinfo_len, 0), e.out_samplerate < 16e3 ? h(r, 4094, 12) : h(r, 4095, 12), h(r, e.version, 1), h(r, 1, 2), h(r, e.error_protection ? 0 : 1, 1), h(r, r.bitrate_index, 4), h(r, r.samplerate_index, 2), h(r, r.padding, 1), h(r, e.extension, 1), h(r, e.mode.ordinal(), 2), h(r, r.mode_ext, 2), h(r, e.copyright, 1), h(r, e.original, 1), h(r, e.emphasis, 2), e.error_protection && h(r, 0, 16), 1 == e.version) {
- for (h(r, a.main_data_begin, 9), 2 == r.channels_out ? h(r, a.private_bits, 3) : h(r, a.private_bits, 5), s = 0; s < r.channels_out; s++) {
+ if (a = r.l3_side, r.header[r.h_ptr].ptr = 0, ye.fill(r.header[r.h_ptr].buf, 0, r.sideinfo_len, 0), e.out_samplerate < 16e3 ? f(r, 4094, 12) : f(r, 4095, 12), f(r, e.version, 1), f(r, 1, 2), f(r, e.error_protection ? 0 : 1, 1), f(r, r.bitrate_index, 4), f(r, r.samplerate_index, 2), f(r, r.padding, 1), f(r, e.extension, 1), f(r, e.mode.ordinal(), 2), f(r, r.mode_ext, 2), f(r, e.copyright, 1), f(r, e.original, 1), f(r, e.emphasis, 2), e.error_protection && f(r, 0, 16), 1 == e.version) {
+ for (f(r, a.main_data_begin, 9), 2 == r.channels_out ? f(r, a.private_bits, 3) : f(r, a.private_bits, 5), n = 0; n < r.channels_out; n++) {
var i;
- for (i = 0; i < 4; i++) h(r, a.scfsi[s][i], 1);
+ for (i = 0; i < 4; i++) f(r, a.scfsi[n][i], 1);
}
- for (n = 0; n < 2; n++) for (s = 0; s < r.channels_out; s++) {
- var o = a.tt[n][s];
- h(r, o.part2_3_length + o.part2_length, 12), h(r, o.big_values / 2, 9), h(r, o.global_gain, 8), h(r, o.scalefac_compress, 4), o.block_type != Ae.NORM_TYPE ? (h(r, 1, 1), h(r, o.block_type, 2), h(r, o.mixed_block_flag, 1), 14 == o.table_select[0] && (o.table_select[0] = 16), h(r, o.table_select[0], 5), 14 == o.table_select[1] && (o.table_select[1] = 16), h(r, o.table_select[1], 5), h(r, o.subblock_gain[0], 3), h(r, o.subblock_gain[1], 3), h(r, o.subblock_gain[2], 3)) : (h(r, 0, 1), 14 == o.table_select[0] && (o.table_select[0] = 16), h(r, o.table_select[0], 5), 14 == o.table_select[1] && (o.table_select[1] = 16), h(r, o.table_select[1], 5), 14 == o.table_select[2] && (o.table_select[2] = 16), h(r, o.table_select[2], 5), h(r, o.region0_count, 4), h(r, o.region1_count, 3)), h(r, o.preflag, 1), h(r, o.scalefac_scale, 1), h(r, o.count1table_select, 1);
- }
- } else for (h(r, a.main_data_begin, 8), h(r, a.private_bits, r.channels_out), s = n = 0; s < r.channels_out; s++) {
- var o = a.tt[n][s];
- h(r, o.part2_3_length + o.part2_length, 12), h(r, o.big_values / 2, 9), h(r, o.global_gain, 8), h(r, o.scalefac_compress, 9), o.block_type != Ae.NORM_TYPE ? (h(r, 1, 1), h(r, o.block_type, 2), h(r, o.mixed_block_flag, 1), 14 == o.table_select[0] && (o.table_select[0] = 16), h(r, o.table_select[0], 5), 14 == o.table_select[1] && (o.table_select[1] = 16), h(r, o.table_select[1], 5), h(r, o.subblock_gain[0], 3), h(r, o.subblock_gain[1], 3), h(r, o.subblock_gain[2], 3)) : (h(r, 0, 1), 14 == o.table_select[0] && (o.table_select[0] = 16), h(r, o.table_select[0], 5), 14 == o.table_select[1] && (o.table_select[1] = 16), h(r, o.table_select[1], 5), 14 == o.table_select[2] && (o.table_select[2] = 16), h(r, o.table_select[2], 5), h(r, o.region0_count, 4), h(r, o.region1_count, 3)), h(r, o.scalefac_scale, 1), h(r, o.count1table_select, 1);
+ for (s = 0; s < 2; s++) for (n = 0; n < r.channels_out; n++) f(r, (o = a.tt[s][n]).part2_3_length + o.part2_length, 12), f(r, o.big_values / 2, 9), f(r, o.global_gain, 8), f(r, o.scalefac_compress, 4), o.block_type != Pe.NORM_TYPE ? (f(r, 1, 1), f(r, o.block_type, 2), f(r, o.mixed_block_flag, 1), 14 == o.table_select[0] && (o.table_select[0] = 16), f(r, o.table_select[0], 5), 14 == o.table_select[1] && (o.table_select[1] = 16), f(r, o.table_select[1], 5), f(r, o.subblock_gain[0], 3), f(r, o.subblock_gain[1], 3), f(r, o.subblock_gain[2], 3)) : (f(r, 0, 1), 14 == o.table_select[0] && (o.table_select[0] = 16), f(r, o.table_select[0], 5), 14 == o.table_select[1] && (o.table_select[1] = 16), f(r, o.table_select[1], 5), 14 == o.table_select[2] && (o.table_select[2] = 16), f(r, o.table_select[2], 5), f(r, o.region0_count, 4), f(r, o.region1_count, 3)), f(r, o.preflag, 1), f(r, o.scalefac_scale, 1), f(r, o.count1table_select, 1);
+ } else for (f(r, a.main_data_begin, 8), f(r, a.private_bits, r.channels_out), n = s = 0; n < r.channels_out; n++) {
+ var o;
+ f(r, (o = a.tt[s][n]).part2_3_length + o.part2_length, 12), f(r, o.big_values / 2, 9), f(r, o.global_gain, 8), f(r, o.scalefac_compress, 9), o.block_type != Pe.NORM_TYPE ? (f(r, 1, 1), f(r, o.block_type, 2), f(r, o.mixed_block_flag, 1), 14 == o.table_select[0] && (o.table_select[0] = 16), f(r, o.table_select[0], 5), 14 == o.table_select[1] && (o.table_select[1] = 16), f(r, o.table_select[1], 5), f(r, o.subblock_gain[0], 3), f(r, o.subblock_gain[1], 3), f(r, o.subblock_gain[2], 3)) : (f(r, 0, 1), 14 == o.table_select[0] && (o.table_select[0] = 16), f(r, o.table_select[0], 5), 14 == o.table_select[1] && (o.table_select[1] = 16), f(r, o.table_select[1], 5), 14 == o.table_select[2] && (o.table_select[2] = 16), f(r, o.table_select[2], 5), f(r, o.region0_count, 4), f(r, o.region1_count, 3)), f(r, o.scalefac_scale, 1), f(r, o.count1table_select, 1);
}
- e.error_protection && me();
+ e.error_protection && CRC_writeheader(r, r.header[r.h_ptr].buf);
var _ = r.h_ptr;
- r.h_ptr = _ + 1 & j.MAX_HEADER_BUF - 1, r.header[r.h_ptr].write_timing = r.header[_].write_timing + t, r.h_ptr, r.w_ptr;
- }(e, n);
- var s = 8 * a.sideinfo_len;
- if (s += function (e) {
+ r.h_ptr = _ + 1 & Z.MAX_HEADER_BUF - 1, r.header[r.h_ptr].write_timing = r.header[_].write_timing + t, r.h_ptr == r.w_ptr && $.err.println("Error: MAX_HEADER_BUF too small in bitstream.c \n");
+ }(e, s);
+ var n = 8 * a.sideinfo_len;
+ if (n += function (e) {
var t,
a,
- n,
s,
+ n,
r = 0,
i = e.internal_flags,
o = i.l3_side;
if (1 == e.version) for (t = 0; t < 2; t++) for (a = 0; a < i.channels_out; a++) {
var _ = o.tt[t][a],
- l = A.slen1_tab[_.scalefac_compress],
- f = A.slen2_tab[_.scalefac_compress];
- for (n = s = 0; n < _.sfbdivide; n++) -1 != _.scalefac[n] && (v(i, _.scalefac[n], l), s += l);
- for (; n < _.sfbmax; n++) -1 != _.scalefac[n] && (v(i, _.scalefac[n], f), s += f);
- _.block_type == Ae.SHORT_TYPE ? s += d(i, _) : s += g(i, _), s += m(i, _), r += s;
+ l = k.slen1_tab[_.scalefac_compress],
+ f = k.slen2_tab[_.scalefac_compress];
+ for (s = n = 0; s < _.sfbdivide; s++) -1 != _.scalefac[s] && (v(i, _.scalefac[s], l), n += l);
+ for (; s < _.sfbmax; s++) -1 != _.scalefac[s] && (v(i, _.scalefac[s], f), n += f);
+ _.block_type == Pe.SHORT_TYPE ? n += S(i, _) : n += M(i, _), r += n += d(i, _);
} else for (a = t = 0; a < i.channels_out; a++) {
var c,
- u,
- _ = o.tt[t][a],
- h = 0;
- if (u = n = s = 0, _.block_type == Ae.SHORT_TYPE) {
- for (; u < 4; u++) {
- var b = _.sfb_partition_table[u] / 3,
- p = _.slen[u];
- for (c = 0; c < b; c++, n++) v(i, Math.max(_.scalefac[3 * n + 0], 0), p), v(i, Math.max(_.scalefac[3 * n + 1], 0), p), v(i, Math.max(_.scalefac[3 * n + 2], 0), p), h += 3 * p;
+ h,
+ u = 0;
+ if (h = s = n = 0, (_ = o.tt[t][a]).block_type == Pe.SHORT_TYPE) {
+ for (; h < 4; h++) {
+ var m = _.sfb_partition_table[h] / 3,
+ p = _.slen[h];
+ for (c = 0; c < m; c++, s++) v(i, Math.max(_.scalefac[3 * s + 0], 0), p), v(i, Math.max(_.scalefac[3 * s + 1], 0), p), v(i, Math.max(_.scalefac[3 * s + 2], 0), p), u += 3 * p;
}
- s += d(i, _);
+ n += S(i, _);
} else {
- for (; u < 4; u++) {
- var b = _.sfb_partition_table[u],
- p = _.slen[u];
- for (c = 0; c < b; c++, n++) v(i, Math.max(_.scalefac[n], 0), p), h += p;
- }
- s += g(i, _);
+ for (; h < 4; h++) for (m = _.sfb_partition_table[h], p = _.slen[h], c = 0; c < m; c++, s++) v(i, Math.max(_.scalefac[s], 0), p), u += p;
+ n += M(i, _);
}
- s += m(i, _), r += h + s;
+ r += u + (n += d(i, _));
}
return r;
- }(e), u(e, t.resvDrain_post), s += t.resvDrain_post, t.main_data_begin += (n - s) / 8, w(e, new p()), a.ResvSize, 8 * t.main_data_begin != a.ResvSize && (a.ResvSize = 8 * t.main_data_begin), 1e9 < l) {
+ }(e), o(e, t.resvDrain_post), n += t.resvDrain_post, t.main_data_begin += (s - n) / 8, R(e, new w()) != a.ResvSize && $.err.println("Internal buffer inconsistency. flushbits <> ResvSize"), 8 * t.main_data_begin != a.ResvSize && ($.err.printf("bit reservoir error: \nl3_side.main_data_begin: %d \nResvoir size: %d \nresv drain (post) %d \nresv drain (pre) %d \nheader and sideinfo: %d \ndata bits: %d \ntotal bits: %d (remainder: %d) \nbitsperframe: %d \n", 8 * t.main_data_begin, a.ResvSize, t.resvDrain_post, t.resvDrain_pre, 8 * a.sideinfo_len, n - t.resvDrain_post - 8 * a.sideinfo_len, n, n % 8, s), $.err.println("This is a fatal error. It has several possible causes:"), $.err.println("90%% LAME compiled with buggy version of gcc using advanced optimizations"), $.err.println(" 9%% Your system is overclocked"), $.err.println(" 1%% bug in LAME encoding library"), a.ResvSize = 8 * t.main_data_begin), 1e9 < l) {
var r;
- for (r = 0; r < j.MAX_HEADER_BUF; ++r) a.header[r].write_timing -= l;
+ for (r = 0; r < Z.MAX_HEADER_BUF; ++r) a.header[r].write_timing -= l;
l = 0;
}
return 0;
- }, this.copy_buffer = function (e, t, a, n, s) {
- var r = f + 1;
+ }, this.copy_buffer = function (e, t, a, s, n) {
+ var r = p + 1;
if (r <= 0) return 0;
- if (0 != n && n < r) return -1;
- if (I.arraycopy(_, 0, t, a, r), f = -1, (c = 0) != s) {
- var i = ve(1);
- i[0] = e.nMusicCRC, o.updateMusicCRC(i, t, a, r), e.nMusicCRC = i[0], 0 < r && (e.VBR_seek_table.nBytesWritten += r), e.decode_on_the_fly && me();
+ if (0 != s && s < r) return -1;
+ if ($.arraycopy(m, 0, t, a, r), p = -1, (b = 0) != n) {
+ var i = Ae(1);
+ if (i[0] = e.nMusicCRC, u.updateMusicCRC(i, t, a, r), e.nMusicCRC = i[0], 0 < r && (e.VBR_seek_table.nBytesWritten += r), e.decode_on_the_fly) for (var o, _ = ke([2, 1152]), l = r, f = -1; 0 != f;) if (f = h.hip_decode1_unclipped(e.hip, t, a, l, _[0], _[1]), l = 0, -1 == f && (f = 0), 0 < f) {
+ if (e.findPeakSample) {
+ for (o = 0; o < f; o++) _[0][o] > e.PeakSample ? e.PeakSample = _[0][o] : -_[0][o] > e.PeakSample && (e.PeakSample = -_[0][o]);
+ if (1 < e.channels_out) for (o = 0; o < f; o++) _[1][o] > e.PeakSample ? e.PeakSample = _[1][o] : -_[1][o] > e.PeakSample && (e.PeakSample = -_[1][o]);
+ }
+ if (e.findReplayGain && c.AnalyzeSamples(e.rgdata, _[0], 0, _[1], 0, f, e.channels_out) == X.GAIN_ANALYSIS_ERROR) return -6;
+ }
}
return r;
}, this.init_bit_stream_w = function (e) {
- _ = S(Y.LAME_MAXMP3BUFFER), e.h_ptr = e.w_ptr = 0, e.header[e.h_ptr].write_timing = 0, f = -1, l = c = 0;
+ m = A(U.LAME_MAXMP3BUFFER), e.h_ptr = e.w_ptr = 0, e.header[e.h_ptr].write_timing = 0, p = -1, l = b = 0;
};
}
- function e(e, t, a, n) {
- this.xlen = e, this.linmax = t, this.table = a, this.hlen = n;
+ function e(e, t, a, s) {
+ this.xlen = e, this.linmax = t, this.table = a, this.hlen = s;
}
- D.MAX_VALUE = 3.4028235e38, Me.vbr_off = new Me(0), Me.vbr_mt = new Me(1), Me.vbr_rh = new Me(2), Me.vbr_abr = new Me(3), Me.vbr_mtrh = new Me(4), Me.vbr_default = Me.vbr_mtrh, ye.STEREO = new ye(0), ye.JOINT_STEREO = new ye(1), ye.DUAL_CHANNEL = new ye(2), ye.MONO = new ye(3), ye.NOT_SET = new ye(4), O.STEPS_per_dB = 100, O.MAX_dB = 120, O.GAIN_NOT_ENOUGH_SAMPLES = -24601, O.GAIN_ANALYSIS_ERROR = 0, O.GAIN_ANALYSIS_OK = 1, O.INIT_GAIN_ANALYSIS_ERROR = 0, O.INIT_GAIN_ANALYSIS_OK = 1, O.MAX_ORDER = O.YULE_ORDER = 10, O.MAX_SAMPLES_PER_WINDOW = (O.MAX_SAMP_FREQ = 48e3) * (O.RMS_WINDOW_TIME_NUMERATOR = 1) / (O.RMS_WINDOW_TIME_DENOMINATOR = 20) + 1, y.NUMTOCENTRIES = 100, y.MAXFRAMESIZE = 2880, N.EQ = function (e, t) {
+ Ee.STEREO = new Ee(0), Ee.JOINT_STEREO = new Ee(1), Ee.DUAL_CHANNEL = new Ee(2), Ee.MONO = new Ee(3), Ee.NOT_SET = new Ee(4), X.STEPS_per_dB = 100, X.MAX_dB = 120, X.GAIN_NOT_ENOUGH_SAMPLES = -24601, X.GAIN_ANALYSIS_ERROR = 0, X.GAIN_ANALYSIS_OK = 1, X.INIT_GAIN_ANALYSIS_ERROR = 0, X.INIT_GAIN_ANALYSIS_OK = 1, X.MAX_ORDER = X.YULE_ORDER = 10, X.MAX_SAMPLES_PER_WINDOW = (X.MAX_SAMP_FREQ = 48e3) * (X.RMS_WINDOW_TIME_NUMERATOR = 1) / (X.RMS_WINDOW_TIME_DENOMINATOR = 20) + 1, M.NUMTOCENTRIES = 100, M.MAXFRAMESIZE = 2880, q.EQ = function (e, t) {
return Math.abs(e) > Math.abs(t) ? Math.abs(e - t) <= 1e-6 * Math.abs(e) : Math.abs(e - t) <= 1e-6 * Math.abs(t);
- }, N.NEQ = function (e, t) {
- return !N.EQ(e, t);
+ }, q.NEQ = function (e, t) {
+ return !q.EQ(e, t);
};
- var k = {};
- function R(e) {
+ var F = {};
+ function j(e) {
this.bits = e;
}
- function x() {
+ function y() {
this.over_noise = 0, this.tot_noise = 0, this.max_noise = 0, this.over_count = 0, this.over_SSD = 0, this.bits = 0;
}
- function r(e, t, a, n) {
- this.l = ve(1 + Ae.SBMAX_l), this.s = ve(1 + Ae.SBMAX_s), this.psfb21 = ve(1 + Ae.PSFB21), this.psfb12 = ve(1 + Ae.PSFB12);
- var s = this.l,
+ function r(e, t, a, s) {
+ this.l = Ae(1 + Pe.SBMAX_l), this.s = Ae(1 + Pe.SBMAX_s), this.psfb21 = Ae(1 + Pe.PSFB21), this.psfb12 = Ae(1 + Pe.PSFB12);
+ var n = this.l,
r = this.s;
- 4 == arguments.length && (this.arrL = e, this.arrS = t, this.arr21 = a, this.arr12 = n, I.arraycopy(this.arrL, 0, s, 0, Math.min(this.arrL.length, this.l.length)), I.arraycopy(this.arrS, 0, r, 0, Math.min(this.arrS.length, this.s.length)), I.arraycopy(this.arr21, 0, this.psfb21, 0, Math.min(this.arr21.length, this.psfb21.length)), I.arraycopy(this.arr12, 0, this.psfb12, 0, Math.min(this.arr12.length, this.psfb12.length)));
+ 4 == arguments.length && (this.arrL = e, this.arrS = t, this.arr21 = a, this.arr12 = s, $.arraycopy(this.arrL, 0, n, 0, Math.min(this.arrL.length, this.l.length)), $.arraycopy(this.arrS, 0, r, 0, Math.min(this.arrS.length, this.s.length)), $.arraycopy(this.arr21, 0, this.psfb21, 0, Math.min(this.arr21.length, this.psfb21.length)), $.arraycopy(this.arr12, 0, this.psfb12, 0, Math.min(this.arr12.length, this.psfb12.length)));
}
- function T() {
+ function x() {
var l = null,
- b = null,
- n = null;
+ m = null,
+ s = null;
this.setModules = function (e, t, a) {
- l = e, b = t, n = a;
+ l = e, m = t, s = a;
}, this.IPOW20 = function (e) {
- return h[e];
+ return u[e];
};
- var B = 2.220446049250313e-16,
- e = T.IXMAX_VAL,
- f = e + 2,
- c = T.Q_MAX,
- u = T.Q_MAX2,
- s = 100;
+ var T = 2.220446049250313e-16,
+ f = x.IXMAX_VAL + 2,
+ c = x.Q_MAX,
+ h = x.Q_MAX2,
+ n = 100;
this.nr_of_sfb_block = [[[6, 5, 5, 5], [9, 9, 9, 9], [6, 9, 9, 9]], [[6, 5, 7, 3], [9, 9, 12, 6], [6, 9, 12, 6]], [[11, 10, 0, 0], [18, 18, 0, 0], [15, 18, 0, 0]], [[7, 7, 7, 0], [12, 12, 12, 0], [6, 15, 12, 0]], [[6, 6, 6, 3], [12, 9, 9, 6], [6, 12, 9, 6]], [[8, 8, 5, 0], [15, 12, 9, 0], [6, 18, 9, 0]]];
- var M = [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 2, 2, 3, 3, 3, 2, 0];
- this.pretab = M, this.sfBandIndex = [new r([0, 6, 12, 18, 24, 30, 36, 44, 54, 66, 80, 96, 116, 140, 168, 200, 238, 284, 336, 396, 464, 522, 576], [0, 4, 8, 12, 18, 24, 32, 42, 56, 74, 100, 132, 174, 192], [0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0]), new r([0, 6, 12, 18, 24, 30, 36, 44, 54, 66, 80, 96, 114, 136, 162, 194, 232, 278, 332, 394, 464, 540, 576], [0, 4, 8, 12, 18, 26, 36, 48, 62, 80, 104, 136, 180, 192], [0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0]), new r([0, 6, 12, 18, 24, 30, 36, 44, 54, 66, 80, 96, 116, 140, 168, 200, 238, 284, 336, 396, 464, 522, 576], [0, 4, 8, 12, 18, 26, 36, 48, 62, 80, 104, 134, 174, 192], [0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0]), new r([0, 4, 8, 12, 16, 20, 24, 30, 36, 44, 52, 62, 74, 90, 110, 134, 162, 196, 238, 288, 342, 418, 576], [0, 4, 8, 12, 16, 22, 30, 40, 52, 66, 84, 106, 136, 192], [0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0]), new r([0, 4, 8, 12, 16, 20, 24, 30, 36, 42, 50, 60, 72, 88, 106, 128, 156, 190, 230, 276, 330, 384, 576], [0, 4, 8, 12, 16, 22, 28, 38, 50, 64, 80, 100, 126, 192], [0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0]), new r([0, 4, 8, 12, 16, 20, 24, 30, 36, 44, 54, 66, 82, 102, 126, 156, 194, 240, 296, 364, 448, 550, 576], [0, 4, 8, 12, 16, 22, 30, 42, 58, 78, 104, 138, 180, 192], [0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0]), new r([0, 6, 12, 18, 24, 30, 36, 44, 54, 66, 80, 96, 116, 140, 168, 200, 238, 284, 336, 396, 464, 522, 576], [0, 4, 8, 12, 18, 26, 36, 48, 62, 80, 104, 134, 174, 192], [0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0]), new r([0, 6, 12, 18, 24, 30, 36, 44, 54, 66, 80, 96, 116, 140, 168, 200, 238, 284, 336, 396, 464, 522, 576], [0, 4, 8, 12, 18, 26, 36, 48, 62, 80, 104, 134, 174, 192], [0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0]), new r([0, 12, 24, 36, 48, 60, 72, 88, 108, 132, 160, 192, 232, 280, 336, 400, 476, 566, 568, 570, 572, 574, 576], [0, 8, 16, 24, 36, 52, 72, 96, 124, 160, 162, 164, 166, 192], [0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0])];
- var y = de(c + u + 1),
- h = de(c),
- p = de(f),
- m = de(f);
+ var w = [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 2, 2, 3, 3, 3, 2, 0];
+ this.pretab = w, this.sfBandIndex = [new r([0, 6, 12, 18, 24, 30, 36, 44, 54, 66, 80, 96, 116, 140, 168, 200, 238, 284, 336, 396, 464, 522, 576], [0, 4, 8, 12, 18, 24, 32, 42, 56, 74, 100, 132, 174, 192], [0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0]), new r([0, 6, 12, 18, 24, 30, 36, 44, 54, 66, 80, 96, 114, 136, 162, 194, 232, 278, 332, 394, 464, 540, 576], [0, 4, 8, 12, 18, 26, 36, 48, 62, 80, 104, 136, 180, 192], [0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0]), new r([0, 6, 12, 18, 24, 30, 36, 44, 54, 66, 80, 96, 116, 140, 168, 200, 238, 284, 336, 396, 464, 522, 576], [0, 4, 8, 12, 18, 26, 36, 48, 62, 80, 104, 134, 174, 192], [0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0]), new r([0, 4, 8, 12, 16, 20, 24, 30, 36, 44, 52, 62, 74, 90, 110, 134, 162, 196, 238, 288, 342, 418, 576], [0, 4, 8, 12, 16, 22, 30, 40, 52, 66, 84, 106, 136, 192], [0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0]), new r([0, 4, 8, 12, 16, 20, 24, 30, 36, 42, 50, 60, 72, 88, 106, 128, 156, 190, 230, 276, 330, 384, 576], [0, 4, 8, 12, 16, 22, 28, 38, 50, 64, 80, 100, 126, 192], [0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0]), new r([0, 4, 8, 12, 16, 20, 24, 30, 36, 44, 54, 66, 82, 102, 126, 156, 194, 240, 296, 364, 448, 550, 576], [0, 4, 8, 12, 16, 22, 30, 42, 58, 78, 104, 138, 180, 192], [0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0]), new r([0, 6, 12, 18, 24, 30, 36, 44, 54, 66, 80, 96, 116, 140, 168, 200, 238, 284, 336, 396, 464, 522, 576], [0, 4, 8, 12, 18, 26, 36, 48, 62, 80, 104, 134, 174, 192], [0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0]), new r([0, 6, 12, 18, 24, 30, 36, 44, 54, 66, 80, 96, 116, 140, 168, 200, 238, 284, 336, 396, 464, 522, 576], [0, 4, 8, 12, 18, 26, 36, 48, 62, 80, 104, 134, 174, 192], [0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0]), new r([0, 12, 24, 36, 48, 60, 72, 88, 108, 132, 160, 192, 232, 280, 336, 400, 476, 566, 568, 570, 572, 574, 576], [0, 8, 16, 24, 36, 52, 72, 96, 124, 160, 162, 164, 166, 192], [0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0])];
+ var R = Be(c + h + 1),
+ u = Be(c),
+ p = Be(f),
+ b = Be(f);
function v(e, t) {
- var a = n.ATHformula(t, e);
- return a -= s, a = Math.pow(10, a / 10 + e.ATHlower);
+ var a = s.ATHformula(t, e);
+ return a -= n, a = Math.pow(10, a / 10 + e.ATHlower);
}
function A(e) {
this.s = e;
}
- this.adj43 = m, this.iteration_init = function (e) {
+ this.adj43 = b, this.iteration_init = function (e) {
var t,
a = e.internal_flags,
- n = a.l3_side;
+ s = a.l3_side;
if (0 == a.iteration_init_init) {
- for (a.iteration_init_init = 1, n.main_data_begin = 0, function (e) {
- for (var t = e.internal_flags.ATH.l, a = e.internal_flags.ATH.psfb21, n = e.internal_flags.ATH.s, s = e.internal_flags.ATH.psfb12, r = e.internal_flags, i = e.out_samplerate, o = 0; o < Ae.SBMAX_l; o++) {
+ for (a.iteration_init_init = 1, s.main_data_begin = 0, function (e) {
+ for (var t = e.internal_flags.ATH.l, a = e.internal_flags.ATH.psfb21, s = e.internal_flags.ATH.s, n = e.internal_flags.ATH.psfb12, r = e.internal_flags, i = e.out_samplerate, o = 0; o < Pe.SBMAX_l; o++) {
var _ = r.scalefac_band.l[o],
l = r.scalefac_band.l[o + 1];
- t[o] = D.MAX_VALUE;
+ t[o] = K.MAX_VALUE;
for (var f = _; f < l; f++) {
- var c = f * i / 1152,
- u = v(e, c);
- t[o] = Math.min(t[o], u);
+ var c = v(e, f * i / 1152);
+ t[o] = Math.min(t[o], c);
}
}
- for (var o = 0; o < Ae.PSFB21; o++) {
- var _ = r.scalefac_band.psfb21[o],
- l = r.scalefac_band.psfb21[o + 1];
- a[o] = D.MAX_VALUE;
- for (var f = _; f < l; f++) {
- var c = f * i / 1152,
- u = v(e, c);
- a[o] = Math.min(a[o], u);
- }
+ for (o = 0; o < Pe.PSFB21; o++) for (_ = r.scalefac_band.psfb21[o], l = r.scalefac_band.psfb21[o + 1], a[o] = K.MAX_VALUE, f = _; f < l; f++) c = v(e, f * i / 1152), a[o] = Math.min(a[o], c);
+ for (o = 0; o < Pe.SBMAX_s; o++) {
+ for (_ = r.scalefac_band.s[o], l = r.scalefac_band.s[o + 1], s[o] = K.MAX_VALUE, f = _; f < l; f++) c = v(e, f * i / 384), s[o] = Math.min(s[o], c);
+ s[o] *= r.scalefac_band.s[o + 1] - r.scalefac_band.s[o];
}
- for (var o = 0; o < Ae.SBMAX_s; o++) {
- var _ = r.scalefac_band.s[o],
- l = r.scalefac_band.s[o + 1];
- n[o] = D.MAX_VALUE;
- for (var f = _; f < l; f++) {
- var c = f * i / 384,
- u = v(e, c);
- n[o] = Math.min(n[o], u);
- }
- n[o] *= r.scalefac_band.s[o + 1] - r.scalefac_band.s[o];
+ for (o = 0; o < Pe.PSFB12; o++) {
+ for (_ = r.scalefac_band.psfb12[o], l = r.scalefac_band.psfb12[o + 1], n[o] = K.MAX_VALUE, f = _; f < l; f++) c = v(e, f * i / 384), n[o] = Math.min(n[o], c);
+ n[o] *= r.scalefac_band.s[13] - r.scalefac_band.s[12];
}
- for (var o = 0; o < Ae.PSFB12; o++) {
- var _ = r.scalefac_band.psfb12[o],
- l = r.scalefac_band.psfb12[o + 1];
- s[o] = D.MAX_VALUE;
- for (var f = _; f < l; f++) {
- var c = f * i / 384,
- u = v(e, c);
- s[o] = Math.min(s[o], u);
- }
- s[o] *= r.scalefac_band.s[13] - r.scalefac_band.s[12];
+ if (e.noATH) {
+ for (o = 0; o < Pe.SBMAX_l; o++) t[o] = 1e-20;
+ for (o = 0; o < Pe.PSFB21; o++) a[o] = 1e-20;
+ for (o = 0; o < Pe.SBMAX_s; o++) s[o] = 1e-20;
+ for (o = 0; o < Pe.PSFB12; o++) n[o] = 1e-20;
}
- e.noATH && me(), r.ATH.floor = 10 * d(v(e, -1));
+ r.ATH.floor = 10 * B(v(e, -1));
}(e), p[0] = 0, t = 1; t < f; t++) p[t] = Math.pow(t, 4 / 3);
- for (t = 0; t < f - 1; t++) m[t] = t + 1 - Math.pow(.5 * (p[t] + p[t + 1]), .75);
- for (m[t] = .5, t = 0; t < c; t++) h[t] = Math.pow(2, -.1875 * (t - 210));
- for (t = 0; t <= c + u; t++) y[t] = Math.pow(2, .25 * (t - 210 - u));
- var s, r, i, o;
- for (l.huffman_init(a), 32 <= (t = e.exp_nspsytune >> 2 & 63) && (t -= 64), s = Math.pow(10, t / 4 / 10), 32 <= (t = e.exp_nspsytune >> 8 & 63) && (t -= 64), r = Math.pow(10, t / 4 / 10), 32 <= (t = e.exp_nspsytune >> 14 & 63) && (t -= 64), i = Math.pow(10, t / 4 / 10), 32 <= (t = e.exp_nspsytune >> 20 & 63) && (t -= 64), o = i * Math.pow(10, t / 4 / 10), t = 0; t < Ae.SBMAX_l; t++) _ = t <= 6 ? s : t <= 13 ? r : t <= 20 ? i : o, a.nsPsy.longfact[t] = _;
- for (t = 0; t < Ae.SBMAX_s; t++) {
+ for (t = 0; t < f - 1; t++) b[t] = t + 1 - Math.pow(.5 * (p[t] + p[t + 1]), .75);
+ for (b[t] = .5, t = 0; t < c; t++) u[t] = Math.pow(2, -.1875 * (t - 210));
+ for (t = 0; t <= c + h; t++) R[t] = Math.pow(2, .25 * (t - 210 - h));
+ var n, r, i, o;
+ for (l.huffman_init(a), 32 <= (t = e.exp_nspsytune >> 2 & 63) && (t -= 64), n = Math.pow(10, t / 4 / 10), 32 <= (t = e.exp_nspsytune >> 8 & 63) && (t -= 64), r = Math.pow(10, t / 4 / 10), 32 <= (t = e.exp_nspsytune >> 14 & 63) && (t -= 64), i = Math.pow(10, t / 4 / 10), 32 <= (t = e.exp_nspsytune >> 20 & 63) && (t -= 64), o = i * Math.pow(10, t / 4 / 10), t = 0; t < Pe.SBMAX_l; t++) {
+ _ = t <= 6 ? n : t <= 13 ? r : t <= 20 ? i : o, a.nsPsy.longfact[t] = _;
+ }
+ for (t = 0; t < Pe.SBMAX_s; t++) {
var _;
- _ = t <= 5 ? s : t <= 10 ? r : t <= 11 ? i : o, a.nsPsy.shortfact[t] = _;
+ _ = t <= 5 ? n : t <= 10 ? r : t <= 11 ? i : o, a.nsPsy.shortfact[t] = _;
}
}
- }, this.on_pe = function (e, t, a, n, s, r) {
+ }, this.on_pe = function (e, t, a, s, n, r) {
var i,
o,
_ = e.internal_flags,
l = 0,
- f = ve(2),
- c = new R(l),
- u = b.ResvMaxBits(e, n, c, r),
- h = (l = c.bits) + u;
- for (j.MAX_BITS_PER_GRANULE < h && (h = j.MAX_BITS_PER_GRANULE), o = i = 0; o < _.channels_out; ++o) a[o] = Math.min(j.MAX_BITS_PER_CHANNEL, l / _.channels_out), f[o] = 0 | a[o] * t[s][o] / 700 - a[o], f[o] > 3 * n / 4 && (f[o] = 3 * n / 4), f[o] < 0 && (f[o] = 0), f[o] + a[o] > j.MAX_BITS_PER_CHANNEL && (f[o] = Math.max(0, j.MAX_BITS_PER_CHANNEL - a[o])), i += f[o];
- if (u < i) for (o = 0; o < _.channels_out; ++o) f[o] = u * f[o] / i;
- for (o = 0; o < _.channels_out; ++o) a[o] += f[o], u -= f[o];
+ f = Ae(2),
+ c = new j(l),
+ h = m.ResvMaxBits(e, s, c, r),
+ u = (l = c.bits) + h;
+ for (Z.MAX_BITS_PER_GRANULE < u && (u = Z.MAX_BITS_PER_GRANULE), o = i = 0; o < _.channels_out; ++o) a[o] = Math.min(Z.MAX_BITS_PER_CHANNEL, l / _.channels_out), f[o] = 0 | a[o] * t[n][o] / 700 - a[o], f[o] > 3 * s / 4 && (f[o] = 3 * s / 4), f[o] < 0 && (f[o] = 0), f[o] + a[o] > Z.MAX_BITS_PER_CHANNEL && (f[o] = Math.max(0, Z.MAX_BITS_PER_CHANNEL - a[o])), i += f[o];
+ if (h < i) for (o = 0; o < _.channels_out; ++o) f[o] = h * f[o] / i;
+ for (o = 0; o < _.channels_out; ++o) a[o] += f[o], h -= f[o];
for (o = i = 0; o < _.channels_out; ++o) i += a[o];
- return j.MAX_BITS_PER_GRANULE < i && me(), h;
+ if (Z.MAX_BITS_PER_GRANULE < i) {
+ for (o = 0; o < _.channels_out; ++o) a[o] *= Z.MAX_BITS_PER_GRANULE, a[o] /= i, a[o];
+ }
+ return u;
+ }, this.reduce_side = function (e, t, a, s) {
+ var n = .33 * (.5 - t) / .5;
+ n < 0 && (n = 0), .5 < n && (n = .5);
+ var r = 0 | .5 * n * (e[0] + e[1]);
+ r > Z.MAX_BITS_PER_CHANNEL - e[0] && (r = Z.MAX_BITS_PER_CHANNEL - e[0]), r < 0 && (r = 0), 125 <= e[1] && (125 < e[1] - r ? (e[0] < a && (e[0] += r), e[1] -= r) : (e[0] += e[1] - 125, e[1] = 125)), s < (r = e[0] + e[1]) && (e[0] = s * e[0] / r, e[1] = s * e[1] / r);
}, this.athAdjust = function (e, t, a) {
- var n = 90.30873362,
- s = V.FAST_LOG10_X(t, 10),
+ var s = 90.30873362,
+ n = ee.FAST_LOG10_X(t, 10),
r = e * e,
i = 0;
- return s -= a, 1e-20 < r && (i = 1 + V.FAST_LOG10_X(r, 10 / n)), i < 0 && (i = 0), s *= i, s += a + n - 94.82444863, Math.pow(10, .1 * s);
- }, this.calc_xmin = function (e, t, a, n) {
- var s,
+ return n -= a, 1e-20 < r && (i = 1 + ee.FAST_LOG10_X(r, 10 / s)), i < 0 && (i = 0), n *= i, n += a + s - 94.82444863, Math.pow(10, .1 * n);
+ }, this.calc_xmin = function (e, t, a, s) {
+ var n,
r = 0,
i = e.internal_flags,
o = 0,
_ = 0,
l = i.ATH,
f = a.xr,
- c = e.VBR == Me.vbr_mtrh ? 1 : 0,
- u = i.masking_lower;
- for (e.VBR != Me.vbr_mtrh && e.VBR != Me.vbr_mt || (u = 1), s = 0; s < a.psy_lmax; s++) {
- for (w = e.VBR == Me.vbr_rh || e.VBR == Me.vbr_mtrh ? athAdjust(l.adjust, l.l[s], l.floor) : l.adjust * l.l[s], v = a.width[s], S = w / v, M = B, A = v >> 1, y = 0; k = f[o] * f[o], y += k, M += k < S ? k : S, R = f[++o] * f[o], y += R, M += R < S ? R : S, o++, 0 < --A;);
- if (w < y && _++, s == Ae.SBPSY_l && me(), 0 != c && (w = M), !e.ATHonly) {
- var h = t.en.l[s];
- 0 < h && (x = y * t.thm.l[s] * u / h, 0 != c && (x *= i.nsPsy.longfact[s]), w < x && (w = x));
- }
- n[r++] = 0 != c ? w : w * i.nsPsy.longfact[s];
+ c = e.VBR == xe.vbr_mtrh ? 1 : 0,
+ h = i.masking_lower;
+ for (e.VBR != xe.vbr_mtrh && e.VBR != xe.vbr_mt || (h = 1), n = 0; n < a.psy_lmax; n++) {
+ S = (g = e.VBR == xe.vbr_rh || e.VBR == xe.vbr_mtrh ? athAdjust(l.adjust, l.l[n], l.floor) : l.adjust * l.l[n]) / (b = a.width[n]), M = T, B = b >> 1, A = 0;
+ do {
+ A += k = f[o] * f[o], M += k < S ? k : S, A += y = f[++o] * f[o], M += y < S ? y : S, o++;
+ } while (0 < --B);
+ if (g < A && _++, n == Pe.SBPSY_l) M < (R = g * i.nsPsy.longfact[n]) && (M = R);
+ if (0 != c && (g = M), !e.ATHonly) if (0 < (w = t.en.l[n])) R = A * t.thm.l[n] * h / w, 0 != c && (R *= i.nsPsy.longfact[n]), g < R && (g = R);
+ s[r++] = 0 != c ? g : g * i.nsPsy.longfact[n];
}
- var b = 575;
- if (a.block_type != Ae.SHORT_TYPE) for (var p = 576; 0 != p-- && N.EQ(f[p], 0);) b = p;
- a.max_nonzero_coeff = b;
- for (var m = a.sfb_smin; s < a.psymax; m++, s += 3) {
- var v, d, g;
- for (g = e.VBR == Me.vbr_rh || e.VBR == Me.vbr_mtrh ? athAdjust(l.adjust, l.s[m], l.floor) : l.adjust * l.s[m], v = a.width[s], d = 0; d < 3; d++) {
- var w,
+ var u = 575;
+ if (a.block_type != Pe.SHORT_TYPE) for (var m = 576; 0 != m-- && q.EQ(f[m], 0);) u = m;
+ a.max_nonzero_coeff = u;
+ for (var p = a.sfb_smin; n < a.psymax; p++, n += 3) {
+ var b, v, d;
+ for (d = e.VBR == xe.vbr_rh || e.VBR == xe.vbr_mtrh ? athAdjust(l.adjust, l.s[p], l.floor) : l.adjust * l.s[p], b = a.width[n], v = 0; v < 3; v++) {
+ var g,
S,
M,
- y = 0,
- A = v >> 1;
- S = g / v, M = B;
+ w,
+ R,
+ A = 0,
+ B = b >> 1;
+ S = d / b, M = T;
do {
- var k, R;
- k = f[o] * f[o], y += k, M += k < S ? k : S, R = f[++o] * f[o], y += R, M += R < S ? R : S, o++;
- } while (0 < --A);
- if (g < y && _++, m == Ae.SBPSY_s && me(), w = 0 != c ? M : g, !e.ATHonly && !e.ATHshort) {
- var x,
- h = t.en.s[m][d];
- 0 < h && (x = y * t.thm.s[m][d] * u / h, 0 != c && (x *= i.nsPsy.shortfact[m]), w < x && (w = x));
- }
- n[r++] = 0 != c ? w : w * i.nsPsy.shortfact[m];
+ var k, y;
+ A += k = f[o] * f[o], M += k < S ? k : S, A += y = f[++o] * f[o], M += y < S ? y : S, o++;
+ } while (0 < --B);
+ if (d < A && _++, p == Pe.SBPSY_s) M < (R = d * i.nsPsy.shortfact[p]) && (M = R);
+ if (g = 0 != c ? M : d, !e.ATHonly && !e.ATHshort) if (0 < (w = t.en.s[p][v])) R = A * t.thm.s[p][v] * h / w, 0 != c && (R *= i.nsPsy.shortfact[p]), g < R && (g = R);
+ s[r++] = 0 != c ? g : g * i.nsPsy.shortfact[p];
}
- e.useTemporal && (n[r - 3] > n[r - 3 + 1] && (n[r - 3 + 1] += (n[r - 3] - n[r - 3 + 1]) * i.decay), n[r - 3 + 1] > n[r - 3 + 2] && (n[r - 3 + 2] += (n[r - 3 + 1] - n[r - 3 + 2]) * i.decay));
+ e.useTemporal && (s[r - 3] > s[r - 3 + 1] && (s[r - 3 + 1] += (s[r - 3] - s[r - 3 + 1]) * i.decay), s[r - 3 + 1] > s[r - 3 + 2] && (s[r - 3 + 2] += (s[r - 3 + 1] - s[r - 3 + 2]) * i.decay));
}
return _;
- }, this.calc_noise_core = function (e, t, a, n) {
- var s = 0,
+ }, this.calc_noise_core = function (e, t, a, s) {
+ var n = 0,
r = t.s,
i = e.l3_enc;
- if (r > e.count1) for (; 0 != a--;) _ = e.xr[r], r++, s += _ * _, _ = e.xr[r], r++, s += _ * _;else if (r > e.big_values) {
- var o = de(2);
- for (o[0] = 0, o[1] = n; 0 != a--;) _ = Math.abs(e.xr[r]) - o[i[r]], r++, s += _ * _, _ = Math.abs(e.xr[r]) - o[i[r]], r++, s += _ * _;
+ if (r > e.count1) for (; 0 != a--;) {
+ _ = e.xr[r], r++, n += _ * _, _ = e.xr[r], r++, n += _ * _;
+ } else if (r > e.big_values) {
+ var o = Be(2);
+ for (o[0] = 0, o[1] = s; 0 != a--;) {
+ _ = Math.abs(e.xr[r]) - o[i[r]], r++, n += _ * _, _ = Math.abs(e.xr[r]) - o[i[r]], r++, n += _ * _;
+ }
} else for (; 0 != a--;) {
var _;
- _ = Math.abs(e.xr[r]) - p[i[r]] * n, r++, s += _ * _, _ = Math.abs(e.xr[r]) - p[i[r]] * n, r++, s += _ * _;
+ _ = Math.abs(e.xr[r]) - p[i[r]] * s, r++, n += _ * _, _ = Math.abs(e.xr[r]) - p[i[r]] * s, r++, n += _ * _;
}
- return t.s = r, s;
- }, this.calc_noise = function (e, t, a, n, s) {
+ return t.s = r, n;
+ }, this.calc_noise = function (e, t, a, s, n) {
var r,
i,
o = 0,
@@ -35857,54 +35530,83 @@ src: recorder-core.js,engine/mp3.js,engine/mp3-engine.js
l = 0,
f = 0,
c = 0,
- u = -20,
- h = 0,
- b = e.scalefac,
+ h = -20,
+ u = 0,
+ m = e.scalefac,
p = 0;
- for (n.over_SSD = 0, r = 0; r < e.psymax; r++) {
- var m,
- v = e.global_gain - (b[p++] + (0 != e.preflag ? M[r] : 0) << e.scalefac_scale + 1) - 8 * e.subblock_gain[e.window[r]],
+ for (r = s.over_SSD = 0; r < e.psymax; r++) {
+ var b,
+ v = e.global_gain - (m[p++] + (0 != e.preflag ? w[r] : 0) << e.scalefac_scale + 1) - 8 * e.subblock_gain[e.window[r]],
d = 0;
- if (null != s && s.step[r] == v) d = s.noise[r], h += e.width[r], a[o++] = d / t[_++], d = s.noise_log[r];else {
+ if (null != n && n.step[r] == v) d = n.noise[r], u += e.width[r], a[o++] = d / t[_++], d = n.noise_log[r];else {
var g,
- w = y[v + T.Q_MAX2];
- i = e.width[r] >> 1, h + e.width[r] > e.max_nonzero_coeff && (g = e.max_nonzero_coeff - h + 1, i = 0 < g ? g >> 1 : 0);
- var S = new A(h);
- d = this.calc_noise_core(e, S, i, w), h = S.s, null != s && (s.step[r] = v, s.noise[r] = d), d = a[o++] = d / t[_++], d = V.FAST_LOG10(Math.max(d, 1e-20)), null != s && (s.noise_log[r] = d);
+ S = R[v + x.Q_MAX2];
+ if (i = e.width[r] >> 1, u + e.width[r] > e.max_nonzero_coeff) i = 0 < (g = e.max_nonzero_coeff - u + 1) ? g >> 1 : 0;
+ var M = new A(u);
+ d = this.calc_noise_core(e, M, i, S), u = M.s, null != n && (n.step[r] = v, n.noise[r] = d), d = a[o++] = d / t[_++], d = ee.FAST_LOG10(Math.max(d, 1e-20)), null != n && (n.noise_log[r] = d);
}
- null != s && (s.global_gain = e.global_gain), c += d, 0 < d && (m = Math.max(0 | 10 * d + .5, 1), n.over_SSD += m * m, l++, f += d), u = Math.max(u, d);
+ if (null != n && (n.global_gain = e.global_gain), c += d, 0 < d) b = Math.max(0 | 10 * d + .5, 1), s.over_SSD += b * b, l++, f += d;
+ h = Math.max(h, d);
}
- return n.over_count = l, n.tot_noise = c, n.over_noise = f, n.max_noise = u, l;
+ return s.over_count = l, s.tot_noise = c, s.over_noise = f, s.max_noise = h, l;
+ }, this.set_pinfo = function (e, t, a, s, n) {
+ var r,
+ i,
+ o,
+ _,
+ l,
+ f = e.internal_flags,
+ c = 0 == t.scalefac_scale ? .5 : 1,
+ h = t.scalefac,
+ u = Be(z.SFBMAX),
+ m = Be(z.SFBMAX),
+ p = new y();
+ calc_xmin(e, a, t, u), calc_noise(t, u, m, p, null);
+ var b = 0;
+ for (i = t.sfb_lmax, t.block_type != Pe.SHORT_TYPE && 0 == t.mixed_block_flag && (i = 22), r = 0; r < i; r++) {
+ var v = f.scalefac_band.l[r],
+ d = (g = f.scalefac_band.l[r + 1]) - v;
+ for (_ = 0; b < g; b++) _ += t.xr[b] * t.xr[b];
+ _ /= d, l = 1e15, f.pinfo.en[s][n][r] = l * _, f.pinfo.xfsf[s][n][r] = l * u[r] * m[r] / d, 0 < a.en.l[r] && !e.ATHonly ? _ /= a.en.l[r] : _ = 0, f.pinfo.thr[s][n][r] = l * Math.max(_ * a.thm.l[r], f.ATH.l[r]), (f.pinfo.LAMEsfb[s][n][r] = 0) != t.preflag && 11 <= r && (f.pinfo.LAMEsfb[s][n][r] = -c * w[r]), r < Pe.SBPSY_l && (f.pinfo.LAMEsfb[s][n][r] -= c * h[r]);
+ }
+ if (t.block_type == Pe.SHORT_TYPE) for (i = r, r = t.sfb_smin; r < Pe.SBMAX_s; r++) {
+ v = f.scalefac_band.s[r], d = (g = f.scalefac_band.s[r + 1]) - v;
+ for (var g, S = 0; S < 3; S++) {
+ for (_ = 0, o = v; o < g; o++) _ += t.xr[b] * t.xr[b], b++;
+ _ = Math.max(_ / d, 1e-20), l = 1e15, f.pinfo.en_s[s][n][3 * r + S] = l * _, f.pinfo.xfsf_s[s][n][3 * r + S] = l * u[i] * m[i] / d, 0 < a.en.s[r][S] ? _ /= a.en.s[r][S] : _ = 0, (e.ATHonly || e.ATHshort) && (_ = 0), f.pinfo.thr_s[s][n][3 * r + S] = l * Math.max(_ * a.thm.s[r][S], f.ATH.s[r]), f.pinfo.LAMEsfb_s[s][n][3 * r + S] = -2 * t.subblock_gain[S], r < Pe.SBPSY_s && (f.pinfo.LAMEsfb_s[s][n][3 * r + S] -= c * h[i]), i++;
+ }
+ }
+ f.pinfo.LAMEqss[s][n] = t.global_gain, f.pinfo.LAMEmainbits[s][n] = t.part2_3_length + t.part2_length, f.pinfo.LAMEsfbits[s][n] = t.part2_length, f.pinfo.over[s][n] = p.over_count, f.pinfo.max_noise[s][n] = 10 * p.max_noise, f.pinfo.over_noise[s][n] = 10 * p.over_noise, f.pinfo.tot_noise[s][n] = 10 * p.tot_noise, f.pinfo.over_SSD[s][n] = p.over_SSD;
};
}
- function B() {
- this.xr = de(576), this.l3_enc = ve(576), this.scalefac = ve(F.SFBMAX), this.xrpow_max = 0, this.part2_3_length = 0, this.big_values = 0, this.count1 = 0, this.global_gain = 0, this.scalefac_compress = 0, this.block_type = 0, this.mixed_block_flag = 0, this.table_select = ve(3), this.subblock_gain = ve(4), this.region0_count = 0, this.region1_count = 0, this.preflag = 0, this.scalefac_scale = 0, this.count1table_select = 0, this.part2_length = 0, this.sfb_lmax = 0, this.sfb_smin = 0, this.psy_lmax = 0, this.sfbmax = 0, this.psymax = 0, this.sfbdivide = 0, this.width = ve(F.SFBMAX), this.window = ve(F.SFBMAX), this.count1bits = 0, this.sfb_partition_table = null, this.slen = ve(4), this.max_nonzero_coeff = 0;
+ function T() {
+ this.xr = Be(576), this.l3_enc = Ae(576), this.scalefac = Ae(z.SFBMAX), this.xrpow_max = 0, this.part2_3_length = 0, this.big_values = 0, this.count1 = 0, this.global_gain = 0, this.scalefac_compress = 0, this.block_type = 0, this.mixed_block_flag = 0, this.table_select = Ae(3), this.subblock_gain = Ae(4), this.region0_count = 0, this.region1_count = 0, this.preflag = 0, this.scalefac_scale = 0, this.count1table_select = 0, this.part2_length = 0, this.sfb_lmax = 0, this.sfb_smin = 0, this.psy_lmax = 0, this.sfbmax = 0, this.psymax = 0, this.sfbdivide = 0, this.width = Ae(z.SFBMAX), this.window = Ae(z.SFBMAX), this.count1bits = 0, this.sfb_partition_table = null, this.slen = Ae(4), this.max_nonzero_coeff = 0;
var a = this;
- function n(e) {
+ function s(e) {
return new Int32Array(e);
}
this.assign = function (e) {
var t;
- a.xr = (t = e.xr, new Float32Array(t)), a.l3_enc = n(e.l3_enc), a.scalefac = n(e.scalefac), a.xrpow_max = e.xrpow_max, a.part2_3_length = e.part2_3_length, a.big_values = e.big_values, a.count1 = e.count1, a.global_gain = e.global_gain, a.scalefac_compress = e.scalefac_compress, a.block_type = e.block_type, a.mixed_block_flag = e.mixed_block_flag, a.table_select = n(e.table_select), a.subblock_gain = n(e.subblock_gain), a.region0_count = e.region0_count, a.region1_count = e.region1_count, a.preflag = e.preflag, a.scalefac_scale = e.scalefac_scale, a.count1table_select = e.count1table_select, a.part2_length = e.part2_length, a.sfb_lmax = e.sfb_lmax, a.sfb_smin = e.sfb_smin, a.psy_lmax = e.psy_lmax, a.sfbmax = e.sfbmax, a.psymax = e.psymax, a.sfbdivide = e.sfbdivide, a.width = n(e.width), a.window = n(e.window), a.count1bits = e.count1bits, a.sfb_partition_table = e.sfb_partition_table.slice(0), a.slen = n(e.slen), a.max_nonzero_coeff = e.max_nonzero_coeff;
+ a.xr = (t = e.xr, new Float32Array(t)), a.l3_enc = s(e.l3_enc), a.scalefac = s(e.scalefac), a.xrpow_max = e.xrpow_max, a.part2_3_length = e.part2_3_length, a.big_values = e.big_values, a.count1 = e.count1, a.global_gain = e.global_gain, a.scalefac_compress = e.scalefac_compress, a.block_type = e.block_type, a.mixed_block_flag = e.mixed_block_flag, a.table_select = s(e.table_select), a.subblock_gain = s(e.subblock_gain), a.region0_count = e.region0_count, a.region1_count = e.region1_count, a.preflag = e.preflag, a.scalefac_scale = e.scalefac_scale, a.count1table_select = e.count1table_select, a.part2_length = e.part2_length, a.sfb_lmax = e.sfb_lmax, a.sfb_smin = e.sfb_smin, a.psy_lmax = e.psy_lmax, a.sfbmax = e.sfbmax, a.psymax = e.psymax, a.sfbdivide = e.sfbdivide, a.width = s(e.width), a.window = s(e.window), a.count1bits = e.count1bits, a.sfb_partition_table = e.sfb_partition_table.slice(0), a.slen = s(e.slen), a.max_nonzero_coeff = e.max_nonzero_coeff;
};
}
- k.t1HB = [1, 1, 1, 0], k.t2HB = [1, 2, 1, 3, 1, 1, 3, 2, 0], k.t3HB = [3, 2, 1, 1, 1, 1, 3, 2, 0], k.t5HB = [1, 2, 6, 5, 3, 1, 4, 4, 7, 5, 7, 1, 6, 1, 1, 0], k.t6HB = [7, 3, 5, 1, 6, 2, 3, 2, 5, 4, 4, 1, 3, 3, 2, 0], k.t7HB = [1, 2, 10, 19, 16, 10, 3, 3, 7, 10, 5, 3, 11, 4, 13, 17, 8, 4, 12, 11, 18, 15, 11, 2, 7, 6, 9, 14, 3, 1, 6, 4, 5, 3, 2, 0], k.t8HB = [3, 4, 6, 18, 12, 5, 5, 1, 2, 16, 9, 3, 7, 3, 5, 14, 7, 3, 19, 17, 15, 13, 10, 4, 13, 5, 8, 11, 5, 1, 12, 4, 4, 1, 1, 0], k.t9HB = [7, 5, 9, 14, 15, 7, 6, 4, 5, 5, 6, 7, 7, 6, 8, 8, 8, 5, 15, 6, 9, 10, 5, 1, 11, 7, 9, 6, 4, 1, 14, 4, 6, 2, 6, 0], k.t10HB = [1, 2, 10, 23, 35, 30, 12, 17, 3, 3, 8, 12, 18, 21, 12, 7, 11, 9, 15, 21, 32, 40, 19, 6, 14, 13, 22, 34, 46, 23, 18, 7, 20, 19, 33, 47, 27, 22, 9, 3, 31, 22, 41, 26, 21, 20, 5, 3, 14, 13, 10, 11, 16, 6, 5, 1, 9, 8, 7, 8, 4, 4, 2, 0], k.t11HB = [3, 4, 10, 24, 34, 33, 21, 15, 5, 3, 4, 10, 32, 17, 11, 10, 11, 7, 13, 18, 30, 31, 20, 5, 25, 11, 19, 59, 27, 18, 12, 5, 35, 33, 31, 58, 30, 16, 7, 5, 28, 26, 32, 19, 17, 15, 8, 14, 14, 12, 9, 13, 14, 9, 4, 1, 11, 4, 6, 6, 6, 3, 2, 0], k.t12HB = [9, 6, 16, 33, 41, 39, 38, 26, 7, 5, 6, 9, 23, 16, 26, 11, 17, 7, 11, 14, 21, 30, 10, 7, 17, 10, 15, 12, 18, 28, 14, 5, 32, 13, 22, 19, 18, 16, 9, 5, 40, 17, 31, 29, 17, 13, 4, 2, 27, 12, 11, 15, 10, 7, 4, 1, 27, 12, 8, 12, 6, 3, 1, 0], k.t13HB = [1, 5, 14, 21, 34, 51, 46, 71, 42, 52, 68, 52, 67, 44, 43, 19, 3, 4, 12, 19, 31, 26, 44, 33, 31, 24, 32, 24, 31, 35, 22, 14, 15, 13, 23, 36, 59, 49, 77, 65, 29, 40, 30, 40, 27, 33, 42, 16, 22, 20, 37, 61, 56, 79, 73, 64, 43, 76, 56, 37, 26, 31, 25, 14, 35, 16, 60, 57, 97, 75, 114, 91, 54, 73, 55, 41, 48, 53, 23, 24, 58, 27, 50, 96, 76, 70, 93, 84, 77, 58, 79, 29, 74, 49, 41, 17, 47, 45, 78, 74, 115, 94, 90, 79, 69, 83, 71, 50, 59, 38, 36, 15, 72, 34, 56, 95, 92, 85, 91, 90, 86, 73, 77, 65, 51, 44, 43, 42, 43, 20, 30, 44, 55, 78, 72, 87, 78, 61, 46, 54, 37, 30, 20, 16, 53, 25, 41, 37, 44, 59, 54, 81, 66, 76, 57, 54, 37, 18, 39, 11, 35, 33, 31, 57, 42, 82, 72, 80, 47, 58, 55, 21, 22, 26, 38, 22, 53, 25, 23, 38, 70, 60, 51, 36, 55, 26, 34, 23, 27, 14, 9, 7, 34, 32, 28, 39, 49, 75, 30, 52, 48, 40, 52, 28, 18, 17, 9, 5, 45, 21, 34, 64, 56, 50, 49, 45, 31, 19, 12, 15, 10, 7, 6, 3, 48, 23, 20, 39, 36, 35, 53, 21, 16, 23, 13, 10, 6, 1, 4, 2, 16, 15, 17, 27, 25, 20, 29, 11, 17, 12, 16, 8, 1, 1, 0, 1], k.t15HB = [7, 12, 18, 53, 47, 76, 124, 108, 89, 123, 108, 119, 107, 81, 122, 63, 13, 5, 16, 27, 46, 36, 61, 51, 42, 70, 52, 83, 65, 41, 59, 36, 19, 17, 15, 24, 41, 34, 59, 48, 40, 64, 50, 78, 62, 80, 56, 33, 29, 28, 25, 43, 39, 63, 55, 93, 76, 59, 93, 72, 54, 75, 50, 29, 52, 22, 42, 40, 67, 57, 95, 79, 72, 57, 89, 69, 49, 66, 46, 27, 77, 37, 35, 66, 58, 52, 91, 74, 62, 48, 79, 63, 90, 62, 40, 38, 125, 32, 60, 56, 50, 92, 78, 65, 55, 87, 71, 51, 73, 51, 70, 30, 109, 53, 49, 94, 88, 75, 66, 122, 91, 73, 56, 42, 64, 44, 21, 25, 90, 43, 41, 77, 73, 63, 56, 92, 77, 66, 47, 67, 48, 53, 36, 20, 71, 34, 67, 60, 58, 49, 88, 76, 67, 106, 71, 54, 38, 39, 23, 15, 109, 53, 51, 47, 90, 82, 58, 57, 48, 72, 57, 41, 23, 27, 62, 9, 86, 42, 40, 37, 70, 64, 52, 43, 70, 55, 42, 25, 29, 18, 11, 11, 118, 68, 30, 55, 50, 46, 74, 65, 49, 39, 24, 16, 22, 13, 14, 7, 91, 44, 39, 38, 34, 63, 52, 45, 31, 52, 28, 19, 14, 8, 9, 3, 123, 60, 58, 53, 47, 43, 32, 22, 37, 24, 17, 12, 15, 10, 2, 1, 71, 37, 34, 30, 28, 20, 17, 26, 21, 16, 10, 6, 8, 6, 2, 0], k.t16HB = [1, 5, 14, 44, 74, 63, 110, 93, 172, 149, 138, 242, 225, 195, 376, 17, 3, 4, 12, 20, 35, 62, 53, 47, 83, 75, 68, 119, 201, 107, 207, 9, 15, 13, 23, 38, 67, 58, 103, 90, 161, 72, 127, 117, 110, 209, 206, 16, 45, 21, 39, 69, 64, 114, 99, 87, 158, 140, 252, 212, 199, 387, 365, 26, 75, 36, 68, 65, 115, 101, 179, 164, 155, 264, 246, 226, 395, 382, 362, 9, 66, 30, 59, 56, 102, 185, 173, 265, 142, 253, 232, 400, 388, 378, 445, 16, 111, 54, 52, 100, 184, 178, 160, 133, 257, 244, 228, 217, 385, 366, 715, 10, 98, 48, 91, 88, 165, 157, 148, 261, 248, 407, 397, 372, 380, 889, 884, 8, 85, 84, 81, 159, 156, 143, 260, 249, 427, 401, 392, 383, 727, 713, 708, 7, 154, 76, 73, 141, 131, 256, 245, 426, 406, 394, 384, 735, 359, 710, 352, 11, 139, 129, 67, 125, 247, 233, 229, 219, 393, 743, 737, 720, 885, 882, 439, 4, 243, 120, 118, 115, 227, 223, 396, 746, 742, 736, 721, 712, 706, 223, 436, 6, 202, 224, 222, 218, 216, 389, 386, 381, 364, 888, 443, 707, 440, 437, 1728, 4, 747, 211, 210, 208, 370, 379, 734, 723, 714, 1735, 883, 877, 876, 3459, 865, 2, 377, 369, 102, 187, 726, 722, 358, 711, 709, 866, 1734, 871, 3458, 870, 434, 0, 12, 10, 7, 11, 10, 17, 11, 9, 13, 12, 10, 7, 5, 3, 1, 3], k.t24HB = [15, 13, 46, 80, 146, 262, 248, 434, 426, 669, 653, 649, 621, 517, 1032, 88, 14, 12, 21, 38, 71, 130, 122, 216, 209, 198, 327, 345, 319, 297, 279, 42, 47, 22, 41, 74, 68, 128, 120, 221, 207, 194, 182, 340, 315, 295, 541, 18, 81, 39, 75, 70, 134, 125, 116, 220, 204, 190, 178, 325, 311, 293, 271, 16, 147, 72, 69, 135, 127, 118, 112, 210, 200, 188, 352, 323, 306, 285, 540, 14, 263, 66, 129, 126, 119, 114, 214, 202, 192, 180, 341, 317, 301, 281, 262, 12, 249, 123, 121, 117, 113, 215, 206, 195, 185, 347, 330, 308, 291, 272, 520, 10, 435, 115, 111, 109, 211, 203, 196, 187, 353, 332, 313, 298, 283, 531, 381, 17, 427, 212, 208, 205, 201, 193, 186, 177, 169, 320, 303, 286, 268, 514, 377, 16, 335, 199, 197, 191, 189, 181, 174, 333, 321, 305, 289, 275, 521, 379, 371, 11, 668, 184, 183, 179, 175, 344, 331, 314, 304, 290, 277, 530, 383, 373, 366, 10, 652, 346, 171, 168, 164, 318, 309, 299, 287, 276, 263, 513, 375, 368, 362, 6, 648, 322, 316, 312, 307, 302, 292, 284, 269, 261, 512, 376, 370, 364, 359, 4, 620, 300, 296, 294, 288, 282, 273, 266, 515, 380, 374, 369, 365, 361, 357, 2, 1033, 280, 278, 274, 267, 264, 259, 382, 378, 372, 367, 363, 360, 358, 356, 0, 43, 20, 19, 17, 15, 13, 11, 9, 7, 6, 4, 7, 5, 3, 1, 3], k.t32HB = [1, 10, 8, 20, 12, 20, 16, 32, 14, 12, 24, 0, 28, 16, 24, 16], k.t33HB = [15, 28, 26, 48, 22, 40, 36, 64, 14, 24, 20, 32, 12, 16, 8, 0], k.t1l = [1, 4, 3, 5], k.t2l = [1, 4, 7, 4, 5, 7, 6, 7, 8], k.t3l = [2, 3, 7, 4, 4, 7, 6, 7, 8], k.t5l = [1, 4, 7, 8, 4, 5, 8, 9, 7, 8, 9, 10, 8, 8, 9, 10], k.t6l = [3, 4, 6, 8, 4, 4, 6, 7, 5, 6, 7, 8, 7, 7, 8, 9], k.t7l = [1, 4, 7, 9, 9, 10, 4, 6, 8, 9, 9, 10, 7, 7, 9, 10, 10, 11, 8, 9, 10, 11, 11, 11, 8, 9, 10, 11, 11, 12, 9, 10, 11, 12, 12, 12], k.t8l = [2, 4, 7, 9, 9, 10, 4, 4, 6, 10, 10, 10, 7, 6, 8, 10, 10, 11, 9, 10, 10, 11, 11, 12, 9, 9, 10, 11, 12, 12, 10, 10, 11, 11, 13, 13], k.t9l = [3, 4, 6, 7, 9, 10, 4, 5, 6, 7, 8, 10, 5, 6, 7, 8, 9, 10, 7, 7, 8, 9, 9, 10, 8, 8, 9, 9, 10, 11, 9, 9, 10, 10, 11, 11], k.t10l = [1, 4, 7, 9, 10, 10, 10, 11, 4, 6, 8, 9, 10, 11, 10, 10, 7, 8, 9, 10, 11, 12, 11, 11, 8, 9, 10, 11, 12, 12, 11, 12, 9, 10, 11, 12, 12, 12, 12, 12, 10, 11, 12, 12, 13, 13, 12, 13, 9, 10, 11, 12, 12, 12, 13, 13, 10, 10, 11, 12, 12, 13, 13, 13], k.t11l = [2, 4, 6, 8, 9, 10, 9, 10, 4, 5, 6, 8, 10, 10, 9, 10, 6, 7, 8, 9, 10, 11, 10, 10, 8, 8, 9, 11, 10, 12, 10, 11, 9, 10, 10, 11, 11, 12, 11, 12, 9, 10, 11, 12, 12, 13, 12, 13, 9, 9, 9, 10, 11, 12, 12, 12, 9, 9, 10, 11, 12, 12, 12, 12], k.t12l = [4, 4, 6, 8, 9, 10, 10, 10, 4, 5, 6, 7, 9, 9, 10, 10, 6, 6, 7, 8, 9, 10, 9, 10, 7, 7, 8, 8, 9, 10, 10, 10, 8, 8, 9, 9, 10, 10, 10, 11, 9, 9, 10, 10, 10, 11, 10, 11, 9, 9, 9, 10, 10, 11, 11, 12, 10, 10, 10, 11, 11, 11, 11, 12], k.t13l = [1, 5, 7, 8, 9, 10, 10, 11, 10, 11, 12, 12, 13, 13, 14, 14, 4, 6, 8, 9, 10, 10, 11, 11, 11, 11, 12, 12, 13, 14, 14, 14, 7, 8, 9, 10, 11, 11, 12, 12, 11, 12, 12, 13, 13, 14, 15, 15, 8, 9, 10, 11, 11, 12, 12, 12, 12, 13, 13, 13, 13, 14, 15, 15, 9, 9, 11, 11, 12, 12, 13, 13, 12, 13, 13, 14, 14, 15, 15, 16, 10, 10, 11, 12, 12, 12, 13, 13, 13, 13, 14, 13, 15, 15, 16, 16, 10, 11, 12, 12, 13, 13, 13, 13, 13, 14, 14, 14, 15, 15, 16, 16, 11, 11, 12, 13, 13, 13, 14, 14, 14, 14, 15, 15, 15, 16, 18, 18, 10, 10, 11, 12, 12, 13, 13, 14, 14, 14, 14, 15, 15, 16, 17, 17, 11, 11, 12, 12, 13, 13, 13, 15, 14, 15, 15, 16, 16, 16, 18, 17, 11, 12, 12, 13, 13, 14, 14, 15, 14, 15, 16, 15, 16, 17, 18, 19, 12, 12, 12, 13, 14, 14, 14, 14, 15, 15, 15, 16, 17, 17, 17, 18, 12, 13, 13, 14, 14, 15, 14, 15, 16, 16, 17, 17, 17, 18, 18, 18, 13, 13, 14, 15, 15, 15, 16, 16, 16, 16, 16, 17, 18, 17, 18, 18, 14, 14, 14, 15, 15, 15, 17, 16, 16, 19, 17, 17, 17, 19, 18, 18, 13, 14, 15, 16, 16, 16, 17, 16, 17, 17, 18, 18, 21, 20, 21, 18], k.t15l = [3, 5, 6, 8, 8, 9, 10, 10, 10, 11, 11, 12, 12, 12, 13, 14, 5, 5, 7, 8, 9, 9, 10, 10, 10, 11, 11, 12, 12, 12, 13, 13, 6, 7, 7, 8, 9, 9, 10, 10, 10, 11, 11, 12, 12, 13, 13, 13, 7, 8, 8, 9, 9, 10, 10, 11, 11, 11, 12, 12, 12, 13, 13, 13, 8, 8, 9, 9, 10, 10, 11, 11, 11, 11, 12, 12, 12, 13, 13, 13, 9, 9, 9, 10, 10, 10, 11, 11, 11, 11, 12, 12, 13, 13, 13, 14, 10, 9, 10, 10, 10, 11, 11, 11, 11, 12, 12, 12, 13, 13, 14, 14, 10, 10, 10, 11, 11, 11, 11, 12, 12, 12, 12, 12, 13, 13, 13, 14, 10, 10, 10, 11, 11, 11, 11, 12, 12, 12, 12, 13, 13, 14, 14, 14, 10, 10, 11, 11, 11, 11, 12, 12, 12, 13, 13, 13, 13, 14, 14, 14, 11, 11, 11, 11, 12, 12, 12, 12, 12, 13, 13, 13, 13, 14, 15, 14, 11, 11, 11, 11, 12, 12, 12, 12, 13, 13, 13, 13, 14, 14, 14, 15, 12, 12, 11, 12, 12, 12, 13, 13, 13, 13, 13, 13, 14, 14, 15, 15, 12, 12, 12, 12, 12, 13, 13, 13, 13, 14, 14, 14, 14, 14, 15, 15, 13, 13, 13, 13, 13, 13, 13, 13, 14, 14, 14, 14, 15, 15, 14, 15, 13, 13, 13, 13, 13, 13, 13, 14, 14, 14, 14, 14, 15, 15, 15, 15], k.t16_5l = [1, 5, 7, 9, 10, 10, 11, 11, 12, 12, 12, 13, 13, 13, 14, 11, 4, 6, 8, 9, 10, 11, 11, 11, 12, 12, 12, 13, 14, 13, 14, 11, 7, 8, 9, 10, 11, 11, 12, 12, 13, 12, 13, 13, 13, 14, 14, 12, 9, 9, 10, 11, 11, 12, 12, 12, 13, 13, 14, 14, 14, 15, 15, 13, 10, 10, 11, 11, 12, 12, 13, 13, 13, 14, 14, 14, 15, 15, 15, 12, 10, 10, 11, 11, 12, 13, 13, 14, 13, 14, 14, 15, 15, 15, 16, 13, 11, 11, 11, 12, 13, 13, 13, 13, 14, 14, 14, 14, 15, 15, 16, 13, 11, 11, 12, 12, 13, 13, 13, 14, 14, 15, 15, 15, 15, 17, 17, 13, 11, 12, 12, 13, 13, 13, 14, 14, 15, 15, 15, 15, 16, 16, 16, 13, 12, 12, 12, 13, 13, 14, 14, 15, 15, 15, 15, 16, 15, 16, 15, 14, 12, 13, 12, 13, 14, 14, 14, 14, 15, 16, 16, 16, 17, 17, 16, 13, 13, 13, 13, 13, 14, 14, 15, 16, 16, 16, 16, 16, 16, 15, 16, 14, 13, 14, 14, 14, 14, 15, 15, 15, 15, 17, 16, 16, 16, 16, 18, 14, 15, 14, 14, 14, 15, 15, 16, 16, 16, 18, 17, 17, 17, 19, 17, 14, 14, 15, 13, 14, 16, 16, 15, 16, 16, 17, 18, 17, 19, 17, 16, 14, 11, 11, 11, 12, 12, 13, 13, 13, 14, 14, 14, 14, 14, 14, 14, 12], k.t16l = [1, 5, 7, 9, 10, 10, 11, 11, 12, 12, 12, 13, 13, 13, 14, 10, 4, 6, 8, 9, 10, 11, 11, 11, 12, 12, 12, 13, 14, 13, 14, 10, 7, 8, 9, 10, 11, 11, 12, 12, 13, 12, 13, 13, 13, 14, 14, 11, 9, 9, 10, 11, 11, 12, 12, 12, 13, 13, 14, 14, 14, 15, 15, 12, 10, 10, 11, 11, 12, 12, 13, 13, 13, 14, 14, 14, 15, 15, 15, 11, 10, 10, 11, 11, 12, 13, 13, 14, 13, 14, 14, 15, 15, 15, 16, 12, 11, 11, 11, 12, 13, 13, 13, 13, 14, 14, 14, 14, 15, 15, 16, 12, 11, 11, 12, 12, 13, 13, 13, 14, 14, 15, 15, 15, 15, 17, 17, 12, 11, 12, 12, 13, 13, 13, 14, 14, 15, 15, 15, 15, 16, 16, 16, 12, 12, 12, 12, 13, 13, 14, 14, 15, 15, 15, 15, 16, 15, 16, 15, 13, 12, 13, 12, 13, 14, 14, 14, 14, 15, 16, 16, 16, 17, 17, 16, 12, 13, 13, 13, 13, 14, 14, 15, 16, 16, 16, 16, 16, 16, 15, 16, 13, 13, 14, 14, 14, 14, 15, 15, 15, 15, 17, 16, 16, 16, 16, 18, 13, 15, 14, 14, 14, 15, 15, 16, 16, 16, 18, 17, 17, 17, 19, 17, 13, 14, 15, 13, 14, 16, 16, 15, 16, 16, 17, 18, 17, 19, 17, 16, 13, 10, 10, 10, 11, 11, 12, 12, 12, 13, 13, 13, 13, 13, 13, 13, 10], k.t24l = [4, 5, 7, 8, 9, 10, 10, 11, 11, 12, 12, 12, 12, 12, 13, 10, 5, 6, 7, 8, 9, 10, 10, 11, 11, 11, 12, 12, 12, 12, 12, 10, 7, 7, 8, 9, 9, 10, 10, 11, 11, 11, 11, 12, 12, 12, 13, 9, 8, 8, 9, 9, 10, 10, 10, 11, 11, 11, 11, 12, 12, 12, 12, 9, 9, 9, 9, 10, 10, 10, 10, 11, 11, 11, 12, 12, 12, 12, 13, 9, 10, 9, 10, 10, 10, 10, 11, 11, 11, 11, 12, 12, 12, 12, 12, 9, 10, 10, 10, 10, 10, 11, 11, 11, 11, 12, 12, 12, 12, 12, 13, 9, 11, 10, 10, 10, 11, 11, 11, 11, 12, 12, 12, 12, 12, 13, 13, 10, 11, 11, 11, 11, 11, 11, 11, 11, 11, 12, 12, 12, 12, 13, 13, 10, 11, 11, 11, 11, 11, 11, 11, 12, 12, 12, 12, 12, 13, 13, 13, 10, 12, 11, 11, 11, 11, 12, 12, 12, 12, 12, 12, 13, 13, 13, 13, 10, 12, 12, 11, 11, 11, 12, 12, 12, 12, 12, 12, 13, 13, 13, 13, 10, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 13, 13, 13, 13, 13, 10, 12, 12, 12, 12, 12, 12, 12, 12, 13, 13, 13, 13, 13, 13, 13, 10, 13, 12, 12, 12, 12, 12, 12, 13, 13, 13, 13, 13, 13, 13, 13, 10, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 10, 10, 10, 10, 6], k.t32l = [1, 5, 5, 7, 5, 8, 7, 9, 5, 7, 7, 9, 7, 9, 9, 10], k.t33l = [4, 5, 5, 6, 5, 6, 6, 7, 5, 6, 6, 7, 6, 7, 7, 8], k.ht = [new e(0, 0, null, null), new e(2, 0, k.t1HB, k.t1l), new e(3, 0, k.t2HB, k.t2l), new e(3, 0, k.t3HB, k.t3l), new e(0, 0, null, null), new e(4, 0, k.t5HB, k.t5l), new e(4, 0, k.t6HB, k.t6l), new e(6, 0, k.t7HB, k.t7l), new e(6, 0, k.t8HB, k.t8l), new e(6, 0, k.t9HB, k.t9l), new e(8, 0, k.t10HB, k.t10l), new e(8, 0, k.t11HB, k.t11l), new e(8, 0, k.t12HB, k.t12l), new e(16, 0, k.t13HB, k.t13l), new e(0, 0, null, k.t16_5l), new e(16, 0, k.t15HB, k.t15l), new e(1, 1, k.t16HB, k.t16l), new e(2, 3, k.t16HB, k.t16l), new e(3, 7, k.t16HB, k.t16l), new e(4, 15, k.t16HB, k.t16l), new e(6, 63, k.t16HB, k.t16l), new e(8, 255, k.t16HB, k.t16l), new e(10, 1023, k.t16HB, k.t16l), new e(13, 8191, k.t16HB, k.t16l), new e(4, 15, k.t24HB, k.t24l), new e(5, 31, k.t24HB, k.t24l), new e(6, 63, k.t24HB, k.t24l), new e(7, 127, k.t24HB, k.t24l), new e(8, 255, k.t24HB, k.t24l), new e(9, 511, k.t24HB, k.t24l), new e(11, 2047, k.t24HB, k.t24l), new e(13, 8191, k.t24HB, k.t24l), new e(0, 0, k.t32HB, k.t32l), new e(0, 0, k.t33HB, k.t33l)], k.largetbl = [65540, 327685, 458759, 589832, 655369, 655370, 720906, 720907, 786443, 786444, 786444, 851980, 851980, 851980, 917517, 655370, 262149, 393222, 524295, 589832, 655369, 720906, 720906, 720907, 786443, 786443, 786444, 851980, 917516, 851980, 917516, 655370, 458759, 524295, 589832, 655369, 720905, 720906, 786442, 786443, 851979, 786443, 851979, 851980, 851980, 917516, 917517, 720905, 589832, 589832, 655369, 720905, 720906, 786442, 786442, 786443, 851979, 851979, 917515, 917516, 917516, 983052, 983052, 786441, 655369, 655369, 720905, 720906, 786442, 786442, 851978, 851979, 851979, 917515, 917516, 917516, 983052, 983052, 983053, 720905, 655370, 655369, 720906, 720906, 786442, 851978, 851979, 917515, 851979, 917515, 917516, 983052, 983052, 983052, 1048588, 786441, 720906, 720906, 720906, 786442, 851978, 851979, 851979, 851979, 917515, 917516, 917516, 917516, 983052, 983052, 1048589, 786441, 720907, 720906, 786442, 786442, 851979, 851979, 851979, 917515, 917516, 983052, 983052, 983052, 983052, 1114125, 1114125, 786442, 720907, 786443, 786443, 851979, 851979, 851979, 917515, 917515, 983051, 983052, 983052, 983052, 1048588, 1048589, 1048589, 786442, 786443, 786443, 786443, 851979, 851979, 917515, 917515, 983052, 983052, 983052, 983052, 1048588, 983053, 1048589, 983053, 851978, 786444, 851979, 786443, 851979, 917515, 917516, 917516, 917516, 983052, 1048588, 1048588, 1048589, 1114125, 1114125, 1048589, 786442, 851980, 851980, 851979, 851979, 917515, 917516, 983052, 1048588, 1048588, 1048588, 1048588, 1048589, 1048589, 983053, 1048589, 851978, 851980, 917516, 917516, 917516, 917516, 983052, 983052, 983052, 983052, 1114124, 1048589, 1048589, 1048589, 1048589, 1179661, 851978, 983052, 917516, 917516, 917516, 983052, 983052, 1048588, 1048588, 1048589, 1179661, 1114125, 1114125, 1114125, 1245197, 1114125, 851978, 917517, 983052, 851980, 917516, 1048588, 1048588, 983052, 1048589, 1048589, 1114125, 1179661, 1114125, 1245197, 1114125, 1048589, 851978, 655369, 655369, 655369, 720905, 720905, 786441, 786441, 786441, 851977, 851977, 851977, 851978, 851978, 851978, 851978, 655366], k.table23 = [65538, 262147, 458759, 262148, 327684, 458759, 393222, 458759, 524296], k.table56 = [65539, 262148, 458758, 524296, 262148, 327684, 524294, 589831, 458757, 524294, 589831, 655368, 524295, 524295, 589832, 655369], k.bitrate_table = [[0, 8, 16, 24, 32, 40, 48, 56, 64, 80, 96, 112, 128, 144, 160, -1], [0, 32, 40, 48, 56, 64, 80, 96, 112, 128, 160, 192, 224, 256, 320, -1], [0, 8, 16, 24, 32, 40, 48, 56, 64, -1, -1, -1, -1, -1, -1, -1]], k.samplerate_table = [[22050, 24e3, 16e3, -1], [44100, 48e3, 32e3, -1], [11025, 12e3, 8e3, -1]], k.scfsi_band = [0, 6, 11, 16, 21], T.Q_MAX = 257, T.Q_MAX2 = 116, T.LARGE_BITS = 1e5, T.IXMAX_VAL = 8206;
- var F = {};
- function C() {
- var r, g;
+ F.t1HB = [1, 1, 1, 0], F.t2HB = [1, 2, 1, 3, 1, 1, 3, 2, 0], F.t3HB = [3, 2, 1, 1, 1, 1, 3, 2, 0], F.t5HB = [1, 2, 6, 5, 3, 1, 4, 4, 7, 5, 7, 1, 6, 1, 1, 0], F.t6HB = [7, 3, 5, 1, 6, 2, 3, 2, 5, 4, 4, 1, 3, 3, 2, 0], F.t7HB = [1, 2, 10, 19, 16, 10, 3, 3, 7, 10, 5, 3, 11, 4, 13, 17, 8, 4, 12, 11, 18, 15, 11, 2, 7, 6, 9, 14, 3, 1, 6, 4, 5, 3, 2, 0], F.t8HB = [3, 4, 6, 18, 12, 5, 5, 1, 2, 16, 9, 3, 7, 3, 5, 14, 7, 3, 19, 17, 15, 13, 10, 4, 13, 5, 8, 11, 5, 1, 12, 4, 4, 1, 1, 0], F.t9HB = [7, 5, 9, 14, 15, 7, 6, 4, 5, 5, 6, 7, 7, 6, 8, 8, 8, 5, 15, 6, 9, 10, 5, 1, 11, 7, 9, 6, 4, 1, 14, 4, 6, 2, 6, 0], F.t10HB = [1, 2, 10, 23, 35, 30, 12, 17, 3, 3, 8, 12, 18, 21, 12, 7, 11, 9, 15, 21, 32, 40, 19, 6, 14, 13, 22, 34, 46, 23, 18, 7, 20, 19, 33, 47, 27, 22, 9, 3, 31, 22, 41, 26, 21, 20, 5, 3, 14, 13, 10, 11, 16, 6, 5, 1, 9, 8, 7, 8, 4, 4, 2, 0], F.t11HB = [3, 4, 10, 24, 34, 33, 21, 15, 5, 3, 4, 10, 32, 17, 11, 10, 11, 7, 13, 18, 30, 31, 20, 5, 25, 11, 19, 59, 27, 18, 12, 5, 35, 33, 31, 58, 30, 16, 7, 5, 28, 26, 32, 19, 17, 15, 8, 14, 14, 12, 9, 13, 14, 9, 4, 1, 11, 4, 6, 6, 6, 3, 2, 0], F.t12HB = [9, 6, 16, 33, 41, 39, 38, 26, 7, 5, 6, 9, 23, 16, 26, 11, 17, 7, 11, 14, 21, 30, 10, 7, 17, 10, 15, 12, 18, 28, 14, 5, 32, 13, 22, 19, 18, 16, 9, 5, 40, 17, 31, 29, 17, 13, 4, 2, 27, 12, 11, 15, 10, 7, 4, 1, 27, 12, 8, 12, 6, 3, 1, 0], F.t13HB = [1, 5, 14, 21, 34, 51, 46, 71, 42, 52, 68, 52, 67, 44, 43, 19, 3, 4, 12, 19, 31, 26, 44, 33, 31, 24, 32, 24, 31, 35, 22, 14, 15, 13, 23, 36, 59, 49, 77, 65, 29, 40, 30, 40, 27, 33, 42, 16, 22, 20, 37, 61, 56, 79, 73, 64, 43, 76, 56, 37, 26, 31, 25, 14, 35, 16, 60, 57, 97, 75, 114, 91, 54, 73, 55, 41, 48, 53, 23, 24, 58, 27, 50, 96, 76, 70, 93, 84, 77, 58, 79, 29, 74, 49, 41, 17, 47, 45, 78, 74, 115, 94, 90, 79, 69, 83, 71, 50, 59, 38, 36, 15, 72, 34, 56, 95, 92, 85, 91, 90, 86, 73, 77, 65, 51, 44, 43, 42, 43, 20, 30, 44, 55, 78, 72, 87, 78, 61, 46, 54, 37, 30, 20, 16, 53, 25, 41, 37, 44, 59, 54, 81, 66, 76, 57, 54, 37, 18, 39, 11, 35, 33, 31, 57, 42, 82, 72, 80, 47, 58, 55, 21, 22, 26, 38, 22, 53, 25, 23, 38, 70, 60, 51, 36, 55, 26, 34, 23, 27, 14, 9, 7, 34, 32, 28, 39, 49, 75, 30, 52, 48, 40, 52, 28, 18, 17, 9, 5, 45, 21, 34, 64, 56, 50, 49, 45, 31, 19, 12, 15, 10, 7, 6, 3, 48, 23, 20, 39, 36, 35, 53, 21, 16, 23, 13, 10, 6, 1, 4, 2, 16, 15, 17, 27, 25, 20, 29, 11, 17, 12, 16, 8, 1, 1, 0, 1], F.t15HB = [7, 12, 18, 53, 47, 76, 124, 108, 89, 123, 108, 119, 107, 81, 122, 63, 13, 5, 16, 27, 46, 36, 61, 51, 42, 70, 52, 83, 65, 41, 59, 36, 19, 17, 15, 24, 41, 34, 59, 48, 40, 64, 50, 78, 62, 80, 56, 33, 29, 28, 25, 43, 39, 63, 55, 93, 76, 59, 93, 72, 54, 75, 50, 29, 52, 22, 42, 40, 67, 57, 95, 79, 72, 57, 89, 69, 49, 66, 46, 27, 77, 37, 35, 66, 58, 52, 91, 74, 62, 48, 79, 63, 90, 62, 40, 38, 125, 32, 60, 56, 50, 92, 78, 65, 55, 87, 71, 51, 73, 51, 70, 30, 109, 53, 49, 94, 88, 75, 66, 122, 91, 73, 56, 42, 64, 44, 21, 25, 90, 43, 41, 77, 73, 63, 56, 92, 77, 66, 47, 67, 48, 53, 36, 20, 71, 34, 67, 60, 58, 49, 88, 76, 67, 106, 71, 54, 38, 39, 23, 15, 109, 53, 51, 47, 90, 82, 58, 57, 48, 72, 57, 41, 23, 27, 62, 9, 86, 42, 40, 37, 70, 64, 52, 43, 70, 55, 42, 25, 29, 18, 11, 11, 118, 68, 30, 55, 50, 46, 74, 65, 49, 39, 24, 16, 22, 13, 14, 7, 91, 44, 39, 38, 34, 63, 52, 45, 31, 52, 28, 19, 14, 8, 9, 3, 123, 60, 58, 53, 47, 43, 32, 22, 37, 24, 17, 12, 15, 10, 2, 1, 71, 37, 34, 30, 28, 20, 17, 26, 21, 16, 10, 6, 8, 6, 2, 0], F.t16HB = [1, 5, 14, 44, 74, 63, 110, 93, 172, 149, 138, 242, 225, 195, 376, 17, 3, 4, 12, 20, 35, 62, 53, 47, 83, 75, 68, 119, 201, 107, 207, 9, 15, 13, 23, 38, 67, 58, 103, 90, 161, 72, 127, 117, 110, 209, 206, 16, 45, 21, 39, 69, 64, 114, 99, 87, 158, 140, 252, 212, 199, 387, 365, 26, 75, 36, 68, 65, 115, 101, 179, 164, 155, 264, 246, 226, 395, 382, 362, 9, 66, 30, 59, 56, 102, 185, 173, 265, 142, 253, 232, 400, 388, 378, 445, 16, 111, 54, 52, 100, 184, 178, 160, 133, 257, 244, 228, 217, 385, 366, 715, 10, 98, 48, 91, 88, 165, 157, 148, 261, 248, 407, 397, 372, 380, 889, 884, 8, 85, 84, 81, 159, 156, 143, 260, 249, 427, 401, 392, 383, 727, 713, 708, 7, 154, 76, 73, 141, 131, 256, 245, 426, 406, 394, 384, 735, 359, 710, 352, 11, 139, 129, 67, 125, 247, 233, 229, 219, 393, 743, 737, 720, 885, 882, 439, 4, 243, 120, 118, 115, 227, 223, 396, 746, 742, 736, 721, 712, 706, 223, 436, 6, 202, 224, 222, 218, 216, 389, 386, 381, 364, 888, 443, 707, 440, 437, 1728, 4, 747, 211, 210, 208, 370, 379, 734, 723, 714, 1735, 883, 877, 876, 3459, 865, 2, 377, 369, 102, 187, 726, 722, 358, 711, 709, 866, 1734, 871, 3458, 870, 434, 0, 12, 10, 7, 11, 10, 17, 11, 9, 13, 12, 10, 7, 5, 3, 1, 3], F.t24HB = [15, 13, 46, 80, 146, 262, 248, 434, 426, 669, 653, 649, 621, 517, 1032, 88, 14, 12, 21, 38, 71, 130, 122, 216, 209, 198, 327, 345, 319, 297, 279, 42, 47, 22, 41, 74, 68, 128, 120, 221, 207, 194, 182, 340, 315, 295, 541, 18, 81, 39, 75, 70, 134, 125, 116, 220, 204, 190, 178, 325, 311, 293, 271, 16, 147, 72, 69, 135, 127, 118, 112, 210, 200, 188, 352, 323, 306, 285, 540, 14, 263, 66, 129, 126, 119, 114, 214, 202, 192, 180, 341, 317, 301, 281, 262, 12, 249, 123, 121, 117, 113, 215, 206, 195, 185, 347, 330, 308, 291, 272, 520, 10, 435, 115, 111, 109, 211, 203, 196, 187, 353, 332, 313, 298, 283, 531, 381, 17, 427, 212, 208, 205, 201, 193, 186, 177, 169, 320, 303, 286, 268, 514, 377, 16, 335, 199, 197, 191, 189, 181, 174, 333, 321, 305, 289, 275, 521, 379, 371, 11, 668, 184, 183, 179, 175, 344, 331, 314, 304, 290, 277, 530, 383, 373, 366, 10, 652, 346, 171, 168, 164, 318, 309, 299, 287, 276, 263, 513, 375, 368, 362, 6, 648, 322, 316, 312, 307, 302, 292, 284, 269, 261, 512, 376, 370, 364, 359, 4, 620, 300, 296, 294, 288, 282, 273, 266, 515, 380, 374, 369, 365, 361, 357, 2, 1033, 280, 278, 274, 267, 264, 259, 382, 378, 372, 367, 363, 360, 358, 356, 0, 43, 20, 19, 17, 15, 13, 11, 9, 7, 6, 4, 7, 5, 3, 1, 3], F.t32HB = [1, 10, 8, 20, 12, 20, 16, 32, 14, 12, 24, 0, 28, 16, 24, 16], F.t33HB = [15, 28, 26, 48, 22, 40, 36, 64, 14, 24, 20, 32, 12, 16, 8, 0], F.t1l = [1, 4, 3, 5], F.t2l = [1, 4, 7, 4, 5, 7, 6, 7, 8], F.t3l = [2, 3, 7, 4, 4, 7, 6, 7, 8], F.t5l = [1, 4, 7, 8, 4, 5, 8, 9, 7, 8, 9, 10, 8, 8, 9, 10], F.t6l = [3, 4, 6, 8, 4, 4, 6, 7, 5, 6, 7, 8, 7, 7, 8, 9], F.t7l = [1, 4, 7, 9, 9, 10, 4, 6, 8, 9, 9, 10, 7, 7, 9, 10, 10, 11, 8, 9, 10, 11, 11, 11, 8, 9, 10, 11, 11, 12, 9, 10, 11, 12, 12, 12], F.t8l = [2, 4, 7, 9, 9, 10, 4, 4, 6, 10, 10, 10, 7, 6, 8, 10, 10, 11, 9, 10, 10, 11, 11, 12, 9, 9, 10, 11, 12, 12, 10, 10, 11, 11, 13, 13], F.t9l = [3, 4, 6, 7, 9, 10, 4, 5, 6, 7, 8, 10, 5, 6, 7, 8, 9, 10, 7, 7, 8, 9, 9, 10, 8, 8, 9, 9, 10, 11, 9, 9, 10, 10, 11, 11], F.t10l = [1, 4, 7, 9, 10, 10, 10, 11, 4, 6, 8, 9, 10, 11, 10, 10, 7, 8, 9, 10, 11, 12, 11, 11, 8, 9, 10, 11, 12, 12, 11, 12, 9, 10, 11, 12, 12, 12, 12, 12, 10, 11, 12, 12, 13, 13, 12, 13, 9, 10, 11, 12, 12, 12, 13, 13, 10, 10, 11, 12, 12, 13, 13, 13], F.t11l = [2, 4, 6, 8, 9, 10, 9, 10, 4, 5, 6, 8, 10, 10, 9, 10, 6, 7, 8, 9, 10, 11, 10, 10, 8, 8, 9, 11, 10, 12, 10, 11, 9, 10, 10, 11, 11, 12, 11, 12, 9, 10, 11, 12, 12, 13, 12, 13, 9, 9, 9, 10, 11, 12, 12, 12, 9, 9, 10, 11, 12, 12, 12, 12], F.t12l = [4, 4, 6, 8, 9, 10, 10, 10, 4, 5, 6, 7, 9, 9, 10, 10, 6, 6, 7, 8, 9, 10, 9, 10, 7, 7, 8, 8, 9, 10, 10, 10, 8, 8, 9, 9, 10, 10, 10, 11, 9, 9, 10, 10, 10, 11, 10, 11, 9, 9, 9, 10, 10, 11, 11, 12, 10, 10, 10, 11, 11, 11, 11, 12], F.t13l = [1, 5, 7, 8, 9, 10, 10, 11, 10, 11, 12, 12, 13, 13, 14, 14, 4, 6, 8, 9, 10, 10, 11, 11, 11, 11, 12, 12, 13, 14, 14, 14, 7, 8, 9, 10, 11, 11, 12, 12, 11, 12, 12, 13, 13, 14, 15, 15, 8, 9, 10, 11, 11, 12, 12, 12, 12, 13, 13, 13, 13, 14, 15, 15, 9, 9, 11, 11, 12, 12, 13, 13, 12, 13, 13, 14, 14, 15, 15, 16, 10, 10, 11, 12, 12, 12, 13, 13, 13, 13, 14, 13, 15, 15, 16, 16, 10, 11, 12, 12, 13, 13, 13, 13, 13, 14, 14, 14, 15, 15, 16, 16, 11, 11, 12, 13, 13, 13, 14, 14, 14, 14, 15, 15, 15, 16, 18, 18, 10, 10, 11, 12, 12, 13, 13, 14, 14, 14, 14, 15, 15, 16, 17, 17, 11, 11, 12, 12, 13, 13, 13, 15, 14, 15, 15, 16, 16, 16, 18, 17, 11, 12, 12, 13, 13, 14, 14, 15, 14, 15, 16, 15, 16, 17, 18, 19, 12, 12, 12, 13, 14, 14, 14, 14, 15, 15, 15, 16, 17, 17, 17, 18, 12, 13, 13, 14, 14, 15, 14, 15, 16, 16, 17, 17, 17, 18, 18, 18, 13, 13, 14, 15, 15, 15, 16, 16, 16, 16, 16, 17, 18, 17, 18, 18, 14, 14, 14, 15, 15, 15, 17, 16, 16, 19, 17, 17, 17, 19, 18, 18, 13, 14, 15, 16, 16, 16, 17, 16, 17, 17, 18, 18, 21, 20, 21, 18], F.t15l = [3, 5, 6, 8, 8, 9, 10, 10, 10, 11, 11, 12, 12, 12, 13, 14, 5, 5, 7, 8, 9, 9, 10, 10, 10, 11, 11, 12, 12, 12, 13, 13, 6, 7, 7, 8, 9, 9, 10, 10, 10, 11, 11, 12, 12, 13, 13, 13, 7, 8, 8, 9, 9, 10, 10, 11, 11, 11, 12, 12, 12, 13, 13, 13, 8, 8, 9, 9, 10, 10, 11, 11, 11, 11, 12, 12, 12, 13, 13, 13, 9, 9, 9, 10, 10, 10, 11, 11, 11, 11, 12, 12, 13, 13, 13, 14, 10, 9, 10, 10, 10, 11, 11, 11, 11, 12, 12, 12, 13, 13, 14, 14, 10, 10, 10, 11, 11, 11, 11, 12, 12, 12, 12, 12, 13, 13, 13, 14, 10, 10, 10, 11, 11, 11, 11, 12, 12, 12, 12, 13, 13, 14, 14, 14, 10, 10, 11, 11, 11, 11, 12, 12, 12, 13, 13, 13, 13, 14, 14, 14, 11, 11, 11, 11, 12, 12, 12, 12, 12, 13, 13, 13, 13, 14, 15, 14, 11, 11, 11, 11, 12, 12, 12, 12, 13, 13, 13, 13, 14, 14, 14, 15, 12, 12, 11, 12, 12, 12, 13, 13, 13, 13, 13, 13, 14, 14, 15, 15, 12, 12, 12, 12, 12, 13, 13, 13, 13, 14, 14, 14, 14, 14, 15, 15, 13, 13, 13, 13, 13, 13, 13, 13, 14, 14, 14, 14, 15, 15, 14, 15, 13, 13, 13, 13, 13, 13, 13, 14, 14, 14, 14, 14, 15, 15, 15, 15], F.t16_5l = [1, 5, 7, 9, 10, 10, 11, 11, 12, 12, 12, 13, 13, 13, 14, 11, 4, 6, 8, 9, 10, 11, 11, 11, 12, 12, 12, 13, 14, 13, 14, 11, 7, 8, 9, 10, 11, 11, 12, 12, 13, 12, 13, 13, 13, 14, 14, 12, 9, 9, 10, 11, 11, 12, 12, 12, 13, 13, 14, 14, 14, 15, 15, 13, 10, 10, 11, 11, 12, 12, 13, 13, 13, 14, 14, 14, 15, 15, 15, 12, 10, 10, 11, 11, 12, 13, 13, 14, 13, 14, 14, 15, 15, 15, 16, 13, 11, 11, 11, 12, 13, 13, 13, 13, 14, 14, 14, 14, 15, 15, 16, 13, 11, 11, 12, 12, 13, 13, 13, 14, 14, 15, 15, 15, 15, 17, 17, 13, 11, 12, 12, 13, 13, 13, 14, 14, 15, 15, 15, 15, 16, 16, 16, 13, 12, 12, 12, 13, 13, 14, 14, 15, 15, 15, 15, 16, 15, 16, 15, 14, 12, 13, 12, 13, 14, 14, 14, 14, 15, 16, 16, 16, 17, 17, 16, 13, 13, 13, 13, 13, 14, 14, 15, 16, 16, 16, 16, 16, 16, 15, 16, 14, 13, 14, 14, 14, 14, 15, 15, 15, 15, 17, 16, 16, 16, 16, 18, 14, 15, 14, 14, 14, 15, 15, 16, 16, 16, 18, 17, 17, 17, 19, 17, 14, 14, 15, 13, 14, 16, 16, 15, 16, 16, 17, 18, 17, 19, 17, 16, 14, 11, 11, 11, 12, 12, 13, 13, 13, 14, 14, 14, 14, 14, 14, 14, 12], F.t16l = [1, 5, 7, 9, 10, 10, 11, 11, 12, 12, 12, 13, 13, 13, 14, 10, 4, 6, 8, 9, 10, 11, 11, 11, 12, 12, 12, 13, 14, 13, 14, 10, 7, 8, 9, 10, 11, 11, 12, 12, 13, 12, 13, 13, 13, 14, 14, 11, 9, 9, 10, 11, 11, 12, 12, 12, 13, 13, 14, 14, 14, 15, 15, 12, 10, 10, 11, 11, 12, 12, 13, 13, 13, 14, 14, 14, 15, 15, 15, 11, 10, 10, 11, 11, 12, 13, 13, 14, 13, 14, 14, 15, 15, 15, 16, 12, 11, 11, 11, 12, 13, 13, 13, 13, 14, 14, 14, 14, 15, 15, 16, 12, 11, 11, 12, 12, 13, 13, 13, 14, 14, 15, 15, 15, 15, 17, 17, 12, 11, 12, 12, 13, 13, 13, 14, 14, 15, 15, 15, 15, 16, 16, 16, 12, 12, 12, 12, 13, 13, 14, 14, 15, 15, 15, 15, 16, 15, 16, 15, 13, 12, 13, 12, 13, 14, 14, 14, 14, 15, 16, 16, 16, 17, 17, 16, 12, 13, 13, 13, 13, 14, 14, 15, 16, 16, 16, 16, 16, 16, 15, 16, 13, 13, 14, 14, 14, 14, 15, 15, 15, 15, 17, 16, 16, 16, 16, 18, 13, 15, 14, 14, 14, 15, 15, 16, 16, 16, 18, 17, 17, 17, 19, 17, 13, 14, 15, 13, 14, 16, 16, 15, 16, 16, 17, 18, 17, 19, 17, 16, 13, 10, 10, 10, 11, 11, 12, 12, 12, 13, 13, 13, 13, 13, 13, 13, 10], F.t24l = [4, 5, 7, 8, 9, 10, 10, 11, 11, 12, 12, 12, 12, 12, 13, 10, 5, 6, 7, 8, 9, 10, 10, 11, 11, 11, 12, 12, 12, 12, 12, 10, 7, 7, 8, 9, 9, 10, 10, 11, 11, 11, 11, 12, 12, 12, 13, 9, 8, 8, 9, 9, 10, 10, 10, 11, 11, 11, 11, 12, 12, 12, 12, 9, 9, 9, 9, 10, 10, 10, 10, 11, 11, 11, 12, 12, 12, 12, 13, 9, 10, 9, 10, 10, 10, 10, 11, 11, 11, 11, 12, 12, 12, 12, 12, 9, 10, 10, 10, 10, 10, 11, 11, 11, 11, 12, 12, 12, 12, 12, 13, 9, 11, 10, 10, 10, 11, 11, 11, 11, 12, 12, 12, 12, 12, 13, 13, 10, 11, 11, 11, 11, 11, 11, 11, 11, 11, 12, 12, 12, 12, 13, 13, 10, 11, 11, 11, 11, 11, 11, 11, 12, 12, 12, 12, 12, 13, 13, 13, 10, 12, 11, 11, 11, 11, 12, 12, 12, 12, 12, 12, 13, 13, 13, 13, 10, 12, 12, 11, 11, 11, 12, 12, 12, 12, 12, 12, 13, 13, 13, 13, 10, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 13, 13, 13, 13, 13, 10, 12, 12, 12, 12, 12, 12, 12, 12, 13, 13, 13, 13, 13, 13, 13, 10, 13, 12, 12, 12, 12, 12, 12, 13, 13, 13, 13, 13, 13, 13, 13, 10, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 10, 10, 10, 10, 6], F.t32l = [1, 5, 5, 7, 5, 8, 7, 9, 5, 7, 7, 9, 7, 9, 9, 10], F.t33l = [4, 5, 5, 6, 5, 6, 6, 7, 5, 6, 6, 7, 6, 7, 7, 8], F.ht = [new e(0, 0, null, null), new e(2, 0, F.t1HB, F.t1l), new e(3, 0, F.t2HB, F.t2l), new e(3, 0, F.t3HB, F.t3l), new e(0, 0, null, null), new e(4, 0, F.t5HB, F.t5l), new e(4, 0, F.t6HB, F.t6l), new e(6, 0, F.t7HB, F.t7l), new e(6, 0, F.t8HB, F.t8l), new e(6, 0, F.t9HB, F.t9l), new e(8, 0, F.t10HB, F.t10l), new e(8, 0, F.t11HB, F.t11l), new e(8, 0, F.t12HB, F.t12l), new e(16, 0, F.t13HB, F.t13l), new e(0, 0, null, F.t16_5l), new e(16, 0, F.t15HB, F.t15l), new e(1, 1, F.t16HB, F.t16l), new e(2, 3, F.t16HB, F.t16l), new e(3, 7, F.t16HB, F.t16l), new e(4, 15, F.t16HB, F.t16l), new e(6, 63, F.t16HB, F.t16l), new e(8, 255, F.t16HB, F.t16l), new e(10, 1023, F.t16HB, F.t16l), new e(13, 8191, F.t16HB, F.t16l), new e(4, 15, F.t24HB, F.t24l), new e(5, 31, F.t24HB, F.t24l), new e(6, 63, F.t24HB, F.t24l), new e(7, 127, F.t24HB, F.t24l), new e(8, 255, F.t24HB, F.t24l), new e(9, 511, F.t24HB, F.t24l), new e(11, 2047, F.t24HB, F.t24l), new e(13, 8191, F.t24HB, F.t24l), new e(0, 0, F.t32HB, F.t32l), new e(0, 0, F.t33HB, F.t33l)], F.largetbl = [65540, 327685, 458759, 589832, 655369, 655370, 720906, 720907, 786443, 786444, 786444, 851980, 851980, 851980, 917517, 655370, 262149, 393222, 524295, 589832, 655369, 720906, 720906, 720907, 786443, 786443, 786444, 851980, 917516, 851980, 917516, 655370, 458759, 524295, 589832, 655369, 720905, 720906, 786442, 786443, 851979, 786443, 851979, 851980, 851980, 917516, 917517, 720905, 589832, 589832, 655369, 720905, 720906, 786442, 786442, 786443, 851979, 851979, 917515, 917516, 917516, 983052, 983052, 786441, 655369, 655369, 720905, 720906, 786442, 786442, 851978, 851979, 851979, 917515, 917516, 917516, 983052, 983052, 983053, 720905, 655370, 655369, 720906, 720906, 786442, 851978, 851979, 917515, 851979, 917515, 917516, 983052, 983052, 983052, 1048588, 786441, 720906, 720906, 720906, 786442, 851978, 851979, 851979, 851979, 917515, 917516, 917516, 917516, 983052, 983052, 1048589, 786441, 720907, 720906, 786442, 786442, 851979, 851979, 851979, 917515, 917516, 983052, 983052, 983052, 983052, 1114125, 1114125, 786442, 720907, 786443, 786443, 851979, 851979, 851979, 917515, 917515, 983051, 983052, 983052, 983052, 1048588, 1048589, 1048589, 786442, 786443, 786443, 786443, 851979, 851979, 917515, 917515, 983052, 983052, 983052, 983052, 1048588, 983053, 1048589, 983053, 851978, 786444, 851979, 786443, 851979, 917515, 917516, 917516, 917516, 983052, 1048588, 1048588, 1048589, 1114125, 1114125, 1048589, 786442, 851980, 851980, 851979, 851979, 917515, 917516, 983052, 1048588, 1048588, 1048588, 1048588, 1048589, 1048589, 983053, 1048589, 851978, 851980, 917516, 917516, 917516, 917516, 983052, 983052, 983052, 983052, 1114124, 1048589, 1048589, 1048589, 1048589, 1179661, 851978, 983052, 917516, 917516, 917516, 983052, 983052, 1048588, 1048588, 1048589, 1179661, 1114125, 1114125, 1114125, 1245197, 1114125, 851978, 917517, 983052, 851980, 917516, 1048588, 1048588, 983052, 1048589, 1048589, 1114125, 1179661, 1114125, 1245197, 1114125, 1048589, 851978, 655369, 655369, 655369, 720905, 720905, 786441, 786441, 786441, 851977, 851977, 851977, 851978, 851978, 851978, 851978, 655366], F.table23 = [65538, 262147, 458759, 262148, 327684, 458759, 393222, 458759, 524296], F.table56 = [65539, 262148, 458758, 524296, 262148, 327684, 524294, 589831, 458757, 524294, 589831, 655368, 524295, 524295, 589832, 655369], F.bitrate_table = [[0, 8, 16, 24, 32, 40, 48, 56, 64, 80, 96, 112, 128, 144, 160, -1], [0, 32, 40, 48, 56, 64, 80, 96, 112, 128, 160, 192, 224, 256, 320, -1], [0, 8, 16, 24, 32, 40, 48, 56, 64, -1, -1, -1, -1, -1, -1, -1]], F.samplerate_table = [[22050, 24e3, 16e3, -1], [44100, 48e3, 32e3, -1], [11025, 12e3, 8e3, -1]], F.scfsi_band = [0, 6, 11, 16, 21], x.Q_MAX = 257, x.Q_MAX2 = 116, x.LARGE_BITS = 1e5, x.IXMAX_VAL = 8206;
+ var z = {};
+ function w() {
+ var v, g, M;
this.rv = null, this.qupvt = null;
var w,
- s = new function () {
+ n = new function () {
this.setModules = function (e, t) {};
}();
- function S(e) {
+ function R(e) {
this.ordinal = e;
}
function o(e) {
for (var t = 0; t < e.sfbmax; t++) if (e.scalefac[t] + e.subblock_gain[e.window[t]] == 0) return !1;
return !0;
}
- function M(e, t, a, n, s) {
+ function A(e, t, a, s, n) {
var r;
switch (e) {
default:
@@ -35912,10 +35614,13 @@ src: recorder-core.js,engine/mp3.js,engine/mp3-engine.js
0 < t.over_count ? (r = a.over_SSD <= t.over_SSD, a.over_SSD == t.over_SSD && (r = a.bits < t.bits)) : r = a.max_noise < 0 && 10 * a.max_noise + a.bits <= 10 * t.max_noise + t.bits;
break;
case 0:
- r = a.over_count < t.over_count || a.over_count == t.over_count && a.over_noise < t.over_noise || a.over_count == t.over_count && N.EQ(a.over_noise, t.over_noise) && a.tot_noise < t.tot_noise;
+ r = a.over_count < t.over_count || a.over_count == t.over_count && a.over_noise < t.over_noise || a.over_count == t.over_count && q.EQ(a.over_noise, t.over_noise) && a.tot_noise < t.tot_noise;
break;
case 8:
- me();
+ a.max_noise = function (e, t) {
+ for (var a, s = 1e-37, n = 0; n < t.psymax; n++) s += (a = e[n], ee.FAST_LOG10(.368 + .632 * a * a * a));
+ return Math.max(1e-20, s);
+ }(n, s);
case 1:
r = a.max_noise < t.max_noise;
break;
@@ -35929,25 +35634,25 @@ src: recorder-core.js,engine/mp3.js,engine/mp3-engine.js
r = a.max_noise <= 0 && .2 < t.max_noise || a.max_noise <= 0 && t.max_noise < 0 && t.max_noise > a.max_noise - .2 && a.tot_noise < t.tot_noise || a.max_noise <= 0 && 0 < t.max_noise && t.max_noise > a.max_noise - .2 && a.tot_noise < t.tot_noise + t.over_noise || 0 < a.max_noise && -.05 < t.max_noise && t.max_noise > a.max_noise - .1 && a.tot_noise + a.over_noise < t.tot_noise + t.over_noise || 0 < a.max_noise && -.1 < t.max_noise && t.max_noise > a.max_noise - .15 && a.tot_noise + a.over_noise + a.over_noise < t.tot_noise + t.over_noise + t.over_noise;
break;
case 5:
- r = a.over_noise < t.over_noise || N.EQ(a.over_noise, t.over_noise) && a.tot_noise < t.tot_noise;
+ r = a.over_noise < t.over_noise || q.EQ(a.over_noise, t.over_noise) && a.tot_noise < t.tot_noise;
break;
case 6:
- r = a.over_noise < t.over_noise || N.EQ(a.over_noise, t.over_noise) && (a.max_noise < t.max_noise || N.EQ(a.max_noise, t.max_noise) && a.tot_noise <= t.tot_noise);
+ r = a.over_noise < t.over_noise || q.EQ(a.over_noise, t.over_noise) && (a.max_noise < t.max_noise || q.EQ(a.max_noise, t.max_noise) && a.tot_noise <= t.tot_noise);
break;
case 7:
r = a.over_count < t.over_count || a.over_noise < t.over_noise;
}
return 0 == t.over_count && (r = r && a.bits < t.bits), r;
}
- function y(e, t, a, n, s) {
+ function B(e, t, a, s, n) {
var r = e.internal_flags;
- !function (e, t, a, n, s) {
+ !function (e, t, a, s, n) {
var r,
i = e.internal_flags;
r = 0 == t.scalefac_scale ? 1.2968395546510096 : 1.6817928305074292;
for (var o = 0, _ = 0; _ < t.sfbmax; _++) o < a[_] && (o = a[_]);
var l = i.noise_shaping_amp;
- switch (3 == l && me(), l) {
+ switch (3 == l && (l = n ? 2 : 1), l) {
case 2:
break;
case 1:
@@ -35957,536 +35662,734 @@ src: recorder-core.js,engine/mp3.js,engine/mp3-engine.js
default:
1 < o ? o = 1 : o *= .95;
}
- for (var f = 0, _ = 0; _ < t.sfbmax; _++) {
+ var f = 0;
+ for (_ = 0; _ < t.sfbmax; _++) {
var c,
- u = t.width[_];
- if (f += u, !(a[_] < o)) {
- for (0 != (2 & i.substep_shaping) && me(), t.scalefac[_]++, c = -u; c < 0; c++) n[f + c] *= r, n[f + c] > t.xrpow_max && (t.xrpow_max = n[f + c]);
+ h = t.width[_];
+ if (f += h, !(a[_] < o)) {
+ if (0 != (2 & i.substep_shaping) && (i.pseudohalf[_] = 0 == i.pseudohalf[_] ? 1 : 0, 0 == i.pseudohalf[_] && 2 == i.noise_shaping_amp)) return;
+ for (t.scalefac[_]++, c = -h; c < 0; c++) s[f + c] *= r, s[f + c] > t.xrpow_max && (t.xrpow_max = s[f + c]);
if (2 == i.noise_shaping_amp) return;
}
}
- }(e, t, a, n);
+ }(e, t, a, s, n);
var i = o(t);
- return !(i || (i = 2 == r.mode_gr ? w.scale_bitcount(t) : w.scale_bitcount_lsf(r, t)) && (1 < r.noise_shaping && (we.fill(r.pseudohalf, 0), 0 == t.scalefac_scale ? (function (e, t) {
- for (var a = 0, n = 0; n < e.sfbmax; n++) {
- var s = e.width[n],
- r = e.scalefac[n];
- if (0 != e.preflag && (r += g.pretab[n]), a += s, 0 != (1 & r)) {
+ return !i && (!(i = 2 == r.mode_gr ? w.scale_bitcount(t) : w.scale_bitcount_lsf(r, t)) || (1 < r.noise_shaping && (ye.fill(r.pseudohalf, 0), 0 == t.scalefac_scale ? (!function (e, t) {
+ for (var a = 0, s = 0; s < e.sfbmax; s++) {
+ var n = e.width[s],
+ r = e.scalefac[s];
+ if (0 != e.preflag && (r += M.pretab[s]), a += n, 0 != (1 & r)) {
r++;
- for (var i = -s; i < 0; i++) t[a + i] *= 1.2968395546510096, t[a + i] > e.xrpow_max && (e.xrpow_max = t[a + i]);
+ for (var i = -n; i < 0; i++) t[a + i] *= 1.2968395546510096, t[a + i] > e.xrpow_max && (e.xrpow_max = t[a + i]);
}
- e.scalefac[n] = r >> 1;
+ e.scalefac[s] = r >> 1;
}
e.preflag = 0, e.scalefac_scale = 1;
- }(t, n), i = !1) : t.block_type == Ae.SHORT_TYPE && 0 < r.subblock_gain && (i = function (e, t, a) {
- var n,
- s = t.scalefac;
- for (n = 0; n < t.sfb_lmax; n++) if (16 <= s[n]) return !0;
+ }(t, s), i = !1) : t.block_type == Pe.SHORT_TYPE && 0 < r.subblock_gain && (i = function (e, t, a) {
+ var s,
+ n = t.scalefac;
+ for (s = 0; s < t.sfb_lmax; s++) if (16 <= n[s]) return !0;
for (var r = 0; r < 3; r++) {
var i = 0,
o = 0;
- for (n = t.sfb_lmax + r; n < t.sfbdivide; n += 3) i < s[n] && (i = s[n]);
- for (; n < t.sfbmax; n += 3) o < s[n] && (o = s[n]);
+ for (s = t.sfb_lmax + r; s < t.sfbdivide; s += 3) i < n[s] && (i = n[s]);
+ for (; s < t.sfbmax; s += 3) o < n[s] && (o = n[s]);
if (!(i < 16 && o < 8)) {
if (7 <= t.subblock_gain[r]) return !0;
t.subblock_gain[r]++;
var _ = e.scalefac_band.l[t.sfb_lmax];
- for (n = t.sfb_lmax + r; n < t.sfbmax; n += 3) {
- var l = t.width[n],
- f = s[n];
- if (0 <= (f -= 4 >> t.scalefac_scale)) s[n] = f, _ += 3 * l;else {
- s[n] = 0;
+ for (s = t.sfb_lmax + r; s < t.sfbmax; s += 3) {
+ var l = t.width[s],
+ f = n[s];
+ if (0 <= (f -= 4 >> t.scalefac_scale)) n[s] = f, _ += 3 * l;else {
+ n[s] = 0;
var c = 210 + (f << t.scalefac_scale + 1);
- h = g.IPOW20(c), _ += l * (r + 1);
- for (var u = -l; u < 0; u++) a[_ + u] *= h, a[_ + u] > t.xrpow_max && (t.xrpow_max = a[_ + u]);
+ u = M.IPOW20(c), _ += l * (r + 1);
+ for (var h = -l; h < 0; h++) a[_ + h] *= u, a[_ + h] > t.xrpow_max && (t.xrpow_max = a[_ + h]);
_ += l * (3 - r - 1);
}
}
- var h = g.IPOW20(202);
- _ += t.width[n] * (r + 1);
- for (var u = -t.width[n]; u < 0; u++) a[_ + u] *= h, a[_ + u] > t.xrpow_max && (t.xrpow_max = a[_ + u]);
+ var u = M.IPOW20(202);
+ for (_ += t.width[s] * (r + 1), h = -t.width[s]; h < 0; h++) a[_ + h] *= u, a[_ + h] > t.xrpow_max && (t.xrpow_max = a[_ + h]);
}
}
return !1;
- }(r, t, n) || o(t))), i || (i = 2 == r.mode_gr ? w.scale_bitcount(t) : w.scale_bitcount_lsf(r, t)), i));
+ }(r, t, s) || o(t))), i || (i = 2 == r.mode_gr ? w.scale_bitcount(t) : w.scale_bitcount_lsf(r, t)), !i));
}
- this.setModules = function (e, t, a, n) {
- r = t, this.rv = t, g = a, this.qupvt = a, w = n, s.setModules(g, w);
+ this.setModules = function (e, t, a, s) {
+ v = e, g = t, this.rv = t, M = a, this.qupvt = a, w = s, n.setModules(M, w);
+ }, this.ms_convert = function (e, t) {
+ for (var a = 0; a < 576; ++a) {
+ var s = e.tt[t][0].xr[a],
+ n = e.tt[t][1].xr[a];
+ e.tt[t][0].xr[a] = (s + n) * (.5 * ee.SQRT2), e.tt[t][1].xr[a] = (s - n) * (.5 * ee.SQRT2);
+ }
}, this.init_xrpow = function (e, t, a) {
- var n = 0,
- s = 0 | t.max_nonzero_coeff;
- if (t.xrpow_max = 0, we.fill(a, s, 576, 0), 1e-20 < (n = function (e, t, a, n) {
- for (var s = n = 0; s <= a; ++s) {
- var r = Math.abs(e.xr[s]);
- n += r, t[s] = Math.sqrt(r * Math.sqrt(r)), t[s] > e.xrpow_max && (e.xrpow_max = t[s]);
+ var s = 0,
+ n = 0 | t.max_nonzero_coeff;
+ if (t.xrpow_max = 0, ye.fill(a, n, 576, 0), 1e-20 < (s = function (e, t, a, s) {
+ for (var n = s = 0; n <= a; ++n) {
+ var r = Math.abs(e.xr[n]);
+ s += r, t[n] = Math.sqrt(r * Math.sqrt(r)), t[n] > e.xrpow_max && (e.xrpow_max = t[n]);
}
- return n;
- }(t, a, s, n))) {
+ return s;
+ }(t, a, n, s))) {
var r = 0;
0 != (2 & e.substep_shaping) && (r = 1);
for (var i = 0; i < t.psymax; i++) e.pseudohalf[i] = r;
return !0;
}
- return we.fill(t.l3_enc, 0, 576, 0), !1;
+ return ye.fill(t.l3_enc, 0, 576, 0), !1;
}, this.init_outer_loop = function (e, t) {
- t.part2_3_length = 0, t.big_values = 0, t.count1 = 0, t.global_gain = 210, t.scalefac_compress = 0, t.table_select[0] = 0, t.table_select[1] = 0, t.table_select[2] = 0, t.subblock_gain[0] = 0, t.subblock_gain[1] = 0, t.subblock_gain[2] = 0, t.subblock_gain[3] = 0, t.region0_count = 0, t.region1_count = 0, t.preflag = 0, t.scalefac_scale = 0, t.count1table_select = 0, t.part2_length = 0, t.sfb_lmax = Ae.SBPSY_l, t.sfb_smin = Ae.SBPSY_s, t.psy_lmax = e.sfb21_extra ? Ae.SBMAX_l : Ae.SBPSY_l, t.psymax = t.psy_lmax, t.sfbmax = t.sfb_lmax, t.sfbdivide = 11;
- for (var a = 0; a < Ae.SBMAX_l; a++) t.width[a] = e.scalefac_band.l[a + 1] - e.scalefac_band.l[a], t.window[a] = 3;
- if (t.block_type == Ae.SHORT_TYPE) {
- var n = de(576);
- t.sfb_smin = 0, (t.sfb_lmax = 0) != t.mixed_block_flag && me(), t.psymax = t.sfb_lmax + 3 * ((e.sfb21_extra ? Ae.SBMAX_s : Ae.SBPSY_s) - t.sfb_smin), t.sfbmax = t.sfb_lmax + 3 * (Ae.SBPSY_s - t.sfb_smin), t.sfbdivide = t.sfbmax - 18, t.psy_lmax = t.sfb_lmax;
- var s = e.scalefac_band.l[t.sfb_lmax];
- I.arraycopy(t.xr, 0, n, 0, 576);
- for (var a = t.sfb_smin; a < Ae.SBMAX_s; a++) for (var r = e.scalefac_band.s[a], i = e.scalefac_band.s[a + 1], o = 0; o < 3; o++) for (var _ = r; _ < i; _++) t.xr[s++] = n[3 * _ + o];
- for (var l = t.sfb_lmax, a = t.sfb_smin; a < Ae.SBMAX_s; a++) t.width[l] = t.width[l + 1] = t.width[l + 2] = e.scalefac_band.s[a + 1] - e.scalefac_band.s[a], t.window[l] = 0, t.window[l + 1] = 1, t.window[l + 2] = 2, l += 3;
+ t.part2_3_length = 0, t.big_values = 0, t.count1 = 0, t.global_gain = 210, t.scalefac_compress = 0, t.table_select[0] = 0, t.table_select[1] = 0, t.table_select[2] = 0, t.subblock_gain[0] = 0, t.subblock_gain[1] = 0, t.subblock_gain[2] = 0, t.subblock_gain[3] = 0, t.region0_count = 0, t.region1_count = 0, t.preflag = 0, t.scalefac_scale = 0, t.count1table_select = 0, t.part2_length = 0, t.sfb_lmax = Pe.SBPSY_l, t.sfb_smin = Pe.SBPSY_s, t.psy_lmax = e.sfb21_extra ? Pe.SBMAX_l : Pe.SBPSY_l, t.psymax = t.psy_lmax, t.sfbmax = t.sfb_lmax, t.sfbdivide = 11;
+ for (var a = 0; a < Pe.SBMAX_l; a++) t.width[a] = e.scalefac_band.l[a + 1] - e.scalefac_band.l[a], t.window[a] = 3;
+ if (t.block_type == Pe.SHORT_TYPE) {
+ var s = Be(576);
+ t.sfb_smin = 0, (t.sfb_lmax = 0) != t.mixed_block_flag && (t.sfb_smin = 3, t.sfb_lmax = 2 * e.mode_gr + 4), t.psymax = t.sfb_lmax + 3 * ((e.sfb21_extra ? Pe.SBMAX_s : Pe.SBPSY_s) - t.sfb_smin), t.sfbmax = t.sfb_lmax + 3 * (Pe.SBPSY_s - t.sfb_smin), t.sfbdivide = t.sfbmax - 18, t.psy_lmax = t.sfb_lmax;
+ var n = e.scalefac_band.l[t.sfb_lmax];
+ $.arraycopy(t.xr, 0, s, 0, 576);
+ for (a = t.sfb_smin; a < Pe.SBMAX_s; a++) for (var r = e.scalefac_band.s[a], i = e.scalefac_band.s[a + 1], o = 0; o < 3; o++) for (var _ = r; _ < i; _++) t.xr[n++] = s[3 * _ + o];
+ var l = t.sfb_lmax;
+ for (a = t.sfb_smin; a < Pe.SBMAX_s; a++) t.width[l] = t.width[l + 1] = t.width[l + 2] = e.scalefac_band.s[a + 1] - e.scalefac_band.s[a], t.window[l] = 0, t.window[l + 1] = 1, t.window[l + 2] = 2, l += 3;
}
- t.count1bits = 0, t.sfb_partition_table = g.nr_of_sfb_block[0][0], t.slen[0] = 0, t.slen[1] = 0, t.slen[2] = 0, t.slen[3] = 0, t.max_nonzero_coeff = 575, we.fill(t.scalefac, 0), function (e, t) {
+ t.count1bits = 0, t.sfb_partition_table = M.nr_of_sfb_block[0][0], t.slen[0] = 0, t.slen[1] = 0, t.slen[2] = 0, t.slen[3] = 0, t.max_nonzero_coeff = 575, ye.fill(t.scalefac, 0), function (e, t) {
var a = e.ATH,
- n = t.xr;
- if (t.block_type != Ae.SHORT_TYPE) for (var s = !1, r = Ae.PSFB21 - 1; 0 <= r && !s; r--) {
+ s = t.xr;
+ if (t.block_type != Pe.SHORT_TYPE) for (var n = !1, r = Pe.PSFB21 - 1; 0 <= r && !n; r--) {
var i = e.scalefac_band.psfb21[r],
o = e.scalefac_band.psfb21[r + 1],
- _ = g.athAdjust(a.adjust, a.psfb21[r], a.floor);
+ _ = M.athAdjust(a.adjust, a.psfb21[r], a.floor);
1e-12 < e.nsPsy.longfact[21] && (_ *= e.nsPsy.longfact[21]);
for (var l = o - 1; i <= l; l--) {
- if (!(Math.abs(n[l]) < _)) {
- s = !0;
+ if (!(Math.abs(s[l]) < _)) {
+ n = !0;
break;
}
- n[l] = 0;
+ s[l] = 0;
}
- } else for (var f = 0; f < 3; f++) for (var s = !1, r = Ae.PSFB12 - 1; 0 <= r && !s; r--) {
- var i = 3 * e.scalefac_band.s[12] + (e.scalefac_band.s[13] - e.scalefac_band.s[12]) * f + (e.scalefac_band.psfb12[r] - e.scalefac_band.psfb12[0]),
- o = i + (e.scalefac_band.psfb12[r + 1] - e.scalefac_band.psfb12[r]),
- c = g.athAdjust(a.adjust, a.psfb12[r], a.floor);
- 1e-12 < e.nsPsy.shortfact[12] && (c *= e.nsPsy.shortfact[12]);
- for (var l = o - 1; i <= l; l--) {
- if (!(Math.abs(n[l]) < c)) {
- s = !0;
+ } else for (var f = 0; f < 3; f++) for (n = !1, r = Pe.PSFB12 - 1; 0 <= r && !n; r--) {
+ o = (i = 3 * e.scalefac_band.s[12] + (e.scalefac_band.s[13] - e.scalefac_band.s[12]) * f + (e.scalefac_band.psfb12[r] - e.scalefac_band.psfb12[0])) + (e.scalefac_band.psfb12[r + 1] - e.scalefac_band.psfb12[r]);
+ var c = M.athAdjust(a.adjust, a.psfb12[r], a.floor);
+ for (1e-12 < e.nsPsy.shortfact[12] && (c *= e.nsPsy.shortfact[12]), l = o - 1; i <= l; l--) {
+ if (!(Math.abs(s[l]) < c)) {
+ n = !0;
break;
}
- n[l] = 0;
+ s[l] = 0;
}
}
}(e, t);
- }, S.BINSEARCH_NONE = new S(0), S.BINSEARCH_UP = new S(1), S.BINSEARCH_DOWN = new S(2), this.outer_loop = function (e, t, a, n, s, r) {
+ }, R.BINSEARCH_NONE = new R(0), R.BINSEARCH_UP = new R(1), R.BINSEARCH_DOWN = new R(2), this.trancate_smallspectrums = function (e, t, a, s) {
+ var n = Be(z.SFBMAX);
+ if ((0 != (4 & e.substep_shaping) || t.block_type != Pe.SHORT_TYPE) && 0 == (128 & e.substep_shaping)) {
+ M.calc_noise(t, a, n, new y(), null);
+ for (var r = 0; r < 576; r++) {
+ var i = 0;
+ 0 != t.l3_enc[r] && (i = Math.abs(t.xr[r])), s[r] = i;
+ }
+ r = 0;
+ var o = 8;
+ t.block_type == Pe.SHORT_TYPE && (o = 6);
+ do {
+ var _,
+ l,
+ f,
+ c,
+ h = t.width[o];
+ if (r += h, !(1 <= n[o] || (ye.sort(s, r - h, h), q.EQ(s[r - 1], 0)))) {
+ _ = (1 - n[o]) * a[o], c = l = 0;
+ do {
+ var u;
+ for (f = 1; c + f < h && !q.NEQ(s[c + r - h], s[c + r + f - h]); f++);
+ if (_ < (u = s[c + r - h] * s[c + r - h] * f)) {
+ 0 != c && (l = s[c + r - h - 1]);
+ break;
+ }
+ _ -= u, c += f;
+ } while (c < h);
+ if (!q.EQ(l, 0)) for (; Math.abs(t.xr[r - h]) <= l && (t.l3_enc[r - h] = 0), 0 < --h;);
+ }
+ } while (++o < t.psymax);
+ t.part2_3_length = w.noquant_count_bits(e, t, null);
+ }
+ }, this.outer_loop = function (e, t, a, s, n, r) {
var i = e.internal_flags,
- o = new B(),
- _ = de(576),
- l = de(F.SFBMAX),
- f = new x(),
+ o = new T(),
+ _ = Be(576),
+ l = Be(z.SFBMAX),
+ f = new y(),
c = new function () {
- this.global_gain = 0, this.sfb_count1 = 0, this.step = ve(39), this.noise = de(39), this.noise_log = de(39);
+ this.global_gain = 0, this.sfb_count1 = 0, this.step = Ae(39), this.noise = Be(39), this.noise_log = Be(39);
}(),
- u = 9999999,
- h = !1;
- if (function (e, t, a, n, s) {
+ h = 9999999,
+ u = !1,
+ m = !1,
+ p = 0;
+ if (function (e, t, a, s, n) {
var r,
- i = e.CurrentStep[n],
+ i = e.CurrentStep[s],
o = !1,
- _ = e.OldValue[n],
- l = S.BINSEARCH_NONE;
+ _ = e.OldValue[s],
+ l = R.BINSEARCH_NONE;
for (t.global_gain = _, a -= t.part2_length;;) {
var f;
- if (r = w.count_bits(e, s, t, null), 1 == i || r == a) break;
- a < r ? (l == S.BINSEARCH_DOWN && (o = !0), o && (i /= 2), l = S.BINSEARCH_UP, f = i) : (l == S.BINSEARCH_UP && (o = !0), o && (i /= 2), l = S.BINSEARCH_DOWN, f = -i), t.global_gain += f, t.global_gain < 0 && me(), 255 < t.global_gain && me();
+ if (r = w.count_bits(e, n, t, null), 1 == i || r == a) break;
+ a < r ? (l == R.BINSEARCH_DOWN && (o = !0), o && (i /= 2), l = R.BINSEARCH_UP, f = i) : (l == R.BINSEARCH_UP && (o = !0), o && (i /= 2), l = R.BINSEARCH_DOWN, f = -i), t.global_gain += f, t.global_gain < 0 && (o = !(t.global_gain = 0)), 255 < t.global_gain && (t.global_gain = 255, o = !0);
}
- for (; a < r && t.global_gain < 255;) t.global_gain++, r = w.count_bits(e, s, t, null);
- e.CurrentStep[n] = 4 <= _ - t.global_gain ? 4 : 2, e.OldValue[n] = t.global_gain, t.part2_3_length = r;
- }(i, t, r, s, n), 0 == i.noise_shaping) return 100;
- g.calc_noise(t, a, l, f, c), f.bits = t.part2_3_length, o.assign(t);
+ for (; a < r && t.global_gain < 255;) t.global_gain++, r = w.count_bits(e, n, t, null);
+ e.CurrentStep[s] = 4 <= _ - t.global_gain ? 4 : 2, e.OldValue[s] = t.global_gain, t.part2_3_length = r;
+ }(i, t, r, n, s), 0 == i.noise_shaping) return 100;
+ M.calc_noise(t, a, l, f, c), f.bits = t.part2_3_length, o.assign(t);
var b = 0;
- for (I.arraycopy(n, 0, _, 0, 576); !h;) {
+ for ($.arraycopy(s, 0, _, 0, 576); !u;) {
do {
- var p,
- m = new x(),
- v = 255;
- if (p = 0 != (2 & i.substep_shaping) ? 20 : 3, i.sfb21_extra && me(), !y(e, o, l, n)) break;
- 0 != o.scalefac_scale && (v = 254);
- var d = r - o.part2_length;
- if (d <= 0) break;
- for (; (o.part2_3_length = w.count_bits(i, n, o, c)) > d && o.global_gain <= v;) o.global_gain++;
- if (o.global_gain > v) break;
- if (0 == f.over_count) {
- for (; (o.part2_3_length = w.count_bits(i, n, o, c)) > u && o.global_gain <= v;) o.global_gain++;
- if (o.global_gain > v) break;
+ var v,
+ d = new y(),
+ g = 255;
+ if (v = 0 != (2 & i.substep_shaping) ? 20 : 3, i.sfb21_extra) {
+ if (1 < l[o.sfbmax]) break;
+ if (o.block_type == Pe.SHORT_TYPE && (1 < l[o.sfbmax + 1] || 1 < l[o.sfbmax + 2])) break;
}
- if (g.calc_noise(o, a, l, m, c), m.bits = o.part2_3_length, 0 != (M(t.block_type != Ae.SHORT_TYPE ? e.quant_comp : e.quant_comp_short, f, m) ? 1 : 0)) u = t.part2_3_length, f = m, t.assign(o), b = 0, I.arraycopy(n, 0, _, 0, 576);else if (0 == i.full_outer_loop) {
- if (++b > p && 0 == f.over_count) break;
- i.noise_shaping_amp, i.noise_shaping_amp;
+ if (!B(e, o, l, s, m)) break;
+ 0 != o.scalefac_scale && (g = 254);
+ var S = r - o.part2_length;
+ if (S <= 0) break;
+ for (; (o.part2_3_length = w.count_bits(i, s, o, c)) > S && o.global_gain <= g;) o.global_gain++;
+ if (o.global_gain > g) break;
+ if (0 == f.over_count) {
+ for (; (o.part2_3_length = w.count_bits(i, s, o, c)) > h && o.global_gain <= g;) o.global_gain++;
+ if (o.global_gain > g) break;
+ }
+ if (M.calc_noise(o, a, l, d, c), d.bits = o.part2_3_length, 0 != (A(t.block_type != Pe.SHORT_TYPE ? e.quant_comp : e.quant_comp_short, f, d, o, l) ? 1 : 0)) h = t.part2_3_length, f = d, t.assign(o), b = 0, $.arraycopy(s, 0, _, 0, 576);else if (0 == i.full_outer_loop) {
+ if (++b > v && 0 == f.over_count) break;
+ if (3 == i.noise_shaping_amp && m && 30 < b) break;
+ if (3 == i.noise_shaping_amp && m && 15 < o.global_gain - p) break;
}
} while (o.global_gain + o.scalefac_scale < 255);
- 3 == i.noise_shaping_amp ? me() : h = !0;
+ 3 == i.noise_shaping_amp ? m ? u = !0 : (o.assign(t), $.arraycopy(_, 0, s, 0, 576), b = 0, p = o.global_gain, m = !0) : u = !0;
}
- return e.VBR == Me.vbr_rh || e.VBR == Me.vbr_mtrh ? I.arraycopy(_, 0, n, 0, 576) : 0 != (1 & i.substep_shaping) && me(), f.over_count;
+ return e.VBR == xe.vbr_rh || e.VBR == xe.vbr_mtrh ? $.arraycopy(_, 0, s, 0, 576) : 0 != (1 & i.substep_shaping) && trancate_smallspectrums(i, t, a, s), f.over_count;
}, this.iteration_finish_one = function (e, t, a) {
- var n = e.l3_side,
- s = n.tt[t][a];
- w.best_scalefac_store(e, t, a, n), 1 == e.use_best_huffman && w.best_huffman_divide(e, s), r.ResvAdjust(e, s);
+ var s = e.l3_side,
+ n = s.tt[t][a];
+ w.best_scalefac_store(e, t, a, s), 1 == e.use_best_huffman && w.best_huffman_divide(e, n), g.ResvAdjust(e, n);
+ }, this.VBR_encode_granule = function (e, t, a, s, n, r, i) {
+ var o,
+ _ = e.internal_flags,
+ l = new T(),
+ f = Be(576),
+ c = i,
+ h = i + 1,
+ u = (i + r) / 2,
+ m = 0,
+ p = _.sfb21_extra;
+ for (ye.fill(l.l3_enc, 0); _.sfb21_extra = !(c - 42 < u) && p, outer_loop(e, t, a, s, n, u) <= 0 ? (m = 1, h = t.part2_3_length, l.assign(t), $.arraycopy(s, 0, f, 0, 576), o = (i = h - 32) - r, u = (i + r) / 2) : (o = i - (r = u + 32), u = (i + r) / 2, 0 != m && (m = 2, t.assign(l), $.arraycopy(f, 0, s, 0, 576))), 12 < o;);
+ _.sfb21_extra = p, 2 == m && $.arraycopy(l.l3_enc, 0, t.l3_enc, 0, 576);
+ }, this.get_framebits = function (e, t) {
+ var a = e.internal_flags;
+ a.bitrate_index = a.VBR_min_bitrate;
+ var s = v.getframebits(e);
+ a.bitrate_index = 1, s = v.getframebits(e);
+ for (var n = 1; n <= a.VBR_max_bitrate; n++) {
+ a.bitrate_index = n;
+ var r = new j(s);
+ t[n] = g.ResvFrameBegin(e, r), s = r.bits;
+ }
+ }, this.VBR_old_prepare = function (e, t, a, s, n, r, i, o, _) {
+ var l,
+ f = e.internal_flags,
+ c = 0,
+ h = 1,
+ u = 0;
+ f.bitrate_index = f.VBR_max_bitrate;
+ var m = g.ResvFrameBegin(e, new j(0)) / f.mode_gr;
+ get_framebits(e, r);
+ for (var p = 0; p < f.mode_gr; p++) {
+ var b = M.on_pe(e, t, o[p], m, p, 0);
+ f.mode_ext == Pe.MPG_MD_MS_LR && (ms_convert(f.l3_side, p), M.reduce_side(o[p], a[p], m, b));
+ for (var v = 0; v < f.channels_out; ++v) {
+ var d = f.l3_side.tt[p][v];
+ d.block_type != Pe.SHORT_TYPE ? (c = 1.28 / (1 + Math.exp(3.5 - t[p][v] / 300)) - .05, l = f.PSY.mask_adjust - c) : (c = 2.56 / (1 + Math.exp(3.5 - t[p][v] / 300)) - .14, l = f.PSY.mask_adjust_short - c), f.masking_lower = Math.pow(10, .1 * l), init_outer_loop(f, d), _[p][v] = M.calc_xmin(e, s[p][v], d, n[p][v]), 0 != _[p][v] && (h = 0), i[p][v] = 126, u += o[p][v];
+ }
+ }
+ for (p = 0; p < f.mode_gr; p++) for (v = 0; v < f.channels_out; v++) u > r[f.VBR_max_bitrate] && (o[p][v] *= r[f.VBR_max_bitrate], o[p][v] /= u), i[p][v] > o[p][v] && (i[p][v] = o[p][v]);
+ return h;
+ }, this.bitpressure_strategy = function (e, t, a, s) {
+ for (var n = 0; n < e.mode_gr; n++) for (var r = 0; r < e.channels_out; r++) {
+ for (var i = e.l3_side.tt[n][r], o = t[n][r], _ = 0, l = 0; l < i.psy_lmax; l++) o[_++] *= 1 + .029 * l * l / Pe.SBMAX_l / Pe.SBMAX_l;
+ if (i.block_type == Pe.SHORT_TYPE) for (l = i.sfb_smin; l < Pe.SBMAX_s; l++) o[_++] *= 1 + .029 * l * l / Pe.SBMAX_s / Pe.SBMAX_s, o[_++] *= 1 + .029 * l * l / Pe.SBMAX_s / Pe.SBMAX_s, o[_++] *= 1 + .029 * l * l / Pe.SBMAX_s / Pe.SBMAX_s;
+ s[n][r] = 0 | Math.max(a[n][r], .9 * s[n][r]);
+ }
+ }, this.VBR_new_prepare = function (e, t, a, s, n, r) {
+ var i,
+ o = e.internal_flags,
+ _ = 1,
+ l = 0,
+ f = 0;
+ if (e.free_format) {
+ o.bitrate_index = 0;
+ c = new j(l);
+ i = g.ResvFrameBegin(e, c), l = c.bits, n[0] = i;
+ } else {
+ o.bitrate_index = o.VBR_max_bitrate;
+ var c = new j(l);
+ g.ResvFrameBegin(e, c), l = c.bits, get_framebits(e, n), i = n[o.VBR_max_bitrate];
+ }
+ for (var h = 0; h < o.mode_gr; h++) {
+ M.on_pe(e, t, r[h], l, h, 0), o.mode_ext == Pe.MPG_MD_MS_LR && ms_convert(o.l3_side, h);
+ for (var u = 0; u < o.channels_out; ++u) {
+ var m = o.l3_side.tt[h][u];
+ o.masking_lower = Math.pow(10, .1 * o.PSY.mask_adjust), init_outer_loop(o, m), 0 != M.calc_xmin(e, a[h][u], m, s[h][u]) && (_ = 0), f += r[h][u];
+ }
+ }
+ for (h = 0; h < o.mode_gr; h++) for (u = 0; u < o.channels_out; u++) i < f && (r[h][u] *= i, r[h][u] /= f);
+ return _;
+ }, this.calc_target_bits = function (e, t, a, s, n, r) {
+ var i,
+ o,
+ _,
+ l,
+ f = e.internal_flags,
+ c = f.l3_side,
+ h = 0;
+ f.bitrate_index = f.VBR_max_bitrate;
+ var u = new j(h);
+ for (r[0] = g.ResvFrameBegin(e, u), h = u.bits, f.bitrate_index = 1, h = v.getframebits(e) - 8 * f.sideinfo_len, n[0] = h / (f.mode_gr * f.channels_out), h = e.VBR_mean_bitrate_kbps * e.framesize * 1e3, 0 != (1 & f.substep_shaping) && (h *= 1.09), h /= e.out_samplerate, h -= 8 * f.sideinfo_len, h /= f.mode_gr * f.channels_out, (i = .93 + .07 * (11 - e.compression_ratio) / 5.5) < .9 && (i = .9), 1 < i && (i = 1), o = 0; o < f.mode_gr; o++) {
+ var m = 0;
+ for (_ = 0; _ < f.channels_out; _++) {
+ if (s[o][_] = int(i * h), 700 < t[o][_]) {
+ var p = int((t[o][_] - 700) / 1.4),
+ b = c.tt[o][_];
+ s[o][_] = int(i * h), b.block_type == Pe.SHORT_TYPE && p < h / 2 && (p = h / 2), 3 * h / 2 < p ? p = 3 * h / 2 : p < 0 && (p = 0), s[o][_] += p;
+ }
+ s[o][_] > Z.MAX_BITS_PER_CHANNEL && (s[o][_] = Z.MAX_BITS_PER_CHANNEL), m += s[o][_];
+ }
+ if (Z.MAX_BITS_PER_GRANULE < m) for (_ = 0; _ < f.channels_out; ++_) s[o][_] *= Z.MAX_BITS_PER_GRANULE, s[o][_] /= m;
+ }
+ if (f.mode_ext == Pe.MPG_MD_MS_LR) for (o = 0; o < f.mode_gr; o++) M.reduce_side(s[o], a[o], h * f.channels_out, Z.MAX_BITS_PER_GRANULE);
+ for (o = l = 0; o < f.mode_gr; o++) for (_ = 0; _ < f.channels_out; _++) s[o][_] > Z.MAX_BITS_PER_CHANNEL && (s[o][_] = Z.MAX_BITS_PER_CHANNEL), l += s[o][_];
+ if (l > r[0]) for (o = 0; o < f.mode_gr; o++) for (_ = 0; _ < f.channels_out; _++) s[o][_] *= r[0], s[o][_] /= l;
};
}
- function L() {
+ function N() {
this.thm = new i(), this.en = new i();
}
- function Ae() {
- var k = Ae.MPG_MD_MS_LR,
- R = null,
- x = this.psy = null,
- B = null;
- this.setModules = function (e, t, a, n) {
- R = e, this.psy = t, x = t, B = n;
+ function Pe() {
+ var E = Pe.FFTOFFSET,
+ P = Pe.MPG_MD_MS_LR,
+ L = null,
+ I = this.psy = null,
+ H = null,
+ C = null;
+ this.setModules = function (e, t, a, s) {
+ L = e, this.psy = t, I = t, H = s, C = a;
};
- var T = new function () {
- var u = [-.1482523854003001, 32.308141959636465, 296.40344946382766, 883.1344870032432, 11113.947376231741, 1057.2713659324597, 305.7402417275812, 30.825928907280012, 3.8533188138216365, 59.42900443849514, 709.5899960123345, 5281.91112291017, -5829.66483675846, -817.6293103748613, -76.91656988279972, -4.594269939176596, .9063471690191471, .1960342806591213, -.15466694054279598, 34.324387823855965, 301.8067566458425, 817.599602898885, 11573.795901679885, 1181.2520595540152, 321.59731579894424, 31.232021761053772, 3.7107095756221318, 53.650946155329365, 684.167428119626, 5224.56624370173, -6366.391851890084, -908.9766368219582, -89.83068876699639, -5.411397422890401, .8206787908286602, .3901806440322567, -.16070888947830023, 36.147034243915876, 304.11815768187864, 732.7429163887613, 11989.60988270091, 1300.012278487897, 335.28490093152146, 31.48816102859945, 3.373875931311736, 47.232241542899175, 652.7371796173471, 5132.414255594984, -6909.087078780055, -1001.9990371107289, -103.62185754286375, -6.104916304710272, .7416505462720353, .5805693545089249, -.16636367662261495, 37.751650073343995, 303.01103387567713, 627.9747488785183, 12358.763425278165, 1412.2779918482834, 346.7496836825721, 31.598286663170416, 3.1598635433980946, 40.57878626349686, 616.1671130880391, 5007.833007176154, -7454.040671756168, -1095.7960341867115, -118.24411666465777, -6.818469345853504, .6681786379192989, .7653668647301797, -.1716176790982088, 39.11551877123304, 298.3413246578966, 503.5259106886539, 12679.589408408976, 1516.5821921214542, 355.9850766329023, 31.395241710249053, 2.9164211881972335, 33.79716964664243, 574.8943997801362, 4853.234992253242, -7997.57021486075, -1189.7624067269965, -133.6444792601766, -7.7202770609839915, .5993769336819237, .9427934736519954, -.17645823955292173, 40.21879108166477, 289.9982036694474, 359.3226160751053, 12950.259102786438, 1612.1013903507662, 362.85067106591504, 31.045922092242872, 2.822222032597987, 26.988862316190684, 529.8996541764288, 4671.371946949588, -8535.899136645805, -1282.5898586244496, -149.58553632943463, -8.643494270763135, .5345111359507916, 1.111140466039205, -.36174739330527045, 41.04429910497807, 277.5463268268618, 195.6386023135583, 13169.43812144731, 1697.6433561479398, 367.40983966190305, 30.557037410382826, 2.531473372857427, 20.070154905927314, 481.50208566532336, 4464.970341588308, -9065.36882077239, -1373.62841526722, -166.1660487028118, -9.58289321133207, .4729647758913199, 1.268786568327291, -.36970682634889585, 41.393213350082036, 261.2935935556502, 12.935476055240873, 13336.131683328815, 1772.508612059496, 369.76534388639965, 29.751323653701338, 2.4023193045459172, 13.304795348228817, 430.5615775526625, 4237.0568611071185, -9581.931701634761, -1461.6913552409758, -183.12733958476446, -10.718010163869403, .41421356237309503, 1.414213562373095, -.37677560326535325, 41.619486213528496, 241.05423794991074, -187.94665032361226, 13450.063605744153, 1836.153896465782, 369.4908799925761, 29.001847876923147, 2.0714759319987186, 6.779591200894186, 377.7767837205709, 3990.386575512536, -10081.709459700915, -1545.947424837898, -200.3762958015653, -11.864482073055006, .3578057213145241, 1.546020906725474, -.3829366947518991, 41.1516456456653, 216.47684307105183, -406.1569483347166, 13511.136535077321, 1887.8076599260432, 367.3025214564151, 28.136213436723654, 1.913880671464418, .3829366947518991, 323.85365704338597, 3728.1472257487526, -10561.233882199509, -1625.2025997821418, -217.62525175416, -13.015432208941645, .3033466836073424, 1.66293922460509, -.5822628872992417, 40.35639251440489, 188.20071124269245, -640.2706748618148, 13519.21490106562, 1927.6022433578062, 362.8197642637487, 26.968821921868447, 1.7463817695935329, -5.62650678237171, 269.3016715297017, 3453.386536448852, -11016.145278780888, -1698.6569643425091, -234.7658734267683, -14.16351421663124, .2504869601913055, 1.76384252869671, -.5887180101749253, 39.23429103868072, 155.76096234403798, -889.2492977967378, 13475.470561874661, 1955.0535223723712, 356.4450994756727, 25.894952980042156, 1.5695032905781554, -11.181939564328772, 214.80884394039484, 3169.1640829158237, -11443.321309975563, -1765.1588461316153, -251.68908574481912, -15.49755935939164, .198912367379658, 1.847759065022573, -.7912582233652842, 37.39369355329111, 119.699486012458, -1151.0956593239027, 13380.446257078214, 1970.3952110853447, 348.01959814116185, 24.731487364283044, 1.3850130831637748, -16.421408865300393, 161.05030052864092, 2878.3322807850063, -11838.991423510031, -1823.985884688674, -268.2854986386903, -16.81724543849939, .1483359875383474, 1.913880671464418, -.7960642926861912, 35.2322109610459, 80.01928065061526, -1424.0212633405113, 13235.794061869668, 1973.804052543835, 337.9908651258184, 23.289159354463873, 1.3934255946442087, -21.099669467133474, 108.48348407242611, 2583.700758091299, -12199.726194855148, -1874.2780658979746, -284.2467154529415, -18.11369784385905, .09849140335716425, 1.961570560806461, -.998795456205172, 32.56307803611191, 36.958364584370486, -1706.075448829146, 13043.287458812016, 1965.3831106103316, 326.43182772364605, 22.175018750622293, 1.198638339011324, -25.371248002043963, 57.53505923036915, 2288.41886619975, -12522.674544337233, -1914.8400385312243, -299.26241273417224, -19.37805630698734, .04912684976946725, 1.990369453344394, .035780907 * V.SQRT2 * .5 / 2384e-9, .017876148 * V.SQRT2 * .5 / 2384e-9, .003134727 * V.SQRT2 * .5 / 2384e-9, .002457142 * V.SQRT2 * .5 / 2384e-9, 971317e-9 * V.SQRT2 * .5 / 2384e-9, 218868e-9 * V.SQRT2 * .5 / 2384e-9, 101566e-9 * V.SQRT2 * .5 / 2384e-9, 13828e-9 * V.SQRT2 * .5 / 2384e-9, 12804.797818791945, 1945.5515939597317, 313.4244966442953, 49591e-9 / 2384e-9, 1995.1556208053692, 21458e-9 / 2384e-9, -69618e-9 / 2384e-9],
- A = [[2.382191739347913e-13, 6.423305872147834e-13, 9.400849094049688e-13, 1.122435026096556e-12, 1.183840321267481e-12, 1.122435026096556e-12, 9.40084909404969e-13, 6.423305872147839e-13, 2.382191739347918e-13, 5.456116108943412e-12, 4.878985199565852e-12, 4.240448995017367e-12, 3.559909094758252e-12, 2.858043359288075e-12, 2.156177623817898e-12, 1.475637723558783e-12, 8.371015190102974e-13, 2.599706096327376e-13, -5.456116108943412e-12, -4.878985199565852e-12, -4.240448995017367e-12, -3.559909094758252e-12, -2.858043359288076e-12, -2.156177623817898e-12, -1.475637723558783e-12, -8.371015190102975e-13, -2.599706096327376e-13, -2.382191739347923e-13, -6.423305872147843e-13, -9.400849094049696e-13, -1.122435026096556e-12, -1.183840321267481e-12, -1.122435026096556e-12, -9.400849094049694e-13, -6.42330587214784e-13, -2.382191739347918e-13], [2.382191739347913e-13, 6.423305872147834e-13, 9.400849094049688e-13, 1.122435026096556e-12, 1.183840321267481e-12, 1.122435026096556e-12, 9.400849094049688e-13, 6.423305872147841e-13, 2.382191739347918e-13, 5.456116108943413e-12, 4.878985199565852e-12, 4.240448995017367e-12, 3.559909094758253e-12, 2.858043359288075e-12, 2.156177623817898e-12, 1.475637723558782e-12, 8.371015190102975e-13, 2.599706096327376e-13, -5.461314069809755e-12, -4.921085770524055e-12, -4.343405037091838e-12, -3.732668368707687e-12, -3.093523840190885e-12, -2.430835727329465e-12, -1.734679010007751e-12, -9.74825365660928e-13, -2.797435120168326e-13, 0, 0, 0, 0, 0, 0, -2.283748241799531e-13, -4.037858874020686e-13, -2.146547464825323e-13], [.1316524975873958, .414213562373095, .7673269879789602, 1.091308501069271, 1.303225372841206, 1.56968557711749, 1.920982126971166, 2.414213562373094, 3.171594802363212, 4.510708503662055, 7.595754112725146, 22.90376554843115, .984807753012208, .6427876096865394, .3420201433256688, .9396926207859084, -.1736481776669303, -.7660444431189779, .8660254037844387, .5, -.5144957554275265, -.4717319685649723, -.3133774542039019, -.1819131996109812, -.09457419252642064, -.04096558288530405, -.01419856857247115, -.003699974673760037, .8574929257125442, .8817419973177052, .9496286491027329, .9833145924917901, .9955178160675857, .9991605581781475, .999899195244447, .9999931550702802], [0, 0, 0, 0, 0, 0, 2.283748241799531e-13, 4.037858874020686e-13, 2.146547464825323e-13, 5.461314069809755e-12, 4.921085770524055e-12, 4.343405037091838e-12, 3.732668368707687e-12, 3.093523840190885e-12, 2.430835727329466e-12, 1.734679010007751e-12, 9.74825365660928e-13, 2.797435120168326e-13, -5.456116108943413e-12, -4.878985199565852e-12, -4.240448995017367e-12, -3.559909094758253e-12, -2.858043359288075e-12, -2.156177623817898e-12, -1.475637723558782e-12, -8.371015190102975e-13, -2.599706096327376e-13, -2.382191739347913e-13, -6.423305872147834e-13, -9.400849094049688e-13, -1.122435026096556e-12, -1.183840321267481e-12, -1.122435026096556e-12, -9.400849094049688e-13, -6.423305872147841e-13, -2.382191739347918e-13]],
- k = A[Ae.SHORT_TYPE],
- S = A[Ae.SHORT_TYPE],
- R = A[Ae.SHORT_TYPE],
- x = A[Ae.SHORT_TYPE],
- B = [0, 1, 16, 17, 8, 9, 24, 25, 4, 5, 20, 21, 12, 13, 28, 29, 2, 3, 18, 19, 10, 11, 26, 27, 6, 7, 22, 23, 14, 15, 30, 31];
- function T(e, t, a) {
- for (var n, s, r, i = 10, o = t + 238 - 14 - 286, _ = -15; _ < 0; _++) {
+ var V = new function () {
+ var h = [-.1482523854003001, 32.308141959636465, 296.40344946382766, 883.1344870032432, 11113.947376231741, 1057.2713659324597, 305.7402417275812, 30.825928907280012, 3.8533188138216365, 59.42900443849514, 709.5899960123345, 5281.91112291017, -5829.66483675846, -817.6293103748613, -76.91656988279972, -4.594269939176596, .9063471690191471, .1960342806591213, -.15466694054279598, 34.324387823855965, 301.8067566458425, 817.599602898885, 11573.795901679885, 1181.2520595540152, 321.59731579894424, 31.232021761053772, 3.7107095756221318, 53.650946155329365, 684.167428119626, 5224.56624370173, -6366.391851890084, -908.9766368219582, -89.83068876699639, -5.411397422890401, .8206787908286602, .3901806440322567, -.16070888947830023, 36.147034243915876, 304.11815768187864, 732.7429163887613, 11989.60988270091, 1300.012278487897, 335.28490093152146, 31.48816102859945, 3.373875931311736, 47.232241542899175, 652.7371796173471, 5132.414255594984, -6909.087078780055, -1001.9990371107289, -103.62185754286375, -6.104916304710272, .7416505462720353, .5805693545089249, -.16636367662261495, 37.751650073343995, 303.01103387567713, 627.9747488785183, 12358.763425278165, 1412.2779918482834, 346.7496836825721, 31.598286663170416, 3.1598635433980946, 40.57878626349686, 616.1671130880391, 5007.833007176154, -7454.040671756168, -1095.7960341867115, -118.24411666465777, -6.818469345853504, .6681786379192989, .7653668647301797, -.1716176790982088, 39.11551877123304, 298.3413246578966, 503.5259106886539, 12679.589408408976, 1516.5821921214542, 355.9850766329023, 31.395241710249053, 2.9164211881972335, 33.79716964664243, 574.8943997801362, 4853.234992253242, -7997.57021486075, -1189.7624067269965, -133.6444792601766, -7.7202770609839915, .5993769336819237, .9427934736519954, -.17645823955292173, 40.21879108166477, 289.9982036694474, 359.3226160751053, 12950.259102786438, 1612.1013903507662, 362.85067106591504, 31.045922092242872, 2.822222032597987, 26.988862316190684, 529.8996541764288, 4671.371946949588, -8535.899136645805, -1282.5898586244496, -149.58553632943463, -8.643494270763135, .5345111359507916, 1.111140466039205, -.36174739330527045, 41.04429910497807, 277.5463268268618, 195.6386023135583, 13169.43812144731, 1697.6433561479398, 367.40983966190305, 30.557037410382826, 2.531473372857427, 20.070154905927314, 481.50208566532336, 4464.970341588308, -9065.36882077239, -1373.62841526722, -166.1660487028118, -9.58289321133207, .4729647758913199, 1.268786568327291, -.36970682634889585, 41.393213350082036, 261.2935935556502, 12.935476055240873, 13336.131683328815, 1772.508612059496, 369.76534388639965, 29.751323653701338, 2.4023193045459172, 13.304795348228817, 430.5615775526625, 4237.0568611071185, -9581.931701634761, -1461.6913552409758, -183.12733958476446, -10.718010163869403, .41421356237309503, 1.414213562373095, -.37677560326535325, 41.619486213528496, 241.05423794991074, -187.94665032361226, 13450.063605744153, 1836.153896465782, 369.4908799925761, 29.001847876923147, 2.0714759319987186, 6.779591200894186, 377.7767837205709, 3990.386575512536, -10081.709459700915, -1545.947424837898, -200.3762958015653, -11.864482073055006, .3578057213145241, 1.546020906725474, -.3829366947518991, 41.1516456456653, 216.47684307105183, -406.1569483347166, 13511.136535077321, 1887.8076599260432, 367.3025214564151, 28.136213436723654, 1.913880671464418, .3829366947518991, 323.85365704338597, 3728.1472257487526, -10561.233882199509, -1625.2025997821418, -217.62525175416, -13.015432208941645, .3033466836073424, 1.66293922460509, -.5822628872992417, 40.35639251440489, 188.20071124269245, -640.2706748618148, 13519.21490106562, 1927.6022433578062, 362.8197642637487, 26.968821921868447, 1.7463817695935329, -5.62650678237171, 269.3016715297017, 3453.386536448852, -11016.145278780888, -1698.6569643425091, -234.7658734267683, -14.16351421663124, .2504869601913055, 1.76384252869671, -.5887180101749253, 39.23429103868072, 155.76096234403798, -889.2492977967378, 13475.470561874661, 1955.0535223723712, 356.4450994756727, 25.894952980042156, 1.5695032905781554, -11.181939564328772, 214.80884394039484, 3169.1640829158237, -11443.321309975563, -1765.1588461316153, -251.68908574481912, -15.49755935939164, .198912367379658, 1.847759065022573, -.7912582233652842, 37.39369355329111, 119.699486012458, -1151.0956593239027, 13380.446257078214, 1970.3952110853447, 348.01959814116185, 24.731487364283044, 1.3850130831637748, -16.421408865300393, 161.05030052864092, 2878.3322807850063, -11838.991423510031, -1823.985884688674, -268.2854986386903, -16.81724543849939, .1483359875383474, 1.913880671464418, -.7960642926861912, 35.2322109610459, 80.01928065061526, -1424.0212633405113, 13235.794061869668, 1973.804052543835, 337.9908651258184, 23.289159354463873, 1.3934255946442087, -21.099669467133474, 108.48348407242611, 2583.700758091299, -12199.726194855148, -1874.2780658979746, -284.2467154529415, -18.11369784385905, .09849140335716425, 1.961570560806461, -.998795456205172, 32.56307803611191, 36.958364584370486, -1706.075448829146, 13043.287458812016, 1965.3831106103316, 326.43182772364605, 22.175018750622293, 1.198638339011324, -25.371248002043963, 57.53505923036915, 2288.41886619975, -12522.674544337233, -1914.8400385312243, -299.26241273417224, -19.37805630698734, .04912684976946725, 1.990369453344394, .035780907 * ee.SQRT2 * .5 / 2384e-9, .017876148 * ee.SQRT2 * .5 / 2384e-9, .003134727 * ee.SQRT2 * .5 / 2384e-9, .002457142 * ee.SQRT2 * .5 / 2384e-9, 971317e-9 * ee.SQRT2 * .5 / 2384e-9, 218868e-9 * ee.SQRT2 * .5 / 2384e-9, 101566e-9 * ee.SQRT2 * .5 / 2384e-9, 13828e-9 * ee.SQRT2 * .5 / 2384e-9, 12804.797818791945, 1945.5515939597317, 313.4244966442953, 49591e-9 / 2384e-9, 1995.1556208053692, 21458e-9 / 2384e-9, -69618e-9 / 2384e-9],
+ z = [[2.382191739347913e-13, 6.423305872147834e-13, 9.400849094049688e-13, 1.122435026096556e-12, 1.183840321267481e-12, 1.122435026096556e-12, 9.40084909404969e-13, 6.423305872147839e-13, 2.382191739347918e-13, 5.456116108943412e-12, 4.878985199565852e-12, 4.240448995017367e-12, 3.559909094758252e-12, 2.858043359288075e-12, 2.156177623817898e-12, 1.475637723558783e-12, 8.371015190102974e-13, 2.599706096327376e-13, -5.456116108943412e-12, -4.878985199565852e-12, -4.240448995017367e-12, -3.559909094758252e-12, -2.858043359288076e-12, -2.156177623817898e-12, -1.475637723558783e-12, -8.371015190102975e-13, -2.599706096327376e-13, -2.382191739347923e-13, -6.423305872147843e-13, -9.400849094049696e-13, -1.122435026096556e-12, -1.183840321267481e-12, -1.122435026096556e-12, -9.400849094049694e-13, -6.42330587214784e-13, -2.382191739347918e-13], [2.382191739347913e-13, 6.423305872147834e-13, 9.400849094049688e-13, 1.122435026096556e-12, 1.183840321267481e-12, 1.122435026096556e-12, 9.400849094049688e-13, 6.423305872147841e-13, 2.382191739347918e-13, 5.456116108943413e-12, 4.878985199565852e-12, 4.240448995017367e-12, 3.559909094758253e-12, 2.858043359288075e-12, 2.156177623817898e-12, 1.475637723558782e-12, 8.371015190102975e-13, 2.599706096327376e-13, -5.461314069809755e-12, -4.921085770524055e-12, -4.343405037091838e-12, -3.732668368707687e-12, -3.093523840190885e-12, -2.430835727329465e-12, -1.734679010007751e-12, -9.74825365660928e-13, -2.797435120168326e-13, 0, 0, 0, 0, 0, 0, -2.283748241799531e-13, -4.037858874020686e-13, -2.146547464825323e-13], [.1316524975873958, .414213562373095, .7673269879789602, 1.091308501069271, 1.303225372841206, 1.56968557711749, 1.920982126971166, 2.414213562373094, 3.171594802363212, 4.510708503662055, 7.595754112725146, 22.90376554843115, .984807753012208, .6427876096865394, .3420201433256688, .9396926207859084, -.1736481776669303, -.7660444431189779, .8660254037844387, .5, -.5144957554275265, -.4717319685649723, -.3133774542039019, -.1819131996109812, -.09457419252642064, -.04096558288530405, -.01419856857247115, -.003699974673760037, .8574929257125442, .8817419973177052, .9496286491027329, .9833145924917901, .9955178160675857, .9991605581781475, .999899195244447, .9999931550702802], [0, 0, 0, 0, 0, 0, 2.283748241799531e-13, 4.037858874020686e-13, 2.146547464825323e-13, 5.461314069809755e-12, 4.921085770524055e-12, 4.343405037091838e-12, 3.732668368707687e-12, 3.093523840190885e-12, 2.430835727329466e-12, 1.734679010007751e-12, 9.74825365660928e-13, 2.797435120168326e-13, -5.456116108943413e-12, -4.878985199565852e-12, -4.240448995017367e-12, -3.559909094758253e-12, -2.858043359288075e-12, -2.156177623817898e-12, -1.475637723558782e-12, -8.371015190102975e-13, -2.599706096327376e-13, -2.382191739347913e-13, -6.423305872147834e-13, -9.400849094049688e-13, -1.122435026096556e-12, -1.183840321267481e-12, -1.122435026096556e-12, -9.400849094049688e-13, -6.423305872147841e-13, -2.382191739347918e-13]],
+ Z = z[Pe.SHORT_TYPE],
+ K = z[Pe.SHORT_TYPE],
+ G = z[Pe.SHORT_TYPE],
+ U = z[Pe.SHORT_TYPE],
+ Q = [0, 1, 16, 17, 8, 9, 24, 25, 4, 5, 20, 21, 12, 13, 28, 29, 2, 3, 18, 19, 10, 11, 26, 27, 6, 7, 22, 23, 14, 15, 30, 31];
+ function W(e, t, a) {
+ for (var s, n, r, i = 10, o = t + 238 - 14 - 286, _ = -15; _ < 0; _++) {
var l, f, c;
- l = u[i + -10], f = e[o + -224] * l, c = e[t + 224] * l, l = u[i + -9], f += e[o + -160] * l, c += e[t + 160] * l, l = u[i + -8], f += e[o + -96] * l, c += e[t + 96] * l, l = u[i + -7], f += e[o + -32] * l, c += e[t + 32] * l, l = u[i + -6], f += e[o + 32] * l, c += e[t + -32] * l, l = u[i + -5], f += e[o + 96] * l, c += e[t + -96] * l, l = u[i + -4], f += e[o + 160] * l, c += e[t + -160] * l, l = u[i + -3], f += e[o + 224] * l, c += e[t + -224] * l, l = u[i + -2], f += e[t + -256] * l, c -= e[o + 256] * l, l = u[i + -1], f += e[t + -192] * l, c -= e[o + 192] * l, l = u[i + 0], f += e[t + -128] * l, c -= e[o + 128] * l, l = u[i + 1], f += e[t + -64] * l, c -= e[o + 64] * l, l = u[i + 2], f += e[t + 0] * l, c -= e[o + 0] * l, l = u[i + 3], f += e[t + 64] * l, c -= e[o + -64] * l, l = u[i + 4], f += e[t + 128] * l, c -= e[o + -128] * l, l = u[i + 5], f += e[t + 192] * l, c -= e[o + -192] * l, f *= u[i + 6], l = c - f, a[30 + 2 * _] = c + f, a[31 + 2 * _] = u[i + 7] * l, i += 18, t--, o++;
+ l = h[i + -10], f = e[o + -224] * l, c = e[t + 224] * l, l = h[i + -9], f += e[o + -160] * l, c += e[t + 160] * l, l = h[i + -8], f += e[o + -96] * l, c += e[t + 96] * l, l = h[i + -7], f += e[o + -32] * l, c += e[t + 32] * l, l = h[i + -6], f += e[o + 32] * l, c += e[t + -32] * l, l = h[i + -5], f += e[o + 96] * l, c += e[t + -96] * l, l = h[i + -4], f += e[o + 160] * l, c += e[t + -160] * l, l = h[i + -3], f += e[o + 224] * l, c += e[t + -224] * l, l = h[i + -2], f += e[t + -256] * l, c -= e[o + 256] * l, l = h[i + -1], f += e[t + -192] * l, c -= e[o + 192] * l, l = h[i + 0], f += e[t + -128] * l, c -= e[o + 128] * l, l = h[i + 1], f += e[t + -64] * l, c -= e[o + 64] * l, l = h[i + 2], f += e[t + 0] * l, c -= e[o + 0] * l, l = h[i + 3], f += e[t + 64] * l, c -= e[o + -64] * l, l = h[i + 4], f += e[t + 128] * l, c -= e[o + -128] * l, l = h[i + 5], f += e[t + 192] * l, l = (c -= e[o + -192] * l) - (f *= h[i + 6]), a[30 + 2 * _] = c + f, a[31 + 2 * _] = h[i + 7] * l, i += 18, t--, o++;
}
- c = e[t + -16] * u[i + -10], f = e[t + -32] * u[i + -2], c += (e[t + -48] - e[t + 16]) * u[i + -9], f += e[t + -96] * u[i + -1], c += (e[t + -80] + e[t + 48]) * u[i + -8], f += e[t + -160] * u[i + 0], c += (e[t + -112] - e[t + 80]) * u[i + -7], f += e[t + -224] * u[i + 1], c += (e[t + -144] + e[t + 112]) * u[i + -6], f -= e[t + 32] * u[i + 2], c += (e[t + -176] - e[t + 144]) * u[i + -5], f -= e[t + 96] * u[i + 3], c += (e[t + -208] + e[t + 176]) * u[i + -4], f -= e[t + 160] * u[i + 4], c += (e[t + -240] - e[t + 208]) * u[i + -3], f -= e[t + 224], n = f - c, s = f + c, c = a[14], f = a[15] - c, a[31] = s + c, a[30] = n + f, a[15] = n - f, a[14] = s - c, r = a[28] - a[0], a[0] += a[28], a[28] = r * u[i + -36 + 7], r = a[29] - a[1], a[1] += a[29], a[29] = r * u[i + -36 + 7], r = a[26] - a[2], a[2] += a[26], a[26] = r * u[i + -72 + 7], r = a[27] - a[3], a[3] += a[27], a[27] = r * u[i + -72 + 7], r = a[24] - a[4], a[4] += a[24], a[24] = r * u[i + -108 + 7], r = a[25] - a[5], a[5] += a[25], a[25] = r * u[i + -108 + 7], r = a[22] - a[6], a[6] += a[22], a[22] = r * V.SQRT2, r = a[23] - a[7], a[7] += a[23], a[23] = r * V.SQRT2 - a[7], a[7] -= a[6], a[22] -= a[7], a[23] -= a[22], r = a[6], a[6] = a[31] - r, a[31] = a[31] + r, r = a[7], a[7] = a[30] - r, a[30] = a[30] + r, r = a[22], a[22] = a[15] - r, a[15] = a[15] + r, r = a[23], a[23] = a[14] - r, a[14] = a[14] + r, r = a[20] - a[8], a[8] += a[20], a[20] = r * u[i + -180 + 7], r = a[21] - a[9], a[9] += a[21], a[21] = r * u[i + -180 + 7], r = a[18] - a[10], a[10] += a[18], a[18] = r * u[i + -216 + 7], r = a[19] - a[11], a[11] += a[19], a[19] = r * u[i + -216 + 7], r = a[16] - a[12], a[12] += a[16], a[16] = r * u[i + -252 + 7], r = a[17] - a[13], a[13] += a[17], a[17] = r * u[i + -252 + 7], r = -a[20] + a[24], a[20] += a[24], a[24] = r * u[i + -216 + 7], r = -a[21] + a[25], a[21] += a[25], a[25] = r * u[i + -216 + 7], r = a[4] - a[8], a[4] += a[8], a[8] = r * u[i + -216 + 7], r = a[5] - a[9], a[5] += a[9], a[9] = r * u[i + -216 + 7], r = a[0] - a[12], a[0] += a[12], a[12] = r * u[i + -72 + 7], r = a[1] - a[13], a[1] += a[13], a[13] = r * u[i + -72 + 7], r = a[16] - a[28], a[16] += a[28], a[28] = r * u[i + -72 + 7], r = -a[17] + a[29], a[17] += a[29], a[29] = r * u[i + -72 + 7], r = V.SQRT2 * (a[2] - a[10]), a[2] += a[10], a[10] = r, r = V.SQRT2 * (a[3] - a[11]), a[3] += a[11], a[11] = r, r = V.SQRT2 * (-a[18] + a[26]), a[18] += a[26], a[26] = r - a[18], r = V.SQRT2 * (-a[19] + a[27]), a[19] += a[27], a[27] = r - a[19], r = a[2], a[19] -= a[3], a[3] -= r, a[2] = a[31] - r, a[31] += r, r = a[3], a[11] -= a[19], a[18] -= r, a[3] = a[30] - r, a[30] += r, r = a[18], a[27] -= a[11], a[19] -= r, a[18] = a[15] - r, a[15] += r, r = a[19], a[10] -= r, a[19] = a[14] - r, a[14] += r, r = a[10], a[11] -= r, a[10] = a[23] - r, a[23] += r, r = a[11], a[26] -= r, a[11] = a[22] - r, a[22] += r, r = a[26], a[27] -= r, a[26] = a[7] - r, a[7] += r, r = a[27], a[27] = a[6] - r, a[6] += r, r = V.SQRT2 * (a[0] - a[4]), a[0] += a[4], a[4] = r, r = V.SQRT2 * (a[1] - a[5]), a[1] += a[5], a[5] = r, r = V.SQRT2 * (a[16] - a[20]), a[16] += a[20], a[20] = r, r = V.SQRT2 * (a[17] - a[21]), a[17] += a[21], a[21] = r, r = -V.SQRT2 * (a[8] - a[12]), a[8] += a[12], a[12] = r - a[8], r = -V.SQRT2 * (a[9] - a[13]), a[9] += a[13], a[13] = r - a[9], r = -V.SQRT2 * (a[25] - a[29]), a[25] += a[29], a[29] = r - a[25], r = -V.SQRT2 * (a[24] + a[28]), a[24] -= a[28], a[28] = r - a[24], r = a[24] - a[16], a[24] = r, r = a[20] - r, a[20] = r, r = a[28] - r, a[28] = r, r = a[25] - a[17], a[25] = r, r = a[21] - r, a[21] = r, r = a[29] - r, a[29] = r, r = a[17] - a[1], a[17] = r, r = a[9] - r, a[9] = r, r = a[25] - r, a[25] = r, r = a[5] - r, a[5] = r, r = a[21] - r, a[21] = r, r = a[13] - r, a[13] = r, r = a[29] - r, a[29] = r, r = a[1] - a[0], a[1] = r, r = a[16] - r, a[16] = r, r = a[17] - r, a[17] = r, r = a[8] - r, a[8] = r, r = a[9] - r, a[9] = r, r = a[24] - r, a[24] = r, r = a[25] - r, a[25] = r, r = a[4] - r, a[4] = r, r = a[5] - r, a[5] = r, r = a[20] - r, a[20] = r, r = a[21] - r, a[21] = r, r = a[12] - r, a[12] = r, r = a[13] - r, a[13] = r, r = a[28] - r, a[28] = r, r = a[29] - r, a[29] = r, r = a[0], a[0] += a[31], a[31] -= r, r = a[1], a[1] += a[30], a[30] -= r, r = a[16], a[16] += a[15], a[15] -= r, r = a[17], a[17] += a[14], a[14] -= r, r = a[8], a[8] += a[23], a[23] -= r, r = a[9], a[9] += a[22], a[22] -= r, r = a[24], a[24] += a[7], a[7] -= r, r = a[25], a[25] += a[6], a[6] -= r, r = a[4], a[4] += a[27], a[27] -= r, r = a[5], a[5] += a[26], a[26] -= r, r = a[20], a[20] += a[11], a[11] -= r, r = a[21], a[21] += a[10], a[10] -= r, r = a[12], a[12] += a[19], a[19] -= r, r = a[13], a[13] += a[18], a[18] -= r, r = a[28], a[28] += a[3], a[3] -= r, r = a[29], a[29] += a[2], a[2] -= r;
+ c = e[t + -16] * h[i + -10], f = e[t + -32] * h[i + -2], c += (e[t + -48] - e[t + 16]) * h[i + -9], f += e[t + -96] * h[i + -1], c += (e[t + -80] + e[t + 48]) * h[i + -8], f += e[t + -160] * h[i + 0], c += (e[t + -112] - e[t + 80]) * h[i + -7], f += e[t + -224] * h[i + 1], c += (e[t + -144] + e[t + 112]) * h[i + -6], f -= e[t + 32] * h[i + 2], c += (e[t + -176] - e[t + 144]) * h[i + -5], f -= e[t + 96] * h[i + 3], c += (e[t + -208] + e[t + 176]) * h[i + -4], f -= e[t + 160] * h[i + 4], c += (e[t + -240] - e[t + 208]) * h[i + -3], s = (f -= e[t + 224]) - c, n = f + c, c = a[14], f = a[15] - c, a[31] = n + c, a[30] = s + f, a[15] = s - f, a[14] = n - c, r = a[28] - a[0], a[0] += a[28], a[28] = r * h[i + -36 + 7], r = a[29] - a[1], a[1] += a[29], a[29] = r * h[i + -36 + 7], r = a[26] - a[2], a[2] += a[26], a[26] = r * h[i + -72 + 7], r = a[27] - a[3], a[3] += a[27], a[27] = r * h[i + -72 + 7], r = a[24] - a[4], a[4] += a[24], a[24] = r * h[i + -108 + 7], r = a[25] - a[5], a[5] += a[25], a[25] = r * h[i + -108 + 7], r = a[22] - a[6], a[6] += a[22], a[22] = r * ee.SQRT2, r = a[23] - a[7], a[7] += a[23], a[23] = r * ee.SQRT2 - a[7], a[7] -= a[6], a[22] -= a[7], a[23] -= a[22], r = a[6], a[6] = a[31] - r, a[31] = a[31] + r, r = a[7], a[7] = a[30] - r, a[30] = a[30] + r, r = a[22], a[22] = a[15] - r, a[15] = a[15] + r, r = a[23], a[23] = a[14] - r, a[14] = a[14] + r, r = a[20] - a[8], a[8] += a[20], a[20] = r * h[i + -180 + 7], r = a[21] - a[9], a[9] += a[21], a[21] = r * h[i + -180 + 7], r = a[18] - a[10], a[10] += a[18], a[18] = r * h[i + -216 + 7], r = a[19] - a[11], a[11] += a[19], a[19] = r * h[i + -216 + 7], r = a[16] - a[12], a[12] += a[16], a[16] = r * h[i + -252 + 7], r = a[17] - a[13], a[13] += a[17], a[17] = r * h[i + -252 + 7], r = -a[20] + a[24], a[20] += a[24], a[24] = r * h[i + -216 + 7], r = -a[21] + a[25], a[21] += a[25], a[25] = r * h[i + -216 + 7], r = a[4] - a[8], a[4] += a[8], a[8] = r * h[i + -216 + 7], r = a[5] - a[9], a[5] += a[9], a[9] = r * h[i + -216 + 7], r = a[0] - a[12], a[0] += a[12], a[12] = r * h[i + -72 + 7], r = a[1] - a[13], a[1] += a[13], a[13] = r * h[i + -72 + 7], r = a[16] - a[28], a[16] += a[28], a[28] = r * h[i + -72 + 7], r = -a[17] + a[29], a[17] += a[29], a[29] = r * h[i + -72 + 7], r = ee.SQRT2 * (a[2] - a[10]), a[2] += a[10], a[10] = r, r = ee.SQRT2 * (a[3] - a[11]), a[3] += a[11], a[11] = r, r = ee.SQRT2 * (-a[18] + a[26]), a[18] += a[26], a[26] = r - a[18], r = ee.SQRT2 * (-a[19] + a[27]), a[19] += a[27], a[27] = r - a[19], r = a[2], a[19] -= a[3], a[3] -= r, a[2] = a[31] - r, a[31] += r, r = a[3], a[11] -= a[19], a[18] -= r, a[3] = a[30] - r, a[30] += r, r = a[18], a[27] -= a[11], a[19] -= r, a[18] = a[15] - r, a[15] += r, r = a[19], a[10] -= r, a[19] = a[14] - r, a[14] += r, r = a[10], a[11] -= r, a[10] = a[23] - r, a[23] += r, r = a[11], a[26] -= r, a[11] = a[22] - r, a[22] += r, r = a[26], a[27] -= r, a[26] = a[7] - r, a[7] += r, r = a[27], a[27] = a[6] - r, a[6] += r, r = ee.SQRT2 * (a[0] - a[4]), a[0] += a[4], a[4] = r, r = ee.SQRT2 * (a[1] - a[5]), a[1] += a[5], a[5] = r, r = ee.SQRT2 * (a[16] - a[20]), a[16] += a[20], a[20] = r, r = ee.SQRT2 * (a[17] - a[21]), a[17] += a[21], a[21] = r, r = -ee.SQRT2 * (a[8] - a[12]), a[8] += a[12], a[12] = r - a[8], r = -ee.SQRT2 * (a[9] - a[13]), a[9] += a[13], a[13] = r - a[9], r = -ee.SQRT2 * (a[25] - a[29]), a[25] += a[29], a[29] = r - a[25], r = -ee.SQRT2 * (a[24] + a[28]), a[24] -= a[28], a[28] = r - a[24], r = a[24] - a[16], a[24] = r, r = a[20] - r, a[20] = r, r = a[28] - r, a[28] = r, r = a[25] - a[17], a[25] = r, r = a[21] - r, a[21] = r, r = a[29] - r, a[29] = r, r = a[17] - a[1], a[17] = r, r = a[9] - r, a[9] = r, r = a[25] - r, a[25] = r, r = a[5] - r, a[5] = r, r = a[21] - r, a[21] = r, r = a[13] - r, a[13] = r, r = a[29] - r, a[29] = r, r = a[1] - a[0], a[1] = r, r = a[16] - r, a[16] = r, r = a[17] - r, a[17] = r, r = a[8] - r, a[8] = r, r = a[9] - r, a[9] = r, r = a[24] - r, a[24] = r, r = a[25] - r, a[25] = r, r = a[4] - r, a[4] = r, r = a[5] - r, a[5] = r, r = a[20] - r, a[20] = r, r = a[21] - r, a[21] = r, r = a[12] - r, a[12] = r, r = a[13] - r, a[13] = r, r = a[28] - r, a[28] = r, r = a[29] - r, a[29] = r, r = a[0], a[0] += a[31], a[31] -= r, r = a[1], a[1] += a[30], a[30] -= r, r = a[16], a[16] += a[15], a[15] -= r, r = a[17], a[17] += a[14], a[14] -= r, r = a[8], a[8] += a[23], a[23] -= r, r = a[9], a[9] += a[22], a[22] -= r, r = a[24], a[24] += a[7], a[7] -= r, r = a[25], a[25] += a[6], a[6] -= r, r = a[4], a[4] += a[27], a[27] -= r, r = a[5], a[5] += a[26], a[26] -= r, r = a[20], a[20] += a[11], a[11] -= r, r = a[21], a[21] += a[10], a[10] -= r, r = a[12], a[12] += a[19], a[19] -= r, r = a[13], a[13] += a[18], a[18] -= r, r = a[28], a[28] += a[3], a[3] -= r, r = a[29], a[29] += a[2], a[2] -= r;
}
- function E(e, t) {
+ function J(e, t) {
for (var a = 0; a < 3; a++) {
- var n, s, r, i, o, _;
- i = e[t + 6] * A[Ae.SHORT_TYPE][0] - e[t + 15], n = e[t + 0] * A[Ae.SHORT_TYPE][2] - e[t + 9], s = i + n, r = i - n, i = e[t + 15] * A[Ae.SHORT_TYPE][0] + e[t + 6], n = e[t + 9] * A[Ae.SHORT_TYPE][2] + e[t + 0], o = i + n, _ = -i + n, n = 2.069978111953089e-11 * (e[t + 3] * A[Ae.SHORT_TYPE][1] - e[t + 12]), i = 2.069978111953089e-11 * (e[t + 12] * A[Ae.SHORT_TYPE][1] + e[t + 3]), e[t + 0] = 1.90752519173728e-11 * s + n, e[t + 15] = 1.90752519173728e-11 * -o + i, r = .8660254037844387 * r * 1.907525191737281e-11, o = .5 * o * 1.907525191737281e-11 + i, e[t + 3] = r - o, e[t + 6] = r + o, s = .5 * s * 1.907525191737281e-11 - n, _ = .8660254037844387 * _ * 1.907525191737281e-11, e[t + 9] = s + _, e[t + 12] = s - _, t++;
+ var s, n, r, i, o, _;
+ n = (i = e[t + 6] * z[Pe.SHORT_TYPE][0] - e[t + 15]) + (s = e[t + 0] * z[Pe.SHORT_TYPE][2] - e[t + 9]), r = i - s, o = (i = e[t + 15] * z[Pe.SHORT_TYPE][0] + e[t + 6]) + (s = e[t + 9] * z[Pe.SHORT_TYPE][2] + e[t + 0]), _ = -i + s, s = 2.069978111953089e-11 * (e[t + 3] * z[Pe.SHORT_TYPE][1] - e[t + 12]), i = 2.069978111953089e-11 * (e[t + 12] * z[Pe.SHORT_TYPE][1] + e[t + 3]), e[t + 0] = 1.90752519173728e-11 * n + s, e[t + 15] = 1.90752519173728e-11 * -o + i, r = .8660254037844387 * r * 1.907525191737281e-11, o = .5 * o * 1.907525191737281e-11 + i, e[t + 3] = r - o, e[t + 6] = r + o, n = .5 * n * 1.907525191737281e-11 - s, _ = .8660254037844387 * _ * 1.907525191737281e-11, e[t + 9] = n + _, e[t + 12] = n - _, t++;
}
}
- function C(e, t, a) {
- var n, s, r, i, o, _, l, f, c, u, h, b, p, m, v, d, g, w;
- r = a[17] - a[9], o = a[15] - a[11], _ = a[14] - a[12], l = a[0] + a[8], f = a[1] + a[7], c = a[2] + a[6], u = a[3] + a[5], e[t + 17] = l + c - u - (f - a[4]), s = (l + c - u) * S[19] + (f - a[4]), n = (r - o - _) * S[18], e[t + 5] = n + s, e[t + 6] = n - s, i = (a[16] - a[10]) * S[18], f = f * S[19] + a[4], n = r * S[12] + i + o * S[13] + _ * S[14], s = -l * S[16] + f - c * S[17] + u * S[15], e[t + 1] = n + s, e[t + 2] = n - s, n = r * S[13] - i - o * S[14] + _ * S[12], s = -l * S[17] + f - c * S[15] + u * S[16], e[t + 9] = n + s, e[t + 10] = n - s, n = r * S[14] - i + o * S[12] - _ * S[13], s = l * S[15] - f + c * S[16] - u * S[17], e[t + 13] = n + s, e[t + 14] = n - s, h = a[8] - a[0], p = a[6] - a[2], m = a[5] - a[3], v = a[17] + a[9], d = a[16] + a[10], g = a[15] + a[11], w = a[14] + a[12], e[t + 0] = v + g + w + (d + a[13]), n = (v + g + w) * S[19] - (d + a[13]), s = (h - p + m) * S[18], e[t + 11] = n + s, e[t + 12] = n - s, b = (a[7] - a[1]) * S[18], d = a[13] - d * S[19], n = v * S[15] - d + g * S[16] + w * S[17], s = h * S[14] + b + p * S[12] + m * S[13], e[t + 3] = n + s, e[t + 4] = n - s, n = -v * S[17] + d - g * S[15] - w * S[16], s = h * S[13] + b - p * S[14] - m * S[12], e[t + 7] = n + s, e[t + 8] = n - s, n = -v * S[16] + d - g * S[17] - w * S[15], s = h * S[12] - b + p * S[13] - m * S[14], e[t + 15] = n + s, e[t + 16] = n - s;
- }
this.mdct_sub48 = function (e, t, a) {
- for (var n = t, s = 286, r = 0; r < e.channels_out; r++) {
- for (var i = 0; i < e.mode_gr; i++) {
- for (var o, _ = e.l3_side.tt[i][r], l = _.xr, f = 0, c = e.sb_sample[r][1 - i], u = 0, h = 0; h < 9; h++) for (T(n, s, c[u]), T(n, s + 32, c[u + 1]), u += 2, s += 64, o = 1; o < 32; o += 2) c[u - 1][o] *= -1;
- for (o = 0; o < 32; o++, f += 18) {
- var b = _.block_type,
- p = e.sb_sample[r][i],
- m = e.sb_sample[r][1 - i];
- if (0 != _.mixed_block_flag && o < 2 && (b = 0), e.amp_filter[o] < 1e-12) we.fill(l, f + 0, f + 18, 0);else if (e.amp_filter[o] < 1 && me(), b == Ae.SHORT_TYPE) {
- for (var h = -3; h < 0; h++) {
- var v = A[Ae.SHORT_TYPE][h + 3];
- l[f + 3 * h + 9] = p[9 + h][B[o]] * v - p[8 - h][B[o]], l[f + 3 * h + 18] = p[14 - h][B[o]] * v + p[15 + h][B[o]], l[f + 3 * h + 10] = p[15 + h][B[o]] * v - p[14 - h][B[o]], l[f + 3 * h + 19] = m[2 - h][B[o]] * v + m[3 + h][B[o]], l[f + 3 * h + 11] = m[3 + h][B[o]] * v - m[2 - h][B[o]], l[f + 3 * h + 20] = m[8 - h][B[o]] * v + m[9 + h][B[o]];
+ for (var s, n, r, i, o, _, l, f, c, h, u, m, p, b, v, d, g, S, M, w, R, A = t, B = 286, k = 0; k < e.channels_out; k++) {
+ for (var y = 0; y < e.mode_gr; y++) {
+ for (var T, x = e.l3_side.tt[y][k], E = x.xr, P = 0, L = e.sb_sample[k][1 - y], I = 0, H = 0; H < 9; H++) for (W(A, B, L[I]), W(A, B + 32, L[I + 1]), I += 2, B += 64, T = 1; T < 32; T += 2) L[I - 1][T] *= -1;
+ for (T = 0; T < 32; T++, P += 18) {
+ var C = x.block_type,
+ V = e.sb_sample[k][y],
+ O = e.sb_sample[k][1 - y];
+ if (0 != x.mixed_block_flag && T < 2 && (C = 0), e.amp_filter[T] < 1e-12) ye.fill(E, P + 0, P + 18, 0);else {
+ if (e.amp_filter[T] < 1) for (H = 0; H < 18; H++) O[H][Q[T]] *= e.amp_filter[T];
+ if (C == Pe.SHORT_TYPE) {
+ for (H = -3; H < 0; H++) {
+ var N = z[Pe.SHORT_TYPE][H + 3];
+ E[P + 3 * H + 9] = V[9 + H][Q[T]] * N - V[8 - H][Q[T]], E[P + 3 * H + 18] = V[14 - H][Q[T]] * N + V[15 + H][Q[T]], E[P + 3 * H + 10] = V[15 + H][Q[T]] * N - V[14 - H][Q[T]], E[P + 3 * H + 19] = O[2 - H][Q[T]] * N + O[3 + H][Q[T]], E[P + 3 * H + 11] = O[3 + H][Q[T]] * N - O[2 - H][Q[T]], E[P + 3 * H + 20] = O[8 - H][Q[T]] * N + O[9 + H][Q[T]];
+ }
+ J(E, P);
+ } else {
+ var D = Be(18);
+ for (H = -9; H < 0; H++) {
+ var Y, X;
+ Y = z[C][H + 27] * O[H + 9][Q[T]] + z[C][H + 36] * O[8 - H][Q[T]], X = z[C][H + 9] * V[H + 9][Q[T]] - z[C][H + 18] * V[8 - H][Q[T]], D[H + 9] = Y - X * Z[3 + H + 9], D[H + 18] = Y * Z[3 + H + 9] + X;
+ }
+ s = E, n = P, R = w = M = S = g = d = v = b = p = m = u = h = c = f = l = _ = o = i = void 0, _ = (r = D)[17] - r[9], f = r[15] - r[11], c = r[14] - r[12], h = r[0] + r[8], u = r[1] + r[7], m = r[2] + r[6], p = r[3] + r[5], s[n + 17] = h + m - p - (u - r[4]), o = (h + m - p) * K[19] + (u - r[4]), i = (_ - f - c) * K[18], s[n + 5] = i + o, s[n + 6] = i - o, l = (r[16] - r[10]) * K[18], u = u * K[19] + r[4], i = _ * K[12] + l + f * K[13] + c * K[14], o = -h * K[16] + u - m * K[17] + p * K[15], s[n + 1] = i + o, s[n + 2] = i - o, i = _ * K[13] - l - f * K[14] + c * K[12], o = -h * K[17] + u - m * K[15] + p * K[16], s[n + 9] = i + o, s[n + 10] = i - o, i = _ * K[14] - l + f * K[12] - c * K[13], o = h * K[15] - u + m * K[16] - p * K[17], s[n + 13] = i + o, s[n + 14] = i - o, b = r[8] - r[0], d = r[6] - r[2], g = r[5] - r[3], S = r[17] + r[9], M = r[16] + r[10], w = r[15] + r[11], R = r[14] + r[12], s[n + 0] = S + w + R + (M + r[13]), i = (S + w + R) * K[19] - (M + r[13]), o = (b - d + g) * K[18], s[n + 11] = i + o, s[n + 12] = i - o, v = (r[7] - r[1]) * K[18], M = r[13] - M * K[19], i = S * K[15] - M + w * K[16] + R * K[17], o = b * K[14] + v + d * K[12] + g * K[13], s[n + 3] = i + o, s[n + 4] = i - o, i = -S * K[17] + M - w * K[15] - R * K[16], o = b * K[13] + v - d * K[14] - g * K[12], s[n + 7] = i + o, s[n + 8] = i - o, i = -S * K[16] + M - w * K[17] - R * K[15], o = b * K[12] - v + d * K[13] - g * K[14], s[n + 15] = i + o, s[n + 16] = i - o;
}
- E(l, f);
- } else {
- for (var d = de(18), h = -9; h < 0; h++) {
- var g, w;
- g = A[b][h + 27] * m[h + 9][B[o]] + A[b][h + 36] * m[8 - h][B[o]], w = A[b][h + 9] * p[h + 9][B[o]] - A[b][h + 18] * p[8 - h][B[o]], d[h + 9] = g - w * k[3 + h + 9], d[h + 18] = g * k[3 + h + 9] + w;
- }
- C(l, f, d);
}
- if (b != Ae.SHORT_TYPE && 0 != o) for (var h = 7; 0 <= h; --h) {
- var S, M;
- S = l[f + h] * R[20 + h] + l[f + -1 - h] * x[28 + h], M = l[f + h] * x[28 + h] - l[f + -1 - h] * R[20 + h], l[f + -1 - h] = S, l[f + h] = M;
+ if (C != Pe.SHORT_TYPE && 0 != T) for (H = 7; 0 <= H; --H) {
+ var q, F;
+ q = E[P + H] * G[20 + H] + E[P + -1 - H] * U[28 + H], F = E[P + H] * U[28 + H] - E[P + -1 - H] * G[20 + H], E[P + -1 - H] = q, E[P + H] = F;
}
}
}
- if (n = a, s = 286, 1 == e.mode_gr) for (var y = 0; y < 18; y++) I.arraycopy(e.sb_sample[r][1][y], 0, e.sb_sample[r][0][y], 0, 32);
+ if (A = a, B = 286, 1 == e.mode_gr) for (var j = 0; j < 18; j++) $.arraycopy(e.sb_sample[k][1][j], 0, e.sb_sample[k][0][j], 0, 32);
}
};
}();
- this.lame_encode_mp3_frame = function (e, t, a, n, s, r) {
+ this.lame_encode_mp3_frame = function (e, t, a, s, n, r) {
var i,
- o = E([2, 2]);
- o[0][0] = new L(), o[0][1] = new L(), o[1][0] = new L(), o[1][1] = new L();
+ o = O([2, 2]);
+ o[0][0] = new N(), o[0][1] = new N(), o[1][0] = new N(), o[1][1] = new N();
var _,
- l = E([2, 2]);
- l[0][0] = new L(), l[0][1] = new L(), l[1][0] = new L(), l[1][1] = new L();
+ l = O([2, 2]);
+ l[0][0] = new N(), l[0][1] = new N(), l[1][0] = new N(), l[1][1] = new N();
var f,
c,
- u,
- h = [null, null],
- b = e.internal_flags,
- p = ge([2, 4]),
- m = [[0, 0], [0, 0]],
- v = [[0, 0], [0, 0]];
- if (h[0] = t, h[1] = a, 0 == b.lame_encode_frame_init && function (e, t) {
+ h,
+ u = [null, null],
+ m = e.internal_flags,
+ p = ke([2, 4]),
+ b = [.5, .5],
+ v = [[0, 0], [0, 0]],
+ d = [[0, 0], [0, 0]];
+ if (u[0] = t, u[1] = a, 0 == m.lame_encode_frame_init && function (e, t) {
var a,
- n,
- s = e.internal_flags;
- if (0 == s.lame_encode_frame_init) {
+ s,
+ n = e.internal_flags;
+ if (0 == n.lame_encode_frame_init) {
var r,
i,
- o = de(2014),
- _ = de(2014);
- for (s.lame_encode_frame_init = 1, i = r = 0; r < 286 + 576 * (1 + s.mode_gr); ++r) r < 576 * s.mode_gr ? (o[r] = 0, 2 == s.channels_out && (_[r] = 0)) : (o[r] = t[0][i], 2 == s.channels_out && (_[r] = t[1][i]), ++i);
- for (n = 0; n < s.mode_gr; n++) for (a = 0; a < s.channels_out; a++) s.l3_side.tt[n][a].block_type = Ae.SHORT_TYPE;
- T.mdct_sub48(s, o, _);
+ o = Be(2014),
+ _ = Be(2014);
+ for (n.lame_encode_frame_init = 1, i = r = 0; r < 286 + 576 * (1 + n.mode_gr); ++r) r < 576 * n.mode_gr ? (o[r] = 0, 2 == n.channels_out && (_[r] = 0)) : (o[r] = t[0][i], 2 == n.channels_out && (_[r] = t[1][i]), ++i);
+ for (s = 0; s < n.mode_gr; s++) for (a = 0; a < n.channels_out; a++) n.l3_side.tt[s][a].block_type = Pe.SHORT_TYPE;
+ V.mdct_sub48(n, o, _);
}
- }(e, h), b.padding = 0, (b.slot_lag -= b.frac_SpF) < 0 && (b.slot_lag += e.out_samplerate, b.padding = 1), 0 != b.psymodel) {
- var d,
- g = [null, null],
- w = 0,
- S = ve(2);
- for (u = 0; u < b.mode_gr; u++) {
- for (c = 0; c < b.channels_out; c++) g[c] = h[c], w = 576 + 576 * u - Ae.FFTOFFSET;
- if (e.VBR == Me.vbr_mtrh || e.VBR == Me.vbr_mt ? me() : d = x.L3psycho_anal_ns(e, g, w, u, o, l, m[u], v[u], p[u], S), 0 != d) return -4;
- for (e.mode == ye.JOINT_STEREO && me(), c = 0; c < b.channels_out; c++) {
- var M = b.l3_side.tt[u][c];
- M.block_type = S[c], M.mixed_block_flag = 0;
+ }(e, u), m.padding = 0, (m.slot_lag -= m.frac_SpF) < 0 && (m.slot_lag += e.out_samplerate, m.padding = 1), 0 != m.psymodel) {
+ var g = [null, null],
+ S = 0,
+ M = Ae(2);
+ for (h = 0; h < m.mode_gr; h++) {
+ for (c = 0; c < m.channels_out; c++) g[c] = u[c], S = 576 + 576 * h - Pe.FFTOFFSET;
+ if (0 != (e.VBR == xe.vbr_mtrh || e.VBR == xe.vbr_mt ? I.L3psycho_anal_vbr(e, g, S, h, o, l, v[h], d[h], p[h], M) : I.L3psycho_anal_ns(e, g, S, h, o, l, v[h], d[h], p[h], M))) return -4;
+ for (e.mode == Ee.JOINT_STEREO && (b[h] = p[h][2] + p[h][3], 0 < b[h] && (b[h] = p[h][3] / b[h])), c = 0; c < m.channels_out; c++) {
+ var w = m.l3_side.tt[h][c];
+ w.block_type = M[c], w.mixed_block_flag = 0;
}
}
- } else me();
+ } else for (h = 0; h < m.mode_gr; h++) for (c = 0; c < m.channels_out; c++) m.l3_side.tt[h][c].block_type = Pe.NORM_TYPE, m.l3_side.tt[h][c].mixed_block_flag = 0, d[h][c] = v[h][c] = 700;
if (function (e) {
var t, a;
- if (0 == e.ATH.useAdjust) return e.ATH.adjust = 1;
- if (a = e.loudness_sq[0][0], t = e.loudness_sq[1][0], 2 == e.channels_out ? me() : (a += a, t += t), 2 == e.mode_gr && (a = Math.max(a, t)), a *= .5, .03125 < (a *= e.ATH.aaSensitivityP)) 1 <= e.ATH.adjust ? e.ATH.adjust = 1 : e.ATH.adjust < e.ATH.adjustLimit && (e.ATH.adjust = e.ATH.adjustLimit), e.ATH.adjustLimit = 1;else {
- var n = 31.98 * a + 625e-6;
- e.ATH.adjust >= n ? (e.ATH.adjust *= .075 * n + .925, e.ATH.adjust < n && (e.ATH.adjust = n)) : e.ATH.adjustLimit >= n ? e.ATH.adjust = n : e.ATH.adjust < e.ATH.adjustLimit && (e.ATH.adjust = e.ATH.adjustLimit), e.ATH.adjustLimit = n;
+ if (0 != e.ATH.useAdjust) {
+ if (a = e.loudness_sq[0][0], t = e.loudness_sq[1][0], 2 == e.channels_out ? (a += e.loudness_sq[0][1], t += e.loudness_sq[1][1]) : (a += a, t += t), 2 == e.mode_gr && (a = Math.max(a, t)), a *= .5, .03125 < (a *= e.ATH.aaSensitivityP)) 1 <= e.ATH.adjust ? e.ATH.adjust = 1 : e.ATH.adjust < e.ATH.adjustLimit && (e.ATH.adjust = e.ATH.adjustLimit), e.ATH.adjustLimit = 1;else {
+ var s = 31.98 * a + 625e-6;
+ e.ATH.adjust >= s ? (e.ATH.adjust *= .075 * s + .925, e.ATH.adjust < s && (e.ATH.adjust = s)) : e.ATH.adjustLimit >= s ? e.ATH.adjust = s : e.ATH.adjust < e.ATH.adjustLimit && (e.ATH.adjust = e.ATH.adjustLimit), e.ATH.adjustLimit = s;
+ }
+ } else e.ATH.adjust = 1;
+ }(m), V.mdct_sub48(m, u[0], u[1]), m.mode_ext = Pe.MPG_MD_LR_LR, e.force_ms) m.mode_ext = Pe.MPG_MD_MS_LR;else if (e.mode == Ee.JOINT_STEREO) {
+ var R = 0,
+ A = 0;
+ for (h = 0; h < m.mode_gr; h++) for (c = 0; c < m.channels_out; c++) R += d[h][c], A += v[h][c];
+ if (R <= 1 * A) {
+ var B = m.l3_side.tt[0],
+ k = m.l3_side.tt[m.mode_gr - 1];
+ B[0].block_type == B[1].block_type && k[0].block_type == k[1].block_type && (m.mode_ext = Pe.MPG_MD_MS_LR);
}
- }(b), T.mdct_sub48(b, h[0], h[1]), b.mode_ext = Ae.MPG_MD_LR_LR, e.force_ms ? b.mode_ext = Ae.MPG_MD_MS_LR : e.mode == ye.JOINT_STEREO && me(), b.mode_ext == k ? (_ = l, f = v) : (_ = o, f = m), e.analysis && null != b.pinfo && me(), e.VBR == Me.vbr_off || e.VBR == Me.vbr_abr) {
- var y, A;
- for (y = 0; y < 18; y++) b.nsPsy.pefirbuf[y] = b.nsPsy.pefirbuf[y + 1];
- for (u = A = 0; u < b.mode_gr; u++) for (c = 0; c < b.channels_out; c++) A += f[u][c];
- for (b.nsPsy.pefirbuf[18] = A, A = b.nsPsy.pefirbuf[9], y = 0; y < 9; y++) A += (b.nsPsy.pefirbuf[y] + b.nsPsy.pefirbuf[18 - y]) * Ae.fircoef[y];
- for (A = 3350 * b.mode_gr * b.channels_out / A, u = 0; u < b.mode_gr; u++) for (c = 0; c < b.channels_out; c++) f[u][c] *= A;
}
- return b.iteration_loop.iteration_loop(e, f, [.5, .5], _), R.format_bitstream(e), i = R.copy_buffer(b, n, s, r, 1), e.bWriteVbrTag && B.addVbrFrame(e), e.analysis && null != b.pinfo && me(), function (e) {
- var t, a;
- for (e.bitrate_stereoMode_Hist[e.bitrate_index][4]++, e.bitrate_stereoMode_Hist[15][4]++, 2 == e.channels_out && me(), t = 0; t < e.mode_gr; ++t) for (a = 0; a < e.channels_out; ++a) {
- var n = 0 | e.l3_side.tt[t][a].block_type;
- 0 != e.l3_side.tt[t][a].mixed_block_flag && (n = 4), e.bitrate_blockType_Hist[e.bitrate_index][n]++, e.bitrate_blockType_Hist[e.bitrate_index][5]++, e.bitrate_blockType_Hist[15][n]++, e.bitrate_blockType_Hist[15][5]++;
+ if (m.mode_ext == P ? (_ = l, f = d) : (_ = o, f = v), e.analysis && null != m.pinfo) for (h = 0; h < m.mode_gr; h++) for (c = 0; c < m.channels_out; c++) m.pinfo.ms_ratio[h] = m.ms_ratio[h], m.pinfo.ms_ener_ratio[h] = b[h], m.pinfo.blocktype[h][c] = m.l3_side.tt[h][c].block_type, m.pinfo.pe[h][c] = f[h][c], $.arraycopy(m.l3_side.tt[h][c].xr, 0, m.pinfo.xr[h][c], 0, 576), m.mode_ext == P && (m.pinfo.ers[h][c] = m.pinfo.ers[h][c + 2], $.arraycopy(m.pinfo.energy[h][c + 2], 0, m.pinfo.energy[h][c], 0, m.pinfo.energy[h][c].length));
+ if (e.VBR == xe.vbr_off || e.VBR == xe.vbr_abr) {
+ var y, T;
+ for (y = 0; y < 18; y++) m.nsPsy.pefirbuf[y] = m.nsPsy.pefirbuf[y + 1];
+ for (h = T = 0; h < m.mode_gr; h++) for (c = 0; c < m.channels_out; c++) T += f[h][c];
+ for (m.nsPsy.pefirbuf[18] = T, T = m.nsPsy.pefirbuf[9], y = 0; y < 9; y++) T += (m.nsPsy.pefirbuf[y] + m.nsPsy.pefirbuf[18 - y]) * Pe.fircoef[y];
+ for (T = 3350 * m.mode_gr * m.channels_out / T, h = 0; h < m.mode_gr; h++) for (c = 0; c < m.channels_out; c++) f[h][c] *= T;
+ }
+ if (m.iteration_loop.iteration_loop(e, f, b, _), L.format_bitstream(e), i = L.copy_buffer(m, s, n, r, 1), e.bWriteVbrTag && H.addVbrFrame(e), e.analysis && null != m.pinfo) {
+ for (c = 0; c < m.channels_out; c++) {
+ var x;
+ for (x = 0; x < E; x++) m.pinfo.pcmdata[c][x] = m.pinfo.pcmdata[c][x + e.framesize];
+ for (x = E; x < 1600; x++) m.pinfo.pcmdata[c][x] = u[c][x - E];
}
- }(b), i;
+ C.set_frame_pinfo(e, _);
+ }
+ return function (e) {
+ var t, a;
+ for (e.bitrate_stereoMode_Hist[e.bitrate_index][4]++, e.bitrate_stereoMode_Hist[15][4]++, 2 == e.channels_out && (e.bitrate_stereoMode_Hist[e.bitrate_index][e.mode_ext]++, e.bitrate_stereoMode_Hist[15][e.mode_ext]++), t = 0; t < e.mode_gr; ++t) for (a = 0; a < e.channels_out; ++a) {
+ var s = 0 | e.l3_side.tt[t][a].block_type;
+ 0 != e.l3_side.tt[t][a].mixed_block_flag && (s = 4), e.bitrate_blockType_Hist[e.bitrate_index][s]++, e.bitrate_blockType_Hist[e.bitrate_index][5]++, e.bitrate_blockType_Hist[15][s]++, e.bitrate_blockType_Hist[15][5]++;
+ }
+ }(m), i;
};
}
function i() {
- this.l = de(Ae.SBMAX_l), this.s = ge([Ae.SBMAX_s, 3]);
- var n = this;
+ this.l = Be(Pe.SBMAX_l), this.s = ke([Pe.SBMAX_s, 3]);
+ var s = this;
this.assign = function (e) {
- I.arraycopy(e.l, 0, n.l, 0, Ae.SBMAX_l);
- for (var t = 0; t < Ae.SBMAX_s; t++) for (var a = 0; a < 3; a++) n.s[t][a] = e.s[t][a];
+ $.arraycopy(e.l, 0, s.l, 0, Pe.SBMAX_l);
+ for (var t = 0; t < Pe.SBMAX_s; t++) for (var a = 0; a < 3; a++) s.s[t][a] = e.s[t][a];
};
}
- function j() {
+ function Z() {
var e = 40;
function t() {
- this.write_timing = 0, this.ptr = 0, this.buf = S(e);
+ this.write_timing = 0, this.ptr = 0, this.buf = A(e);
}
- this.Class_ID = 0, this.lame_encode_frame_init = 0, this.iteration_init_init = 0, this.fill_buffer_resample_init = 0, this.mfbuf = ge([2, j.MFSIZE]), this.mode_gr = 0, this.channels_in = 0, this.channels_out = 0, this.resample_ratio = 0, this.mf_samples_to_encode = 0, this.mf_size = 0, this.VBR_min_bitrate = 0, this.VBR_max_bitrate = 0, this.bitrate_index = 0, this.samplerate_index = 0, this.mode_ext = 0, this.lowpass1 = 0, this.lowpass2 = 0, this.highpass1 = 0, this.highpass2 = 0, this.noise_shaping = 0, this.noise_shaping_amp = 0, this.substep_shaping = 0, this.psymodel = 0, this.noise_shaping_stop = 0, this.subblock_gain = 0, this.use_best_huffman = 0, this.full_outer_loop = 0, this.l3_side = new function () {
- this.tt = [[null, null], [null, null]], this.main_data_begin = 0, this.private_bits = 0, this.resvDrain_pre = 0, this.resvDrain_post = 0, this.scfsi = [ve(4), ve(4)];
- for (var e = 0; e < 2; e++) for (var t = 0; t < 2; t++) this.tt[e][t] = new B();
- }(), this.ms_ratio = de(2), this.padding = 0, this.frac_SpF = 0, this.slot_lag = 0, this.tag_spec = null, this.nMusicCRC = 0, this.OldValue = ve(2), this.CurrentStep = ve(2), this.masking_lower = 0, this.bv_scf = ve(576), this.pseudohalf = ve(F.SFBMAX), this.sfb21_extra = !1, this.inbuf_old = new Array(2), this.blackfilt = new Array(2 * j.BPC + 1), this.itime = n(2), this.sideinfo_len = 0, this.sb_sample = ge([2, 2, 18, Ae.SBLIMIT]), this.amp_filter = de(32), this.header = new Array(j.MAX_HEADER_BUF), this.h_ptr = 0, this.w_ptr = 0, this.ancillary_flag = 0, this.ResvSize = 0, this.ResvMax = 0, this.scalefac_band = new r(), this.minval_l = de(Ae.CBANDS), this.minval_s = de(Ae.CBANDS), this.nb_1 = ge([4, Ae.CBANDS]), this.nb_2 = ge([4, Ae.CBANDS]), this.nb_s1 = ge([4, Ae.CBANDS]), this.nb_s2 = ge([4, Ae.CBANDS]), this.s3_ss = null, this.s3_ll = null, this.decay = 0, this.thm = new Array(4), this.en = new Array(4), this.tot_ener = de(4), this.loudness_sq = ge([2, 2]), this.loudness_sq_save = de(2), this.mld_l = de(Ae.SBMAX_l), this.mld_s = de(Ae.SBMAX_s), this.bm_l = ve(Ae.SBMAX_l), this.bo_l = ve(Ae.SBMAX_l), this.bm_s = ve(Ae.SBMAX_s), this.bo_s = ve(Ae.SBMAX_s), this.npart_l = 0, this.npart_s = 0, this.s3ind = w([Ae.CBANDS, 2]), this.s3ind_s = w([Ae.CBANDS, 2]), this.numlines_s = ve(Ae.CBANDS), this.numlines_l = ve(Ae.CBANDS), this.rnumlines_l = de(Ae.CBANDS), this.mld_cb_l = de(Ae.CBANDS), this.mld_cb_s = de(Ae.CBANDS), this.numlines_s_num1 = 0, this.numlines_l_num1 = 0, this.pe = de(4), this.ms_ratio_s_old = 0, this.ms_ratio_l_old = 0, this.ms_ener_ratio_old = 0, this.blocktype_old = ve(2), this.nsPsy = new function () {
- this.last_en_subshort = ge([4, 9]), this.lastAttacks = ve(4), this.pefirbuf = de(19), this.longfact = de(Ae.SBMAX_l), this.shortfact = de(Ae.SBMAX_s), this.attackthre = 0, this.attackthre_s = 0;
+ this.Class_ID = 0, this.lame_encode_frame_init = 0, this.iteration_init_init = 0, this.fill_buffer_resample_init = 0, this.mfbuf = ke([2, Z.MFSIZE]), this.mode_gr = 0, this.channels_in = 0, this.channels_out = 0, this.resample_ratio = 0, this.mf_samples_to_encode = 0, this.mf_size = 0, this.VBR_min_bitrate = 0, this.VBR_max_bitrate = 0, this.bitrate_index = 0, this.samplerate_index = 0, this.mode_ext = 0, this.lowpass1 = 0, this.lowpass2 = 0, this.highpass1 = 0, this.highpass2 = 0, this.noise_shaping = 0, this.noise_shaping_amp = 0, this.substep_shaping = 0, this.psymodel = 0, this.noise_shaping_stop = 0, this.subblock_gain = 0, this.use_best_huffman = 0, this.full_outer_loop = 0, this.l3_side = new function () {
+ this.tt = [[null, null], [null, null]], this.main_data_begin = 0, this.private_bits = 0, this.resvDrain_pre = 0, this.resvDrain_post = 0, this.scfsi = [Ae(4), Ae(4)];
+ for (var e = 0; e < 2; e++) for (var t = 0; t < 2; t++) this.tt[e][t] = new T();
+ }(), this.ms_ratio = Be(2), this.padding = 0, this.frac_SpF = 0, this.slot_lag = 0, this.tag_spec = null, this.nMusicCRC = 0, this.OldValue = Ae(2), this.CurrentStep = Ae(2), this.masking_lower = 0, this.bv_scf = Ae(576), this.pseudohalf = Ae(z.SFBMAX), this.sfb21_extra = !1, this.inbuf_old = new Array(2), this.blackfilt = new Array(2 * Z.BPC + 1), this.itime = s(2), this.sideinfo_len = 0, this.sb_sample = ke([2, 2, 18, Pe.SBLIMIT]), this.amp_filter = Be(32), this.header = new Array(Z.MAX_HEADER_BUF), this.h_ptr = 0, this.w_ptr = 0, this.ancillary_flag = 0, this.ResvSize = 0, this.ResvMax = 0, this.scalefac_band = new r(), this.minval_l = Be(Pe.CBANDS), this.minval_s = Be(Pe.CBANDS), this.nb_1 = ke([4, Pe.CBANDS]), this.nb_2 = ke([4, Pe.CBANDS]), this.nb_s1 = ke([4, Pe.CBANDS]), this.nb_s2 = ke([4, Pe.CBANDS]), this.s3_ss = null, this.s3_ll = null, this.decay = 0, this.thm = new Array(4), this.en = new Array(4), this.tot_ener = Be(4), this.loudness_sq = ke([2, 2]), this.loudness_sq_save = Be(2), this.mld_l = Be(Pe.SBMAX_l), this.mld_s = Be(Pe.SBMAX_s), this.bm_l = Ae(Pe.SBMAX_l), this.bo_l = Ae(Pe.SBMAX_l), this.bm_s = Ae(Pe.SBMAX_s), this.bo_s = Ae(Pe.SBMAX_s), this.npart_l = 0, this.npart_s = 0, this.s3ind = Y([Pe.CBANDS, 2]), this.s3ind_s = Y([Pe.CBANDS, 2]), this.numlines_s = Ae(Pe.CBANDS), this.numlines_l = Ae(Pe.CBANDS), this.rnumlines_l = Be(Pe.CBANDS), this.mld_cb_l = Be(Pe.CBANDS), this.mld_cb_s = Be(Pe.CBANDS), this.numlines_s_num1 = 0, this.numlines_l_num1 = 0, this.pe = Be(4), this.ms_ratio_s_old = 0, this.ms_ratio_l_old = 0, this.ms_ener_ratio_old = 0, this.blocktype_old = Ae(2), this.nsPsy = new function () {
+ this.last_en_subshort = ke([4, 9]), this.lastAttacks = Ae(4), this.pefirbuf = Be(19), this.longfact = Be(Pe.SBMAX_l), this.shortfact = Be(Pe.SBMAX_s), this.attackthre = 0, this.attackthre_s = 0;
}(), this.VBR_seek_table = new function () {
this.sum = 0, this.seen = 0, this.want = 0, this.pos = 0, this.size = 0, this.bag = null, this.nVbrNumFrames = 0, this.nBytesWritten = 0, this.TotalFrameSize = 0;
- }(), this.ATH = null, this.PSY = null, this.nogap_total = 0, this.nogap_current = 0, this.decode_on_the_fly = !0, this.findReplayGain = !0, this.findPeakSample = !0, this.PeakSample = 0, this.RadioGain = 0, this.AudiophileGain = 0, this.rgdata = null, this.noclipGainChange = 0, this.noclipScale = 0, this.bitrate_stereoMode_Hist = w([16, 5]), this.bitrate_blockType_Hist = w([16, 6]), this.pinfo = null, this.hip = null, this.in_buffer_nsamples = 0, this.in_buffer_0 = null, this.in_buffer_1 = null, this.iteration_loop = null;
+ }(), this.ATH = null, this.PSY = null, this.nogap_total = 0, this.nogap_current = 0, this.decode_on_the_fly = !0, this.findReplayGain = !0, this.findPeakSample = !0, this.PeakSample = 0, this.RadioGain = 0, this.AudiophileGain = 0, this.rgdata = null, this.noclipGainChange = 0, this.noclipScale = 0, this.bitrate_stereoMode_Hist = Y([16, 5]), this.bitrate_blockType_Hist = Y([16, 6]), this.pinfo = null, this.hip = null, this.in_buffer_nsamples = 0, this.in_buffer_0 = null, this.in_buffer_1 = null, this.iteration_loop = null;
for (var a = 0; a < this.en.length; a++) this.en[a] = new i();
- for (var a = 0; a < this.thm.length; a++) this.thm[a] = new i();
- for (var a = 0; a < this.header.length; a++) this.header[a] = new t();
+ for (a = 0; a < this.thm.length; a++) this.thm[a] = new i();
+ for (a = 0; a < this.header.length; a++) this.header[a] = new t();
}
- function X() {
- var k = new function () {
- var h = de(Ae.BLKSIZE),
- p = de(Ae.BLKSIZE_s / 2),
- x = [.9238795325112867, .3826834323650898, .9951847266721969, .0980171403295606, .9996988186962042, .02454122852291229, .9999811752826011, .006135884649154475];
- function m(e, t, a) {
- var n,
- s,
+ function G() {
+ var B = new function () {
+ var u = Be(Pe.BLKSIZE),
+ p = Be(Pe.BLKSIZE_s / 2),
+ y = [.9238795325112867, .3826834323650898, .9951847266721969, .0980171403295606, .9996988186962042, .02454122852291229, .9999811752826011, .006135884649154475];
+ function b(e, t, a) {
+ var s,
+ n,
r,
i = 0,
o = t + (a <<= 1);
- n = 4;
+ s = 4;
do {
- var _, l, f, c, u, h, b;
- for (b = n >> 1, h = (u = (c = n) << 1) + c, n = u << 1, r = (s = t) + b; S = e[s + 0] - e[s + c], w = e[s + 0] + e[s + c], k = e[s + u] - e[s + h], y = e[s + u] + e[s + h], e[s + u] = w - y, e[s + 0] = w + y, e[s + h] = S - k, e[s + c] = S + k, S = e[r + 0] - e[r + c], w = e[r + 0] + e[r + c], k = V.SQRT2 * e[r + h], y = V.SQRT2 * e[r + u], e[r + u] = w - y, e[r + 0] = w + y, e[r + h] = S - k, e[r + c] = S + k, r += n, (s += n) < o;);
- for (l = x[i + 0], _ = x[i + 1], f = 1; f < b; f++) {
- var p, m;
- p = 1 - 2 * _ * _, m = 2 * _ * l, s = t + f, r = t + c - f;
+ var _, l, f, c, h, u, m;
+ for (m = s >> 1, u = (h = (c = s) << 1) + c, s = h << 1, r = (n = t) + m; M = e[n + 0] - e[n + c], S = e[n + 0] + e[n + c], B = e[n + h] - e[n + u], R = e[n + h] + e[n + u], e[n + h] = S - R, e[n + 0] = S + R, e[n + u] = M - B, e[n + c] = M + B, M = e[r + 0] - e[r + c], S = e[r + 0] + e[r + c], B = ee.SQRT2 * e[r + u], R = ee.SQRT2 * e[r + h], e[r + h] = S - R, e[r + 0] = S + R, e[r + u] = M - B, e[r + c] = M + B, r += s, (n += s) < o;);
+ for (l = y[i + 0], _ = y[i + 1], f = 1; f < m; f++) {
+ var p, b;
+ p = 1 - 2 * _ * _, b = 2 * _ * l, n = t + f, r = t + c - f;
do {
- var v, d, g, w, S, M, y, A, k, R;
- d = m * e[s + c] - p * e[r + c], v = p * e[s + c] + m * e[r + c], S = e[s + 0] - v, w = e[s + 0] + v, M = e[r + 0] - d, g = e[r + 0] + d, d = m * e[s + h] - p * e[r + h], v = p * e[s + h] + m * e[r + h], k = e[s + u] - v, y = e[s + u] + v, R = e[r + u] - d, A = e[r + u] + d, d = _ * y - l * R, v = l * y + _ * R, e[s + u] = w - v, e[s + 0] = w + v, e[r + h] = M - d, e[r + c] = M + d, d = l * A - _ * k, v = _ * A + l * k, e[r + u] = g - v, e[r + 0] = g + v, e[s + h] = S - d, e[s + c] = S + d, r += n, s += n;
- } while (s < o);
- l = (p = l) * x[i + 0] - _ * x[i + 1], _ = p * x[i + 1] + _ * x[i + 0];
+ var v, d, g, S, M, w, R, A, B, k;
+ d = b * e[n + c] - p * e[r + c], v = p * e[n + c] + b * e[r + c], M = e[n + 0] - v, S = e[n + 0] + v, w = e[r + 0] - d, g = e[r + 0] + d, d = b * e[n + u] - p * e[r + u], v = p * e[n + u] + b * e[r + u], B = e[n + h] - v, R = e[n + h] + v, k = e[r + h] - d, A = e[r + h] + d, d = _ * R - l * k, v = l * R + _ * k, e[n + h] = S - v, e[n + 0] = S + v, e[r + u] = w - d, e[r + c] = w + d, d = l * A - _ * B, v = _ * A + l * B, e[r + h] = g - v, e[r + 0] = g + v, e[n + u] = M - d, e[n + c] = M + d, r += s, n += s;
+ } while (n < o);
+ l = (p = l) * y[i + 0] - _ * y[i + 1], _ = p * y[i + 1] + _ * y[i + 0];
}
i += 2;
- } while (n < a);
+ } while (s < a);
}
var v = [0, 128, 64, 192, 32, 160, 96, 224, 16, 144, 80, 208, 48, 176, 112, 240, 8, 136, 72, 200, 40, 168, 104, 232, 24, 152, 88, 216, 56, 184, 120, 248, 4, 132, 68, 196, 36, 164, 100, 228, 20, 148, 84, 212, 52, 180, 116, 244, 12, 140, 76, 204, 44, 172, 108, 236, 28, 156, 92, 220, 60, 188, 124, 252, 2, 130, 66, 194, 34, 162, 98, 226, 18, 146, 82, 210, 50, 178, 114, 242, 10, 138, 74, 202, 42, 170, 106, 234, 26, 154, 90, 218, 58, 186, 122, 250, 6, 134, 70, 198, 38, 166, 102, 230, 22, 150, 86, 214, 54, 182, 118, 246, 14, 142, 78, 206, 46, 174, 110, 238, 30, 158, 94, 222, 62, 190, 126, 254];
- this.fft_short = function (e, t, a, n, s) {
+ this.fft_short = function (e, t, a, s, n) {
for (var r = 0; r < 3; r++) {
- var i = Ae.BLKSIZE_s / 2,
+ var i = Pe.BLKSIZE_s / 2,
o = 65535 & 192 * (r + 1),
- _ = Ae.BLKSIZE_s / 8 - 1;
+ _ = Pe.BLKSIZE_s / 8 - 1;
do {
var l,
f,
c,
- u,
h,
- b = 255 & v[_ << 2];
- l = p[b] * n[a][s + b + o], h = p[127 - b] * n[a][s + b + o + 128], f = l - h, l += h, c = p[b + 64] * n[a][s + b + o + 64], h = p[63 - b] * n[a][s + b + o + 192], u = c - h, c += h, i -= 4, t[r][i + 0] = l + c, t[r][i + 2] = l - c, t[r][i + 1] = f + u, t[r][i + 3] = f - u, l = p[b + 1] * n[a][s + b + o + 1], h = p[126 - b] * n[a][s + b + o + 129], f = l - h, l += h, c = p[b + 65] * n[a][s + b + o + 65], h = p[62 - b] * n[a][s + b + o + 193], u = c - h, c += h, t[r][i + Ae.BLKSIZE_s / 2 + 0] = l + c, t[r][i + Ae.BLKSIZE_s / 2 + 2] = l - c, t[r][i + Ae.BLKSIZE_s / 2 + 1] = f + u, t[r][i + Ae.BLKSIZE_s / 2 + 3] = f - u;
+ u,
+ m = 255 & v[_ << 2];
+ f = (l = p[m] * s[a][n + m + o]) - (u = p[127 - m] * s[a][n + m + o + 128]), l += u, h = (c = p[m + 64] * s[a][n + m + o + 64]) - (u = p[63 - m] * s[a][n + m + o + 192]), c += u, i -= 4, t[r][i + 0] = l + c, t[r][i + 2] = l - c, t[r][i + 1] = f + h, t[r][i + 3] = f - h, f = (l = p[m + 1] * s[a][n + m + o + 1]) - (u = p[126 - m] * s[a][n + m + o + 129]), l += u, h = (c = p[m + 65] * s[a][n + m + o + 65]) - (u = p[62 - m] * s[a][n + m + o + 193]), c += u, t[r][i + Pe.BLKSIZE_s / 2 + 0] = l + c, t[r][i + Pe.BLKSIZE_s / 2 + 2] = l - c, t[r][i + Pe.BLKSIZE_s / 2 + 1] = f + h, t[r][i + Pe.BLKSIZE_s / 2 + 3] = f - h;
} while (0 <= --_);
- m(t[r], i, Ae.BLKSIZE_s / 2);
+ b(t[r], i, Pe.BLKSIZE_s / 2);
}
- }, this.fft_long = function (e, t, a, n, s) {
- var r = Ae.BLKSIZE / 8 - 1,
- i = Ae.BLKSIZE / 2;
+ }, this.fft_long = function (e, t, a, s, n) {
+ var r = Pe.BLKSIZE / 8 - 1,
+ i = Pe.BLKSIZE / 2;
do {
var o,
_,
l,
f,
c,
- u = 255 & v[r];
- o = h[u] * n[a][s + u], c = h[u + 512] * n[a][s + u + 512], _ = o - c, o += c, l = h[u + 256] * n[a][s + u + 256], c = h[u + 768] * n[a][s + u + 768], f = l - c, l += c, t[0 + (i -= 4)] = o + l, t[i + 2] = o - l, t[i + 1] = _ + f, t[i + 3] = _ - f, o = h[u + 1] * n[a][s + u + 1], c = h[u + 513] * n[a][s + u + 513], _ = o - c, o += c, l = h[u + 257] * n[a][s + u + 257], c = h[u + 769] * n[a][s + u + 769], f = l - c, l += c, t[i + Ae.BLKSIZE / 2 + 0] = o + l, t[i + Ae.BLKSIZE / 2 + 2] = o - l, t[i + Ae.BLKSIZE / 2 + 1] = _ + f, t[i + Ae.BLKSIZE / 2 + 3] = _ - f;
+ h = 255 & v[r];
+ _ = (o = u[h] * s[a][n + h]) - (c = u[h + 512] * s[a][n + h + 512]), o += c, f = (l = u[h + 256] * s[a][n + h + 256]) - (c = u[h + 768] * s[a][n + h + 768]), l += c, t[0 + (i -= 4)] = o + l, t[i + 2] = o - l, t[i + 1] = _ + f, t[i + 3] = _ - f, _ = (o = u[h + 1] * s[a][n + h + 1]) - (c = u[h + 513] * s[a][n + h + 513]), o += c, f = (l = u[h + 257] * s[a][n + h + 257]) - (c = u[h + 769] * s[a][n + h + 769]), l += c, t[i + Pe.BLKSIZE / 2 + 0] = o + l, t[i + Pe.BLKSIZE / 2 + 2] = o - l, t[i + Pe.BLKSIZE / 2 + 1] = _ + f, t[i + Pe.BLKSIZE / 2 + 3] = _ - f;
} while (0 <= --r);
- m(t, i, Ae.BLKSIZE / 2);
+ b(t, i, Pe.BLKSIZE / 2);
}, this.init_fft = function (e) {
- for (var t = 0; t < Ae.BLKSIZE; t++) h[t] = .42 - .5 * Math.cos(2 * Math.PI * (t + .5) / Ae.BLKSIZE) + .08 * Math.cos(4 * Math.PI * (t + .5) / Ae.BLKSIZE);
- for (var t = 0; t < Ae.BLKSIZE_s / 2; t++) p[t] = .5 * (1 - Math.cos(2 * Math.PI * (t + .5) / Ae.BLKSIZE_s));
+ for (var t = 0; t < Pe.BLKSIZE; t++) u[t] = .42 - .5 * Math.cos(2 * Math.PI * (t + .5) / Pe.BLKSIZE) + .08 * Math.cos(4 * Math.PI * (t + .5) / Pe.BLKSIZE);
+ for (t = 0; t < Pe.BLKSIZE_s / 2; t++) p[t] = .5 * (1 - Math.cos(2 * Math.PI * (t + .5) / Pe.BLKSIZE_s));
};
}(),
- R = 2.302585092994046,
+ k = 2.302585092994046,
+ _e = 2,
+ le = 16,
d = 2,
g = 16,
E = .34,
- v = 1 / 217621504 / (Ae.BLKSIZE / 2),
- w = .2302585093;
- function se(e, t, a, n, s, r, i, o, _, l, f) {
+ n = 1 / 217621504 / (Pe.BLKSIZE / 2),
+ fe = .3,
+ ce = 21,
+ S = .2302585093;
+ function M(e) {
+ return e;
+ }
+ function N(e, t) {
+ for (var a = 0, s = 0; s < Pe.BLKSIZE / 2; ++s) a += e[s] * t.ATH.eql_w[s];
+ return a *= n;
+ }
+ function he(e, t, a, s, n, r, i, o, _, l, f) {
var c = e.internal_flags;
- _ < 2 ? (k.fft_long(c, n[s], _, l, f), k.fft_short(c, r[i], _, l, f)) : 2 == _ && me(), t[0] = n[s + 0][0], t[0] *= t[0];
- for (var u = Ae.BLKSIZE / 2 - 1; 0 <= u; --u) {
- var h = n[s + 0][Ae.BLKSIZE / 2 - u],
- b = n[s + 0][Ae.BLKSIZE / 2 + u];
- t[Ae.BLKSIZE / 2 - u] = .5 * (h * h + b * b);
- }
- for (var p = 2; 0 <= p; --p) {
- a[p][0] = r[i + 0][p][0], a[p][0] *= a[p][0];
- for (var u = Ae.BLKSIZE_s / 2 - 1; 0 <= u; --u) {
- var h = r[i + 0][p][Ae.BLKSIZE_s / 2 - u],
- b = r[i + 0][p][Ae.BLKSIZE_s / 2 + u];
- a[p][Ae.BLKSIZE_s / 2 - u] = .5 * (h * h + b * b);
+ if (_ < 2) B.fft_long(c, s[n], _, l, f), B.fft_short(c, r[i], _, l, f);else if (2 == _) {
+ for (var h = Pe.BLKSIZE - 1; 0 <= h; --h) {
+ var u = s[n + 0][h],
+ m = s[n + 1][h];
+ s[n + 0][h] = (u + m) * ee.SQRT2 * .5, s[n + 1][h] = (u - m) * ee.SQRT2 * .5;
+ }
+ for (var p = 2; 0 <= p; --p) for (h = Pe.BLKSIZE_s - 1; 0 <= h; --h) {
+ u = r[i + 0][p][h], m = r[i + 1][p][h];
+ r[i + 0][p][h] = (u + m) * ee.SQRT2 * .5, r[i + 1][p][h] = (u - m) * ee.SQRT2 * .5;
}
}
- for (var m = 0, u = 11; u < Ae.HBLKSIZE; u++) m += t[u];
- c.tot_ener[_] = m, e.analysis && me(), 2 == e.athaa_loudapprox && _ < 2 && (c.loudness_sq[o][_] = c.loudness_sq_save[_], c.loudness_sq_save[_] = function (e, t) {
- for (var a = 0, n = 0; n < Ae.BLKSIZE / 2; ++n) a += e[n] * t.ATH.eql_w[n];
- return a *= v;
- }(t, c));
+ t[0] = M(s[n + 0][0]), t[0] *= t[0];
+ for (h = Pe.BLKSIZE / 2 - 1; 0 <= h; --h) {
+ var b = s[n + 0][Pe.BLKSIZE / 2 - h],
+ v = s[n + 0][Pe.BLKSIZE / 2 + h];
+ t[Pe.BLKSIZE / 2 - h] = M(.5 * (b * b + v * v));
+ }
+ for (p = 2; 0 <= p; --p) {
+ a[p][0] = r[i + 0][p][0], a[p][0] *= a[p][0];
+ for (h = Pe.BLKSIZE_s / 2 - 1; 0 <= h; --h) {
+ b = r[i + 0][p][Pe.BLKSIZE_s / 2 - h], v = r[i + 0][p][Pe.BLKSIZE_s / 2 + h];
+ a[p][Pe.BLKSIZE_s / 2 - h] = M(.5 * (b * b + v * v));
+ }
+ }
+ var d = 0;
+ for (h = 11; h < Pe.HBLKSIZE; h++) d += t[h];
+ if (c.tot_ener[_] = d, e.analysis) {
+ for (h = 0; h < Pe.HBLKSIZE; h++) c.pinfo.energy[o][_][h] = c.pinfo.energy_save[_][h], c.pinfo.energy_save[_][h] = t[h];
+ c.pinfo.pe[o][_] = c.pe[_];
+ }
+ 2 == e.athaa_loudapprox && _ < 2 && (c.loudness_sq[o][_] = c.loudness_sq_save[_], c.loudness_sq_save[_] = N(t, c));
}
- var x,
- B,
+ var y,
T,
- C = 8,
- I = 23,
- L = 15,
- re = [1, .79433, .63096, .63096, .63096, .63096, .63096, .25119, .11749],
- f = [3.3246 * 3.3246, 3.23837 * 3.23837, 9.9500500969, 9.0247369744, 8.1854926609, 7.0440875649, 2.46209 * 2.46209, 2.284 * 2.284, 4.4892710641, 1.96552 * 1.96552, 1.82335 * 1.82335, 1.69146 * 1.69146, 2.4621061921, 2.1508568964, 1.37074 * 1.37074, 1.31036 * 1.31036, 1.5691069696, 1.4555939904, 1.16203 * 1.16203, 1.2715945225, 1.09428 * 1.09428, 1.0659 * 1.0659, 1.0779838276, 1.0382591025, 1],
+ x,
+ P = 8,
+ L = 23,
+ I = 15,
+ ue = [1, .79433, .63096, .63096, .63096, .63096, .63096, .25119, .11749];
+ var f = [3.3246 * 3.3246, 3.23837 * 3.23837, 9.9500500969, 9.0247369744, 8.1854926609, 7.0440875649, 2.46209 * 2.46209, 2.284 * 2.284, 4.4892710641, 1.96552 * 1.96552, 1.82335 * 1.82335, 1.69146 * 1.69146, 2.4621061921, 2.1508568964, 1.37074 * 1.37074, 1.31036 * 1.31036, 1.5691069696, 1.4555939904, 1.16203 * 1.16203, 1.2715945225, 1.09428 * 1.09428, 1.0659 * 1.0659, 1.0779838276, 1.0382591025, 1],
c = [1.7782755904, 1.35879 * 1.35879, 1.38454 * 1.38454, 1.39497 * 1.39497, 1.40548 * 1.40548, 1.3537 * 1.3537, 1.6999465924, 1.22321 * 1.22321, 1.3169398564, 1],
- u = [5.5396212496, 2.29259 * 2.29259, 4.9868695969, 2.12675 * 2.12675, 2.02545 * 2.02545, 1.87894 * 1.87894, 1.74303 * 1.74303, 1.61695 * 1.61695, 2.2499700001, 1.39148 * 1.39148, 1.29083 * 1.29083, 1.19746 * 1.19746, 1.2339655056, 1.0779838276];
- function ie(e, t, a, n, s, r) {
+ h = [5.5396212496, 2.29259 * 2.29259, 4.9868695969, 2.12675 * 2.12675, 2.02545 * 2.02545, 1.87894 * 1.87894, 1.74303 * 1.74303, 1.61695 * 1.61695, 2.2499700001, 1.39148 * 1.39148, 1.29083 * 1.29083, 1.19746 * 1.19746, 1.2339655056, 1.0779838276];
+ function me(e, t, a, s, n, r) {
var i;
if (e < t) {
- if (!(t < e * B)) return e + t;
+ if (!(t < e * T)) return e + t;
i = t / e;
} else {
- if (t * B <= e) return e + t;
+ if (t * T <= e) return e + t;
i = e / t;
}
- if (e += t, n + 3 <= 6) {
- if (x <= i) return e;
- var o = 0 | V.FAST_LOG10_X(i, 16);
+ if (e += t, s + 3 <= 6) {
+ if (y <= i) return e;
+ var o = 0 | ee.FAST_LOG10_X(i, 16);
return e * c[o];
}
- var _,
- l,
- o = 0 | V.FAST_LOG10_X(i, 16);
- return t = 0 != r ? s.ATH.cb_s[a] * s.ATH.adjust : s.ATH.cb_l[a] * s.ATH.adjust, e < T * t ? t < e ? (_ = 1, o <= 13 && (_ = u[o]), l = V.FAST_LOG10_X(e / t, 10 / 15), e * ((f[o] - _) * l + _)) : 13 < o ? e : e * u[o] : e * f[o];
+ var _, l;
+ o = 0 | ee.FAST_LOG10_X(i, 16);
+ return t = 0 != r ? n.ATH.cb_s[a] * n.ATH.adjust : n.ATH.cb_l[a] * n.ATH.adjust, e < x * t ? t < e ? (_ = 1, o <= 13 && (_ = h[o]), l = ee.FAST_LOG10_X(e / t, 10 / 15), e * ((f[o] - _) * l + _)) : 13 < o ? e : e * h[o] : e * f[o];
}
- function oe(e, t, a, n, s) {
+ var r = [1.7782755904, 1.35879 * 1.35879, 1.38454 * 1.38454, 1.39497 * 1.39497, 1.40548 * 1.40548, 1.3537 * 1.3537, 1.6999465924, 1.22321 * 1.22321, 1.3169398564, 1];
+ function A(e, t, a) {
+ var s;
+ if (e < 0 && (e = 0), t < 0 && (t = 0), e <= 0) return t;
+ if (t <= 0) return e;
+ if (s = e < t ? t / e : e / t, -2 <= a && a <= 2) {
+ if (y <= s) return e + t;
+ var n = 0 | ee.FAST_LOG10_X(s, 16);
+ return (e + t) * r[n];
+ }
+ return s < T ? e + t : (e < t && (e = t), e);
+ }
+ function pe(e, t, a, s, n) {
var r,
i,
o = 0,
_ = 0;
- for (r = i = 0; r < Ae.SBMAX_s; ++i, ++r) {
+ for (r = i = 0; r < Pe.SBMAX_s; ++i, ++r) {
for (var l = e.bo_s[r], f = e.npart_s, c = l < f ? l : f; i < c;) o += t[i], _ += a[i], i++;
- if (e.en[n].s[r][s] = o, e.thm[n].s[r][s] = _, f <= i) {
+ if (e.en[s].s[r][n] = o, e.thm[s].s[r][n] = _, f <= i) {
++r;
break;
}
- var u = e.PSY.bo_s_weight[r],
- h = 1 - u;
- o = u * t[i], _ = u * a[i], e.en[n].s[r][s] += o, e.thm[n].s[r][s] += _, o = h * t[i], _ = h * a[i];
+ var h = e.PSY.bo_s_weight[r],
+ u = 1 - h;
+ o = h * t[i], _ = h * a[i], e.en[s].s[r][n] += o, e.thm[s].s[r][n] += _, o = u * t[i], _ = u * a[i];
}
- for (; r < Ae.SBMAX_s; ++r) e.en[n].s[r][s] = 0, e.thm[n].s[r][s] = 0;
+ for (; r < Pe.SBMAX_s; ++r) e.en[s].s[r][n] = 0, e.thm[s].s[r][n] = 0;
}
- function _e(e, t, a, n) {
- var s,
+ function be(e, t, a, s) {
+ var n,
r,
i = 0,
o = 0;
- for (s = r = 0; s < Ae.SBMAX_l; ++r, ++s) {
- for (var _ = e.bo_l[s], l = e.npart_l, f = _ < l ? _ : l; r < f;) i += t[r], o += a[r], r++;
- if (e.en[n].l[s] = i, e.thm[n].l[s] = o, l <= r) {
- ++s;
+ for (n = r = 0; n < Pe.SBMAX_l; ++r, ++n) {
+ for (var _ = e.bo_l[n], l = e.npart_l, f = _ < l ? _ : l; r < f;) i += t[r], o += a[r], r++;
+ if (e.en[s].l[n] = i, e.thm[s].l[n] = o, l <= r) {
+ ++n;
break;
}
- var c = e.PSY.bo_l_weight[s],
- u = 1 - c;
- i = c * t[r], o = c * a[r], e.en[n].l[s] += i, e.thm[n].l[s] += o, i = u * t[r], o = u * a[r];
+ var c = e.PSY.bo_l_weight[n],
+ h = 1 - c;
+ i = c * t[r], o = c * a[r], e.en[s].l[n] += i, e.thm[s].l[n] += o, i = h * t[r], o = h * a[r];
}
- for (; s < Ae.SBMAX_l; ++s) e.en[n].l[s] = 0, e.thm[n].l[s] = 0;
+ for (; n < Pe.SBMAX_l; ++n) e.en[s].l[n] = 0, e.thm[s].l[n] = 0;
}
- function le(e, t, a, n, s, r) {
+ function ve(e, t, a, s, n, r) {
var i,
o,
_ = e.internal_flags;
for (o = i = 0; o < _.npart_s; ++o) {
- for (var l = 0, f = 0, c = _.numlines_s[o], u = 0; u < c; ++u, ++i) {
- var h = t[r][i];
- l += h, f < h && (f = h);
+ for (var l = 0, f = 0, c = _.numlines_s[o], h = 0; h < c; ++h, ++i) {
+ var u = t[r][i];
+ l += u, f < u && (f = u);
}
a[o] = l;
}
for (i = o = 0; o < _.npart_s; o++) {
- var b = _.s3ind_s[o][0],
- p = _.s3_ss[i++] * a[b];
- for (++b; b <= _.s3ind_s[o][1];) p += _.s3_ss[i] * a[b], ++i, ++b;
- var m = d * _.nb_s1[s][o];
- if (n[o] = Math.min(p, m), _.blocktype_old[1 & s] == Ae.SHORT_TYPE) {
- var m = g * _.nb_s2[s][o],
- v = n[o];
- n[o] = Math.min(m, v);
+ var m = _.s3ind_s[o][0],
+ p = _.s3_ss[i++] * a[m];
+ for (++m; m <= _.s3ind_s[o][1];) p += _.s3_ss[i] * a[m], ++i, ++m;
+ var b = d * _.nb_s1[n][o];
+ if (s[o] = Math.min(p, b), _.blocktype_old[1 & n] == Pe.SHORT_TYPE) {
+ b = g * _.nb_s2[n][o];
+ var v = s[o];
+ s[o] = Math.min(b, v);
}
- _.nb_s2[s][o] = _.nb_s1[s][o], _.nb_s1[s][o] = p;
+ _.nb_s2[n][o] = _.nb_s1[n][o], _.nb_s1[n][o] = p;
}
- for (; o <= Ae.CBANDS; ++o) a[o] = 0, n[o] = 0;
+ for (; o <= Pe.CBANDS; ++o) a[o] = 0, s[o] = 0;
}
- function fe(e, t, a) {
+ function de(e, t, a) {
return 1 <= a ? e : a <= 0 ? t : 0 < t ? Math.pow(e / t, a) * t : 0;
}
var _ = [11.8, 13.6, 17.2, 32, 46.5, 51.3, 57.5, 67.1, 71.5, 84.6, 97.6, 130];
- function ce(e, t) {
- for (var a = 309.07, n = 0; n < Ae.SBMAX_s - 1; n++) for (var s = 0; s < 3; s++) {
- var r = e.thm.s[n][s];
+ function ge(e, t) {
+ for (var a = 309.07, s = 0; s < Pe.SBMAX_s - 1; s++) for (var n = 0; n < 3; n++) {
+ var r = e.thm.s[s][n];
if (0 < r) {
var i = r * t,
- o = e.en.s[n][s];
- i < o && (a += 1e10 * i < o ? _[n] * (10 * R) : _[n] * V.FAST_LOG10(o / i));
+ o = e.en.s[s][n];
+ i < o && (a += 1e10 * i < o ? _[s] * (10 * k) : _[s] * ee.FAST_LOG10(o / i));
}
}
return a;
}
var o = [6.8, 5.8, 5.8, 6.4, 6.5, 9.9, 12.1, 14.4, 15, 18.9, 21.6, 26.9, 34.2, 40.2, 46.8, 56.5, 60.7, 73.9, 85.7, 93.4, 126.1];
- function ue(e, t) {
- for (var a = 281.0575, n = 0; n < Ae.SBMAX_l - 1; n++) {
- var s = e.thm.l[n];
- if (0 < s) {
- var r = s * t,
- i = e.en.l[n];
- r < i && (a += 1e10 * r < i ? o[n] * (10 * R) : o[n] * V.FAST_LOG10(i / r));
+ function Se(e, t) {
+ for (var a = 281.0575, s = 0; s < Pe.SBMAX_l - 1; s++) {
+ var n = e.thm.l[s];
+ if (0 < n) {
+ var r = n * t,
+ i = e.en.l[s];
+ r < i && (a += 1e10 * r < i ? o[s] * (10 * k) : o[s] * ee.FAST_LOG10(i / r));
}
}
return a;
}
- function he(e, t, a, n, s) {
+ function Me(e, t, a, s, n) {
var r, i;
for (r = i = 0; r < e.npart_l; ++r) {
var o,
@@ -36496,495 +36399,894 @@ src: recorder-core.js,engine/mp3.js,engine/mp3-engine.js
var f = t[i];
_ += f, l < f && (l = f);
}
- a[r] = _, n[r] = l, s[r] = _ * e.rnumlines_l[r];
+ a[r] = _, s[r] = l, n[r] = _ * e.rnumlines_l[r];
}
}
- function be(e, t, a, n) {
- var s = re.length - 1,
+ function we(e, t, a, s) {
+ var n = ue.length - 1,
r = 0,
i = a[r] + a[r + 1];
- if (0 < i) {
- var o = t[r];
- o < t[r + 1] && (o = t[r + 1]);
- var _ = 0 | (i = 20 * (2 * o - i) / (i * (e.numlines_l[r] + e.numlines_l[r + 1] - 1)));
- s < _ && (_ = s), n[r] = _;
- } else n[r] = 0;
- for (r = 1; r < e.npart_l - 1; r++) if (0 < (i = a[r - 1] + a[r] + a[r + 1])) {
- var o = t[r - 1];
- o < t[r] && (o = t[r]), o < t[r + 1] && (o = t[r + 1]);
- var _ = 0 | (i = 20 * (3 * o - i) / (i * (e.numlines_l[r - 1] + e.numlines_l[r] + e.numlines_l[r + 1] - 1)));
- s < _ && (_ = s), n[r] = _;
- } else n[r] = 0;
- if (0 < (i = a[r - 1] + a[r])) {
- var o = t[r - 1];
- o < t[r] && (o = t[r]);
- var _ = 0 | (i = 20 * (2 * o - i) / (i * (e.numlines_l[r - 1] + e.numlines_l[r] - 1)));
- s < _ && (_ = s), n[r] = _;
- } else n[r] = 0;
+ 0 < i ? ((o = t[r]) < t[r + 1] && (o = t[r + 1]), n < (_ = 0 | (i = 20 * (2 * o - i) / (i * (e.numlines_l[r] + e.numlines_l[r + 1] - 1)))) && (_ = n), s[r] = _) : s[r] = 0;
+ for (r = 1; r < e.npart_l - 1; r++) {
+ var o, _;
+ if (0 < (i = a[r - 1] + a[r] + a[r + 1])) (o = t[r - 1]) < t[r] && (o = t[r]), o < t[r + 1] && (o = t[r + 1]), n < (_ = 0 | (i = 20 * (3 * o - i) / (i * (e.numlines_l[r - 1] + e.numlines_l[r] + e.numlines_l[r + 1] - 1)))) && (_ = n), s[r] = _;else s[r] = 0;
+ }
+ 0 < (i = a[r - 1] + a[r]) ? ((o = t[r - 1]) < t[r] && (o = t[r]), n < (_ = 0 | (i = 20 * (2 * o - i) / (i * (e.numlines_l[r - 1] + e.numlines_l[r] - 1)))) && (_ = n), s[r] = _) : s[r] = 0;
}
- var pe = [-1.730326e-17, -.01703172, -1.349528e-17, .0418072, -6.73278e-17, -.0876324, -3.0835e-17, .1863476, -1.104424e-16, -.627638];
- function P(e) {
+ var Re = [-1.730326e-17, -.01703172, -1.349528e-17, .0418072, -6.73278e-17, -.0876324, -3.0835e-17, .1863476, -1.104424e-16, -.627638];
+ function D(e, t, a, s, n, r, i, o) {
+ var _ = e.internal_flags;
+ if (s < 2) B.fft_long(_, i[o], s, t, a);else if (2 == s) for (var l = Pe.BLKSIZE - 1; 0 <= l; --l) {
+ var f = i[o + 0][l],
+ c = i[o + 1][l];
+ i[o + 0][l] = (f + c) * ee.SQRT2 * .5, i[o + 1][l] = (f - c) * ee.SQRT2 * .5;
+ }
+ r[0] = M(i[o + 0][0]), r[0] *= r[0];
+ for (l = Pe.BLKSIZE / 2 - 1; 0 <= l; --l) {
+ var h = i[o + 0][Pe.BLKSIZE / 2 - l],
+ u = i[o + 0][Pe.BLKSIZE / 2 + l];
+ r[Pe.BLKSIZE / 2 - l] = M(.5 * (h * h + u * u));
+ }
+ var m = 0;
+ for (l = 11; l < Pe.HBLKSIZE; l++) m += r[l];
+ if (_.tot_ener[s] = m, e.analysis) {
+ for (l = 0; l < Pe.HBLKSIZE; l++) _.pinfo.energy[n][s][l] = _.pinfo.energy_save[s][l], _.pinfo.energy_save[s][l] = r[l];
+ _.pinfo.pe[n][s] = _.pe[s];
+ }
+ }
+ function Y(e, t, a, s, n, r, i, o) {
+ var _ = e.internal_flags;
+ if (0 == n && s < 2 && B.fft_short(_, i[o], s, t, a), 2 == s) for (var l = Pe.BLKSIZE_s - 1; 0 <= l; --l) {
+ var f = i[o + 0][n][l],
+ c = i[o + 1][n][l];
+ i[o + 0][n][l] = (f + c) * ee.SQRT2 * .5, i[o + 1][n][l] = (f - c) * ee.SQRT2 * .5;
+ }
+ r[n][0] = i[o + 0][n][0], r[n][0] *= r[n][0];
+ for (l = Pe.BLKSIZE_s / 2 - 1; 0 <= l; --l) {
+ var h = i[o + 0][n][Pe.BLKSIZE_s / 2 - l],
+ u = i[o + 0][n][Pe.BLKSIZE_s / 2 + l];
+ r[n][Pe.BLKSIZE_s / 2 - l] = M(.5 * (h * h + u * u));
+ }
+ }
+ this.L3psycho_anal_ns = function (e, t, a, s, n, r, i, o, _, l) {
+ var f,
+ c,
+ h,
+ u,
+ m,
+ p,
+ b,
+ v,
+ d,
+ g,
+ S = e.internal_flags,
+ M = ke([2, Pe.BLKSIZE]),
+ w = ke([2, 3, Pe.BLKSIZE_s]),
+ R = Be(Pe.CBANDS + 1),
+ A = Be(Pe.CBANDS + 1),
+ B = Be(Pe.CBANDS + 2),
+ k = Ae(2),
+ y = Ae(2),
+ T = ke([2, 576]),
+ x = Ae(Pe.CBANDS + 2),
+ E = Ae(Pe.CBANDS + 2);
+ for (ye.fill(E, 0), f = S.channels_out, e.mode == Ee.JOINT_STEREO && (f = 4), d = e.VBR == xe.vbr_off ? 0 == S.ResvMax ? 0 : S.ResvSize / S.ResvMax * .5 : e.VBR == xe.vbr_rh || e.VBR == xe.vbr_mtrh || e.VBR == xe.vbr_mt ? .6 : 1, c = 0; c < S.channels_out; c++) {
+ var P = t[c],
+ L = a + 576 - 350 - ce + 192;
+ for (u = 0; u < 576; u++) {
+ var I, H;
+ for (I = P[L + u + 10], m = H = 0; m < (ce - 1) / 2 - 1; m += 2) I += Re[m] * (P[L + u + m] + P[L + u + ce - m]), H += Re[m + 1] * (P[L + u + m + 1] + P[L + u + ce - m - 1]);
+ T[c][u] = I + H;
+ }
+ n[s][c].en.assign(S.en[c]), n[s][c].thm.assign(S.thm[c]), 2 < f && (r[s][c].en.assign(S.en[c + 2]), r[s][c].thm.assign(S.thm[c + 2]));
+ }
+ for (c = 0; c < f; c++) {
+ var C,
+ V = Be(12),
+ O = [0, 0, 0, 0],
+ N = Be(12),
+ D = 1,
+ Y = Be(Pe.CBANDS),
+ X = Be(Pe.CBANDS),
+ q = [0, 0, 0, 0],
+ F = Be(Pe.HBLKSIZE),
+ j = ke([3, Pe.HBLKSIZE_s]);
+ for (u = 0; u < 3; u++) V[u] = S.nsPsy.last_en_subshort[c][u + 6], N[u] = V[u] / S.nsPsy.last_en_subshort[c][u + 4], O[0] += V[u];
+ if (2 == c) for (u = 0; u < 576; u++) {
+ var z, Z;
+ z = T[0][u], Z = T[1][u], T[0][u] = z + Z, T[1][u] = z - Z;
+ }
+ var K = T[1 & c],
+ G = 0;
+ for (u = 0; u < 9; u++) {
+ for (var U = G + 64, Q = 1; G < U; G++) Q < Math.abs(K[G]) && (Q = Math.abs(K[G]));
+ S.nsPsy.last_en_subshort[c][u] = V[u + 3] = Q, O[1 + u / 3] += Q, Q > V[u + 3 - 2] ? Q /= V[u + 3 - 2] : Q = V[u + 3 - 2] > 10 * Q ? V[u + 3 - 2] / (10 * Q) : 0, N[u + 3] = Q;
+ }
+ if (e.analysis) {
+ var W = N[0];
+ for (u = 1; u < 12; u++) W < N[u] && (W = N[u]);
+ S.pinfo.ers[s][c] = S.pinfo.ers_save[c], S.pinfo.ers_save[c] = W;
+ }
+ for (C = 3 == c ? S.nsPsy.attackthre_s : S.nsPsy.attackthre, u = 0; u < 12; u++) 0 == q[u / 3] && N[u] > C && (q[u / 3] = u % 3 + 1);
+ for (u = 1; u < 4; u++) {
+ (O[u - 1] > O[u] ? O[u - 1] / O[u] : O[u] / O[u - 1]) < 1.7 && (q[u] = 0, 1 == u && (q[0] = 0));
+ }
+ for (0 != q[0] && 0 != S.nsPsy.lastAttacks[c] && (q[0] = 0), 3 != S.nsPsy.lastAttacks[c] && q[0] + q[1] + q[2] + q[3] == 0 || ((D = 0) != q[1] && 0 != q[0] && (q[1] = 0), 0 != q[2] && 0 != q[1] && (q[2] = 0), 0 != q[3] && 0 != q[2] && (q[3] = 0)), c < 2 ? y[c] = D : 0 == D && (y[0] = y[1] = 0), _[c] = S.tot_ener[c], he(e, F, j, M, 1 & c, w, 1 & c, s, c, t, a), Me(S, F, R, Y, X), we(S, Y, X, x), v = 0; v < 3; v++) {
+ var J, $;
+ for (ve(e, j, A, B, c, v), pe(S, A, B, c, v), b = 0; b < Pe.SBMAX_s; b++) {
+ if ($ = S.thm[c].s[b][v], $ *= .8, 2 <= q[v] || 1 == q[v + 1]) {
+ var ee = 0 != v ? v - 1 : 2;
+ Q = de(S.thm[c].s[b][ee], $, .6 * d);
+ $ = Math.min($, Q);
+ }
+ if (1 == q[v]) {
+ ee = 0 != v ? v - 1 : 2, Q = de(S.thm[c].s[b][ee], $, fe * d);
+ $ = Math.min($, Q);
+ } else if (0 != v && 3 == q[v - 1] || 0 == v && 3 == S.nsPsy.lastAttacks[c]) {
+ ee = 2 != v ? v + 1 : 0, Q = de(S.thm[c].s[b][ee], $, fe * d);
+ $ = Math.min($, Q);
+ }
+ J = V[3 * v + 3] + V[3 * v + 4] + V[3 * v + 5], 6 * V[3 * v + 5] < J && ($ *= .5, 6 * V[3 * v + 4] < J && ($ *= .5)), S.thm[c].s[b][v] = $;
+ }
+ }
+ for (S.nsPsy.lastAttacks[c] = q[2], h = p = 0; h < S.npart_l; h++) {
+ for (var te = S.s3ind[h][0], ae = R[te] * ue[x[te]], se = S.s3_ll[p++] * ae; ++te <= S.s3ind[h][1];) ae = R[te] * ue[x[te]], se = me(se, S.s3_ll[p++] * ae, te, te - h, S, 0);
+ se *= .158489319246111, S.blocktype_old[1 & c] == Pe.SHORT_TYPE ? B[h] = se : B[h] = de(Math.min(se, Math.min(_e * S.nb_1[c][h], le * S.nb_2[c][h])), se, d), S.nb_2[c][h] = S.nb_1[c][h], S.nb_1[c][h] = se;
+ }
+ for (; h <= Pe.CBANDS; ++h) R[h] = 0, B[h] = 0;
+ be(S, R, B, c);
+ }
+ (e.mode != Ee.STEREO && e.mode != Ee.JOINT_STEREO || 0 < e.interChRatio && function (e, t) {
+ var a = e.internal_flags;
+ if (1 < a.channels_out) {
+ for (var s = 0; s < Pe.SBMAX_l; s++) {
+ var n = a.thm[0].l[s],
+ r = a.thm[1].l[s];
+ a.thm[0].l[s] += r * t, a.thm[1].l[s] += n * t;
+ }
+ for (s = 0; s < Pe.SBMAX_s; s++) for (var i = 0; i < 3; i++) n = a.thm[0].s[s][i], r = a.thm[1].s[s][i], a.thm[0].s[s][i] += r * t, a.thm[1].s[s][i] += n * t;
+ }
+ }(e, e.interChRatio), e.mode == Ee.JOINT_STEREO) && (!function (e) {
+ for (var t = 0; t < Pe.SBMAX_l; t++) if (!(e.thm[0].l[t] > 1.58 * e.thm[1].l[t] || e.thm[1].l[t] > 1.58 * e.thm[0].l[t])) {
+ var a = e.mld_l[t] * e.en[3].l[t],
+ s = Math.max(e.thm[2].l[t], Math.min(e.thm[3].l[t], a));
+ a = e.mld_l[t] * e.en[2].l[t];
+ var n = Math.max(e.thm[3].l[t], Math.min(e.thm[2].l[t], a));
+ e.thm[2].l[t] = s, e.thm[3].l[t] = n;
+ }
+ for (t = 0; t < Pe.SBMAX_s; t++) for (var r = 0; r < 3; r++) e.thm[0].s[t][r] > 1.58 * e.thm[1].s[t][r] || e.thm[1].s[t][r] > 1.58 * e.thm[0].s[t][r] || (a = e.mld_s[t] * e.en[3].s[t][r], s = Math.max(e.thm[2].s[t][r], Math.min(e.thm[3].s[t][r], a)), a = e.mld_s[t] * e.en[2].s[t][r], n = Math.max(e.thm[3].s[t][r], Math.min(e.thm[2].s[t][r], a)), e.thm[2].s[t][r] = s, e.thm[3].s[t][r] = n);
+ }(S), g = e.msfix, 0 < Math.abs(g) && function (e, t, a) {
+ var s = t,
+ n = Math.pow(10, a);
+ t *= 2, s *= 2;
+ for (var r = 0; r < Pe.SBMAX_l; r++) f = e.ATH.cb_l[e.bm_l[r]] * n, (o = Math.min(Math.max(e.thm[0].l[r], f), Math.max(e.thm[1].l[r], f))) * t < (_ = Math.max(e.thm[2].l[r], f)) + (l = Math.max(e.thm[3].l[r], f)) && (_ *= c = o * s / (_ + l), l *= c), e.thm[2].l[r] = Math.min(_, e.thm[2].l[r]), e.thm[3].l[r] = Math.min(l, e.thm[3].l[r]);
+ for (n *= Pe.BLKSIZE_s / Pe.BLKSIZE, r = 0; r < Pe.SBMAX_s; r++) for (var i = 0; i < 3; i++) {
+ var o, _, l, f, c;
+ f = e.ATH.cb_s[e.bm_s[r]] * n, (o = Math.min(Math.max(e.thm[0].s[r][i], f), Math.max(e.thm[1].s[r][i], f))) * t < (_ = Math.max(e.thm[2].s[r][i], f)) + (l = Math.max(e.thm[3].s[r][i], f)) && (_ *= c = o * t / (_ + l), l *= c), e.thm[2].s[r][i] = Math.min(e.thm[2].s[r][i], _), e.thm[3].s[r][i] = Math.min(e.thm[3].s[r][i], l);
+ }
+ }(S, g, e.ATHlower * S.ATH.adjust));
+ for (function (e, t, a, s) {
+ var n = e.internal_flags;
+ e.short_blocks != Te.short_block_coupled || 0 != t[0] && 0 != t[1] || (t[0] = t[1] = 0);
+ for (var r = 0; r < n.channels_out; r++) s[r] = Pe.NORM_TYPE, e.short_blocks == Te.short_block_dispensed && (t[r] = 1), e.short_blocks == Te.short_block_forced && (t[r] = 0), 0 != t[r] ? n.blocktype_old[r] == Pe.SHORT_TYPE && (s[r] = Pe.STOP_TYPE) : (s[r] = Pe.SHORT_TYPE, n.blocktype_old[r] == Pe.NORM_TYPE && (n.blocktype_old[r] = Pe.START_TYPE), n.blocktype_old[r] == Pe.STOP_TYPE && (n.blocktype_old[r] = Pe.SHORT_TYPE)), a[r] = n.blocktype_old[r], n.blocktype_old[r] = s[r];
+ }(e, y, l, k), c = 0; c < f; c++) {
+ var ne,
+ re,
+ ie,
+ oe = 0;
+ 1 < c ? (ne = o, oe = -2, re = Pe.NORM_TYPE, l[0] != Pe.SHORT_TYPE && l[1] != Pe.SHORT_TYPE || (re = Pe.SHORT_TYPE), ie = r[s][c - 2]) : (ne = i, oe = 0, re = l[c], ie = n[s][c]), ne[oe + c] = re == Pe.SHORT_TYPE ? ge(ie, S.masking_lower) : Se(ie, S.masking_lower), e.analysis && (S.pinfo.pe[s][c] = ne[oe + c]);
+ }
+ return 0;
+ };
+ var X = [-1.730326e-17, -.01703172, -1.349528e-17, .0418072, -6.73278e-17, -.0876324, -3.0835e-17, .1863476, -1.104424e-16, -.627638];
+ function q(e, t, a) {
+ if (0 == a) for (var s = 0; s < e.npart_s; s++) e.nb_s2[t][s] = e.nb_s1[t][s], e.nb_s1[t][s] = 0;
+ }
+ function F(e, t) {
+ for (var a = 0; a < e.npart_l; a++) e.nb_2[t][a] = e.nb_1[t][a], e.nb_1[t][a] = 0;
+ }
+ function j(e, t, a, s, n, r) {
+ var i,
+ o,
+ _,
+ l = e.internal_flags,
+ f = new float[Pe.CBANDS](),
+ c = Be(Pe.CBANDS),
+ h = new int[Pe.CBANDS]();
+ for (_ = o = 0; _ < l.npart_s; ++_) {
+ var u = 0,
+ m = 0,
+ p = l.numlines_s[_];
+ for (i = 0; i < p; ++i, ++o) {
+ var b = t[r][o];
+ u += b, m < b && (m = b);
+ }
+ a[_] = u, f[_] = m, c[_] = u / p;
+ }
+ for (; _ < Pe.CBANDS; ++_) f[_] = 0, c[_] = 0;
+ for (function (e, t, a, s) {
+ var n = ue.length - 1,
+ r = 0,
+ i = a[r] + a[r + 1];
+ for (0 < i ? ((o = t[r]) < t[r + 1] && (o = t[r + 1]), n < (_ = 0 | (i = 20 * (2 * o - i) / (i * (e.numlines_s[r] + e.numlines_s[r + 1] - 1)))) && (_ = n), s[r] = _) : s[r] = 0, r = 1; r < e.npart_s - 1; r++) {
+ var o, _;
+ 0 < (i = a[r - 1] + a[r] + a[r + 1]) ? ((o = t[r - 1]) < t[r] && (o = t[r]), o < t[r + 1] && (o = t[r + 1]), n < (_ = 0 | (i = 20 * (3 * o - i) / (i * (e.numlines_s[r - 1] + e.numlines_s[r] + e.numlines_s[r + 1] - 1)))) && (_ = n), s[r] = _) : s[r] = 0;
+ }
+ 0 < (i = a[r - 1] + a[r]) ? ((o = t[r - 1]) < t[r] && (o = t[r]), n < (_ = 0 | (i = 20 * (2 * o - i) / (i * (e.numlines_s[r - 1] + e.numlines_s[r] - 1)))) && (_ = n), s[r] = _) : s[r] = 0;
+ }(l, f, c, h), o = _ = 0; _ < l.npart_s; _++) {
+ var v,
+ d,
+ g,
+ S,
+ M,
+ w = l.s3ind_s[_][0],
+ R = l.s3ind_s[_][1];
+ for (v = h[w], d = 1, S = l.s3_ss[o] * a[w] * ue[h[w]], ++o, ++w; w <= R;) v += h[w], d += 1, S = A(S, g = l.s3_ss[o] * a[w] * ue[h[w]], w - _), ++o, ++w;
+ S *= M = .5 * ue[v = (1 + 2 * v) / (2 * d)], s[_] = S, l.nb_s2[n][_] = l.nb_s1[n][_], l.nb_s1[n][_] = S, g = f[_], g *= l.minval_s[_], g *= M, s[_] > g && (s[_] = g), 1 < l.masking_lower && (s[_] *= l.masking_lower), s[_] > a[_] && (s[_] = a[_]), l.masking_lower < 1 && (s[_] *= l.masking_lower);
+ }
+ for (; _ < Pe.CBANDS; ++_) a[_] = 0, s[_] = 0;
+ }
+ function z(e, t, a, s, n) {
+ var r,
+ i = Be(Pe.CBANDS),
+ o = Be(Pe.CBANDS),
+ _ = Ae(Pe.CBANDS + 2);
+ Me(e, t, a, i, o), we(e, i, o, _);
+ var l = 0;
+ for (r = 0; r < e.npart_l; r++) {
+ var f,
+ c,
+ h,
+ u = e.s3ind[r][0],
+ m = e.s3ind[r][1],
+ p = 0,
+ b = 0;
+ for (p = _[u], b += 1, c = e.s3_ll[l] * a[u] * ue[_[u]], ++l, ++u; u <= m;) p += _[u], b += 1, c = A(c, f = e.s3_ll[l] * a[u] * ue[_[u]], u - r), ++l, ++u;
+ if (c *= h = .5 * ue[p = (1 + 2 * p) / (2 * b)], e.blocktype_old[1 & n] == Pe.SHORT_TYPE) {
+ var v = _e * e.nb_1[n][r];
+ s[r] = 0 < v ? Math.min(c, v) : Math.min(c, a[r] * fe);
+ } else {
+ var d = le * e.nb_2[n][r],
+ g = _e * e.nb_1[n][r];
+ d <= 0 && (d = c), g <= 0 && (g = c), v = e.blocktype_old[1 & n] == Pe.NORM_TYPE ? Math.min(g, d) : g, s[r] = Math.min(c, v);
+ }
+ e.nb_2[n][r] = e.nb_1[n][r], e.nb_1[n][r] = c, f = i[r], f *= e.minval_l[r], f *= h, s[r] > f && (s[r] = f), 1 < e.masking_lower && (s[r] *= e.masking_lower), s[r] > a[r] && (s[r] = a[r]), e.masking_lower < 1 && (s[r] *= e.masking_lower);
+ }
+ for (; r < Pe.CBANDS; ++r) a[r] = 0, s[r] = 0;
+ }
+ function Z(e, t, a, s, n, r, i) {
+ for (var o, _, l = 2 * r, f = 0 < r ? Math.pow(10, n) : 1, c = 0; c < i; ++c) {
+ var h = e[2][c],
+ u = e[3][c],
+ m = t[0][c],
+ p = t[1][c],
+ b = t[2][c],
+ v = t[3][c];
+ if (m <= 1.58 * p && p <= 1.58 * m) {
+ var d = a[c] * u,
+ g = a[c] * h;
+ _ = Math.max(b, Math.min(v, d)), o = Math.max(v, Math.min(b, g));
+ } else _ = b, o = v;
+ if (0 < r) {
+ var S,
+ M,
+ w = s[c] * f;
+ if (S = Math.min(Math.max(m, w), Math.max(p, w)), 0 < (M = (b = Math.max(_, w)) + (v = Math.max(o, w))) && S * l < M) {
+ var R = S * l / M;
+ b *= R, v *= R;
+ }
+ _ = Math.min(b, _), o = Math.min(v, o);
+ }
+ h < _ && (_ = h), u < o && (o = u), t[2][c] = _, t[3][c] = o;
+ }
+ }
+ function w(e, t) {
+ var a;
+ return (a = 0 <= e ? 27 * -e : e * t) <= -72 ? 0 : Math.exp(a * S);
+ }
+ function R(e) {
+ var t,
+ a,
+ s = 0;
+ for (s = 0; 1e-20 < w(s, e); s -= 1);
+ for (n = s, r = 0; 1e-12 < Math.abs(r - n);) 0 < w(s = (r + n) / 2, e) ? r = s : n = s;
+ t = n;
+ var n, r;
+ s = 0;
+ for (s = 0; 1e-20 < w(s, e); s += 1);
+ for (n = 0, r = s; 1e-12 < Math.abs(r - n);) 0 < w(s = (r + n) / 2, e) ? n = s : r = s;
+ a = r;
+ var i,
+ o = 0;
+ for (i = 0; i <= 1e3; ++i) {
+ o += w(s = t + i * (a - t) / 1e3, e);
+ }
+ return 1001 / (o * (a - t));
+ }
+ function H(e) {
return e < 0 && (e = 0), e *= .001, 13 * Math.atan(.76 * e) + 3.5 * Math.atan(e * e / 56.25);
}
- function H(e, t, a, n, s, r, i, o, _, l, f, c) {
- var u,
- h = de(Ae.CBANDS + 1),
- b = o / (15 < c ? 1152 : 384),
- p = ve(Ae.HBLKSIZE);
+ function C(e, t, a, s, n, r, i, o, _, l, f, c) {
+ var h,
+ u = Be(Pe.CBANDS + 1),
+ m = o / (15 < c ? 1152 : 384),
+ p = Ae(Pe.HBLKSIZE);
o /= _;
- var m = 0,
+ var b = 0,
v = 0;
- for (u = 0; u < Ae.CBANDS; u++) {
+ for (h = 0; h < Pe.CBANDS; h++) {
var d;
- for (x = P(o * m), h[u] = o * m, d = m; P(o * d) - x < E && d <= _ / 2; d++);
- for (e[u] = d - m, v = u + 1; m < d;) p[m++] = u;
- if (_ / 2 < m) {
- m = _ / 2, ++u;
+ for (y = H(o * b), u[h] = o * b, d = b; H(o * d) - y < E && d <= _ / 2; d++);
+ for (e[h] = d - b, v = h + 1; b < d;) p[b++] = h;
+ if (_ / 2 < b) {
+ b = _ / 2, ++h;
break;
}
}
- h[u] = o * m;
+ u[h] = o * b;
for (var g = 0; g < c; g++) {
- var w, S, M, y, A;
- M = l[g], y = l[g + 1], (w = 0 | Math.floor(.5 + f * (M - .5))) < 0 && (w = 0), S = 0 | Math.floor(.5 + f * (y - .5)), _ / 2 < S && (S = _ / 2), a[g] = (p[w] + p[S]) / 2, t[g] = p[S];
- var k = b * y;
- i[g] = (k - h[t[g]]) / (h[t[g] + 1] - h[t[g]]), i[g] < 0 ? i[g] = 0 : 1 < i[g] && (i[g] = 1), A = P(o * l[g] * f), A = Math.min(A, 15.5) / 15.5, r[g] = Math.pow(10, 1.25 * (1 - Math.cos(Math.PI * A)) - 2.5);
+ var S, M, w, R, A;
+ w = l[g], R = l[g + 1], (S = 0 | Math.floor(.5 + f * (w - .5))) < 0 && (S = 0), _ / 2 < (M = 0 | Math.floor(.5 + f * (R - .5))) && (M = _ / 2), a[g] = (p[S] + p[M]) / 2, t[g] = p[M];
+ var B = m * R;
+ i[g] = (B - u[t[g]]) / (u[t[g] + 1] - u[t[g]]), i[g] < 0 ? i[g] = 0 : 1 < i[g] && (i[g] = 1), A = H(o * l[g] * f), A = Math.min(A, 15.5) / 15.5, r[g] = Math.pow(10, 1.25 * (1 - Math.cos(Math.PI * A)) - 2.5);
}
- for (var R = m = 0; R < v; R++) {
- var x,
- B,
- T = e[R];
- x = P(o * m), B = P(o * (m + T - 1)), n[R] = .5 * (x + B), x = P(o * (m - .5)), B = P(o * (m + T - .5)), s[R] = B - x, m += T;
+ for (var k = b = 0; k < v; k++) {
+ var y,
+ T,
+ x = e[k];
+ y = H(o * b), T = H(o * (b + x - 1)), s[k] = .5 * (y + T), y = H(o * (b - .5)), T = H(o * (b + x - .5)), n[k] = T - y, b += x;
}
return v;
}
- function O(e, t, a, n, s, r) {
+ function V(e, t, a, s, n, r) {
var i,
o,
_,
l,
f,
c,
- u = ge([Ae.CBANDS, Ae.CBANDS]),
- h = 0;
- if (r) for (var b = 0; b < t; b++) for (i = 0; i < t; i++) {
- var p = (o = a[b] - a[i], c = f = l = _ = void 0, _ = o, l = .5 <= (_ *= 0 <= _ ? 3 : 1.5) && _ <= 2.5 ? 8 * ((c = _ - .5) * c - 2 * c) : 0, ((f = 15.811389 + 7.5 * (_ += .474) - 17.5 * Math.sqrt(1 + _ * _)) <= -60 ? 0 : (_ = Math.exp((l + f) * w), _ /= .6609193)) * n[i]);
- u[b][i] = p * s[b];
- } else me();
- for (var b = 0; b < t; b++) {
- for (i = 0; i < t && !(0 < u[b][i]); i++);
- for (e[b][0] = i, i = t - 1; 0 < i && !(0 < u[b][i]); i--);
- e[b][1] = i, h += e[b][1] - e[b][0] + 1;
+ h = ke([Pe.CBANDS, Pe.CBANDS]),
+ u = 0;
+ if (r) for (var m = 0; m < t; m++) for (i = 0; i < t; i++) {
+ var p = (o = a[m] - a[i], c = f = l = _ = void 0, _ = o, l = .5 <= (_ *= 0 <= _ ? 3 : 1.5) && _ <= 2.5 ? 8 * ((c = _ - .5) * c - 2 * c) : 0, ((f = 15.811389 + 7.5 * (_ += .474) - 17.5 * Math.sqrt(1 + _ * _)) <= -60 ? 0 : (_ = Math.exp((l + f) * S), _ /= .6609193)) * s[i]);
+ h[m][i] = p * n[m];
+ } else for (i = 0; i < t; i++) {
+ var b = 15 + Math.min(21 / a[i], 12),
+ v = R(b);
+ for (m = 0; m < t; m++) {
+ p = v * w(a[m] - a[i], b) * s[i];
+ h[m][i] = p * n[m];
+ }
}
- for (var m = de(h), v = 0, b = 0; b < t; b++) for (i = e[b][0]; i <= e[b][1]; i++) m[v++] = u[b][i];
- return m;
+ for (m = 0; m < t; m++) {
+ for (i = 0; i < t && !(0 < h[m][i]); i++);
+ for (e[m][0] = i, i = t - 1; 0 < i && !(0 < h[m][i]); i--);
+ e[m][1] = i, u += e[m][1] - e[m][0] + 1;
+ }
+ var d = Be(u),
+ g = 0;
+ for (m = 0; m < t; m++) for (i = e[m][0]; i <= e[m][1]; i++) d[g++] = h[m][i];
+ return d;
}
- function N(e) {
- var t = P(e);
+ function O(e) {
+ var t = H(e);
return t = Math.min(t, 15.5) / 15.5, Math.pow(10, 1.25 * (1 - Math.cos(Math.PI * t)) - 2.5);
}
- function n(e, t) {
- e < -.3 && (e = 3410), e /= 1e3, e = Math.max(.1, e);
- var a = 3.64 * Math.pow(e, -.8) - 6.8 * Math.exp(-.6 * Math.pow(e - 3.4, 2)) + 6 * Math.exp(-.15 * Math.pow(e - 8.7, 2)) + .001 * (.6 + .04 * t) * Math.pow(e, 4);
- return a;
+ function s(e, t) {
+ return e < -.3 && (e = 3410), e /= 1e3, e = Math.max(.1, e), 3.64 * Math.pow(e, -.8) - 6.8 * Math.exp(-.6 * Math.pow(e - 3.4, 2)) + 6 * Math.exp(-.15 * Math.pow(e - 8.7, 2)) + .001 * (.6 + .04 * t) * Math.pow(e, 4);
}
- this.L3psycho_anal_ns = function (e, t, a, n, s, r, i, o, _, l) {
+ this.L3psycho_anal_vbr = function (e, t, a, s, n, r, i, o, _, l) {
var f,
c,
- u,
h,
- b,
- p,
+ u,
m,
- v,
- d,
- g = e.internal_flags,
- w = ge([2, Ae.BLKSIZE]),
- S = ge([2, 3, Ae.BLKSIZE_s]),
- M = de(Ae.CBANDS + 1),
- y = de(Ae.CBANDS + 1),
- A = de(Ae.CBANDS + 2),
- k = ve(2),
- R = ve(2),
- x = ge([2, 576]),
- B = ve(Ae.CBANDS + 2),
- T = ve(Ae.CBANDS + 2);
- for (we.fill(T, 0), f = g.channels_out, e.mode == ye.JOINT_STEREO && (f = 4), d = e.VBR == Me.vbr_off ? 0 == g.ResvMax ? 0 : g.ResvSize / g.ResvMax * .5 : e.VBR == Me.vbr_rh || e.VBR == Me.vbr_mtrh || e.VBR == Me.vbr_mt ? .6 : 1, c = 0; c < g.channels_out; c++) {
- var E = t[c],
- C = a + 576 - 350 - 21 + 192;
- for (h = 0; h < 576; h++) {
- var I, L;
- for (I = E[C + h + 10], b = L = 0; b < 9; b += 2) I += pe[b] * (E[C + h + b] + E[C + h + 21 - b]), L += pe[b + 1] * (E[C + h + b + 1] + E[C + h + 21 - b - 1]);
- x[c][h] = I + L;
- }
- s[n][c].en.assign(g.en[c]), s[n][c].thm.assign(g.thm[c]), 2 < f && me();
- }
- for (c = 0; c < f; c++) {
- var P,
- H = de(12),
- O = [0, 0, 0, 0],
- N = de(12),
- V = 1,
- D = de(Ae.CBANDS),
- F = de(Ae.CBANDS),
- j = [0, 0, 0, 0],
- X = de(Ae.HBLKSIZE),
- Y = ge([3, Ae.HBLKSIZE_s]);
- for (h = 0; h < 3; h++) H[h] = g.nsPsy.last_en_subshort[c][h + 6], N[h] = H[h] / g.nsPsy.last_en_subshort[c][h + 4], O[0] += H[h];
- 2 == c && me();
- var z = x[1 & c],
- q = 0;
- for (h = 0; h < 9; h++) {
- for (var G = q + 64, U = 1; q < G; q++) U < Math.abs(z[q]) && (U = Math.abs(z[q]));
- g.nsPsy.last_en_subshort[c][h] = H[h + 3] = U, O[1 + h / 3] += U, U > H[h + 3 - 2] ? U /= H[h + 3 - 2] : U = H[h + 3 - 2] > 10 * U ? H[h + 3 - 2] / (10 * U) : 0, N[h + 3] = U;
- }
- for (e.analysis && me(), P = 3 == c ? g.nsPsy.attackthre_s : g.nsPsy.attackthre, h = 0; h < 12; h++) 0 == j[h / 3] && N[h] > P && (j[h / 3] = h % 3 + 1);
- for (h = 1; h < 4; h++) (O[h - 1] > O[h] ? O[h - 1] / O[h] : O[h] / O[h - 1]) < 1.7 && (j[h] = 0, 1 == h && (j[0] = 0));
- for (0 != j[0] && 0 != g.nsPsy.lastAttacks[c] && (j[0] = 0), 3 != g.nsPsy.lastAttacks[c] && j[0] + j[1] + j[2] + j[3] == 0 || ((V = 0) != j[1] && 0 != j[0] && (j[1] = 0), 0 != j[2] && 0 != j[1] && (j[2] = 0), 0 != j[3] && 0 != j[2] && (j[3] = 0)), c < 2 ? R[c] = V : me(), _[c] = g.tot_ener[c], se(e, X, Y, w, 1 & c, S, 1 & c, n, c, t, a), he(g, X, M, D, F), be(g, D, F, B), v = 0; v < 3; v++) {
- var K, Z;
- for (le(e, Y, y, A, c, v), oe(g, y, A, c, v), m = 0; m < Ae.SBMAX_s; m++) {
- if (Z = g.thm[c].s[m][v], Z *= .8, 2 <= j[v] || 1 == j[v + 1]) {
- var W = 0 != v ? v - 1 : 2,
- U = fe(g.thm[c].s[m][W], Z, .6 * d);
- Z = Math.min(Z, U);
- }
- if (1 == j[v]) {
- var W = 0 != v ? v - 1 : 2,
- U = fe(g.thm[c].s[m][W], Z, .3 * d);
- Z = Math.min(Z, U);
- } else if (0 != v && 3 == j[v - 1] || 0 == v && 3 == g.nsPsy.lastAttacks[c]) {
- var W = 2 != v ? v + 1 : 0,
- U = fe(g.thm[c].s[m][W], Z, .3 * d);
- Z = Math.min(Z, U);
- }
- K = H[3 * v + 3] + H[3 * v + 4] + H[3 * v + 5], 6 * H[3 * v + 5] < K && (Z *= .5, 6 * H[3 * v + 4] < K && (Z *= .5)), g.thm[c].s[m][v] = Z;
+ p = e.internal_flags,
+ b = Be(Pe.HBLKSIZE),
+ v = ke([3, Pe.HBLKSIZE_s]),
+ d = ke([2, Pe.BLKSIZE]),
+ g = ke([2, 3, Pe.BLKSIZE_s]),
+ S = ke([4, Pe.CBANDS]),
+ M = ke([4, Pe.CBANDS]),
+ w = ke([4, 3]),
+ R = [[0, 0, 0, 0], [0, 0, 0, 0], [0, 0, 0, 0], [0, 0, 0, 0]],
+ A = Ae(2),
+ B = e.mode == Ee.JOINT_STEREO ? 4 : p.channels_out;
+ !function (e, t, a, s, n, r, i, o, _, l) {
+ for (var f = ke([2, 576]), c = e.internal_flags, h = c.channels_out, u = e.mode == Ee.JOINT_STEREO ? 4 : h, m = 0; m < h; m++) {
+ firbuf = t[m];
+ for (var p = a + 576 - 350 - ce + 192, b = 0; b < 576; b++) {
+ var v, d;
+ v = firbuf[p + b + 10];
+ for (var g = d = 0; g < (ce - 1) / 2 - 1; g += 2) v += X[g] * (firbuf[p + b + g] + firbuf[p + b + ce - g]), d += X[g + 1] * (firbuf[p + b + g + 1] + firbuf[p + b + ce - g - 1]);
+ f[m][b] = v + d;
}
+ n[s][m].en.assign(c.en[m]), n[s][m].thm.assign(c.thm[m]), 2 < u && (r[s][m].en.assign(c.en[m + 2]), r[s][m].thm.assign(c.thm[m + 2]));
}
- for (g.nsPsy.lastAttacks[c] = j[2], u = p = 0; u < g.npart_l; u++) {
- for (var Q = g.s3ind[u][0], $ = M[Q] * re[B[Q]], J = g.s3_ll[p++] * $; ++Q <= g.s3ind[u][1];) $ = M[Q] * re[B[Q]], J = ie(J, g.s3_ll[p++] * $, Q, Q - u, g, 0);
- J *= .158489319246111, g.blocktype_old[1 & c] == Ae.SHORT_TYPE ? A[u] = J : A[u] = fe(Math.min(J, Math.min(2 * g.nb_1[c][u], 16 * g.nb_2[c][u])), J, d), g.nb_2[c][u] = g.nb_1[c][u], g.nb_1[c][u] = J;
+ for (m = 0; m < u; m++) {
+ var S = Be(12),
+ M = Be(12),
+ w = [0, 0, 0, 0],
+ R = f[1 & m],
+ A = 0,
+ B = 3 == m ? c.nsPsy.attackthre_s : c.nsPsy.attackthre,
+ k = 1;
+ if (2 == m) for (b = 0, g = 576; 0 < g; ++b, --g) {
+ var y = f[0][b],
+ T = f[1][b];
+ f[0][b] = y + T, f[1][b] = y - T;
+ }
+ for (b = 0; b < 3; b++) M[b] = c.nsPsy.last_en_subshort[m][b + 6], S[b] = M[b] / c.nsPsy.last_en_subshort[m][b + 4], w[0] += M[b];
+ for (b = 0; b < 9; b++) {
+ for (var x = A + 64, E = 1; A < x; A++) E < Math.abs(R[A]) && (E = Math.abs(R[A]));
+ c.nsPsy.last_en_subshort[m][b] = M[b + 3] = E, w[1 + b / 3] += E, E > M[b + 3 - 2] ? E /= M[b + 3 - 2] : E = M[b + 3 - 2] > 10 * E ? M[b + 3 - 2] / (10 * E) : 0, S[b + 3] = E;
+ }
+ for (b = 0; b < 3; ++b) {
+ var P = M[3 * b + 3] + M[3 * b + 4] + M[3 * b + 5],
+ L = 1;
+ 6 * M[3 * b + 5] < P && (L *= .5, 6 * M[3 * b + 4] < P && (L *= .5)), o[m][b] = L;
+ }
+ if (e.analysis) {
+ var I = S[0];
+ for (b = 1; b < 12; b++) I < S[b] && (I = S[b]);
+ c.pinfo.ers[s][m] = c.pinfo.ers_save[m], c.pinfo.ers_save[m] = I;
+ }
+ for (b = 0; b < 12; b++) 0 == _[m][b / 3] && S[b] > B && (_[m][b / 3] = b % 3 + 1);
+ for (b = 1; b < 4; b++) {
+ var H = w[b - 1],
+ C = w[b];
+ Math.max(H, C) < 4e4 && H < 1.7 * C && C < 1.7 * H && (1 == b && _[m][0] <= _[m][b] && (_[m][0] = 0), _[m][b] = 0);
+ }
+ _[m][0] <= c.nsPsy.lastAttacks[m] && (_[m][0] = 0), 3 != c.nsPsy.lastAttacks[m] && _[m][0] + _[m][1] + _[m][2] + _[m][3] == 0 || ((k = 0) != _[m][1] && 0 != _[m][0] && (_[m][1] = 0), 0 != _[m][2] && 0 != _[m][1] && (_[m][2] = 0), 0 != _[m][3] && 0 != _[m][2] && (_[m][3] = 0)), m < 2 ? l[m] = k : 0 == k && (l[0] = l[1] = 0), i[m] = c.tot_ener[m];
}
- for (; u <= Ae.CBANDS; ++u) M[u] = 0, A[u] = 0;
- _e(g, M, A, c);
+ }(e, t, a, s, n, r, _, w, R, A), function (e, t) {
+ var a = e.internal_flags;
+ e.short_blocks != Te.short_block_coupled || 0 != t[0] && 0 != t[1] || (t[0] = t[1] = 0);
+ for (var s = 0; s < a.channels_out; s++) e.short_blocks == Te.short_block_dispensed && (t[s] = 1), e.short_blocks == Te.short_block_forced && (t[s] = 0);
+ }(e, A);
+ for (var k = 0; k < B; k++) {
+ D(e, t, a, k, s, b, d, T = 1 & k), c = s, h = k, u = b, m = void 0, m = (f = e).internal_flags, 2 == f.athaa_loudapprox && h < 2 && (m.loudness_sq[c][h] = m.loudness_sq_save[h], m.loudness_sq_save[h] = N(u, m)), 0 != A[T] ? z(p, b, S[k], M[k], k) : F(p, k);
}
- for (e.mode != ye.STEREO && e.mode != ye.JOINT_STEREO || me(), e.mode == ye.JOINT_STEREO && me(), function (e, t, a, n) {
- var s = e.internal_flags;
- e.short_blocks != Se.short_block_coupled || 0 != t[0] && 0 != t[1] || (t[0] = t[1] = 0);
- for (var r = 0; r < s.channels_out; r++) n[r] = Ae.NORM_TYPE, e.short_blocks == Se.short_block_dispensed && (t[r] = 1), e.short_blocks == Se.short_block_forced && (t[r] = 0), 0 != t[r] ? s.blocktype_old[r] == Ae.SHORT_TYPE && (n[r] = Ae.STOP_TYPE) : (n[r] = Ae.SHORT_TYPE, s.blocktype_old[r] == Ae.NORM_TYPE && (s.blocktype_old[r] = Ae.START_TYPE), s.blocktype_old[r] == Ae.STOP_TYPE && (s.blocktype_old[r] = Ae.SHORT_TYPE)), a[r] = s.blocktype_old[r], s.blocktype_old[r] = n[r];
- }(e, R, l, k), c = 0; c < f; c++) {
- var ee,
- te,
- ae,
- ne = 0;
- 1 < c ? me() : (ee = i, ne = 0, te = l[c], ae = s[n][c]), ee[ne + c] = te == Ae.SHORT_TYPE ? ce(ae, g.masking_lower) : ue(ae, g.masking_lower), e.analysis && (g.pinfo.pe[n][c] = ee[ne + c]);
+ A[0] + A[1] == 2 && e.mode == Ee.JOINT_STEREO && Z(S, M, p.mld_cb_l, p.ATH.cb_l, e.ATHlower * p.ATH.adjust, e.msfix, p.npart_l);
+ for (k = 0; k < B; k++) {
+ 0 != A[T = 1 & k] && be(p, S[k], M[k], k);
+ }
+ for (var y = 0; y < 3; y++) {
+ for (k = 0; k < B; ++k) {
+ 0 != A[T = 1 & k] ? q(p, k, y) : (Y(e, t, a, k, y, v, g, T), j(e, v, S[k], M[k], k, y));
+ }
+ A[0] + A[1] == 0 && e.mode == Ee.JOINT_STEREO && Z(S, M, p.mld_cb_s, p.ATH.cb_s, e.ATHlower * p.ATH.adjust, e.msfix, p.npart_s);
+ for (k = 0; k < B; ++k) {
+ 0 == A[T = 1 & k] && pe(p, S[k], M[k], k, y);
+ }
+ }
+ for (k = 0; k < B; k++) {
+ var T;
+ if (0 == A[T = 1 & k]) for (var x = 0; x < Pe.SBMAX_s; x++) {
+ var E = Be(3);
+ for (y = 0; y < 3; y++) {
+ var P = p.thm[k].s[x][y];
+ if (P *= .8, 2 <= R[k][y] || 1 == R[k][y + 1]) {
+ var L = 0 != y ? y - 1 : 2,
+ I = de(p.thm[k].s[x][L], P, .36);
+ P = Math.min(P, I);
+ } else if (1 == R[k][y]) {
+ L = 0 != y ? y - 1 : 2, I = de(p.thm[k].s[x][L], P, .6 * fe);
+ P = Math.min(P, I);
+ } else if (0 != y && 3 == R[k][y - 1] || 0 == y && 3 == p.nsPsy.lastAttacks[k]) {
+ L = 2 != y ? y + 1 : 0, I = de(p.thm[k].s[x][L], P, .6 * fe);
+ P = Math.min(P, I);
+ }
+ P *= w[k][y], E[y] = P;
+ }
+ for (y = 0; y < 3; y++) p.thm[k].s[x][y] = E[y];
+ }
+ }
+ for (k = 0; k < B; k++) p.nsPsy.lastAttacks[k] = R[k][2];
+ !function (e, t, a) {
+ for (var s = e.internal_flags, n = 0; n < s.channels_out; n++) {
+ var r = Pe.NORM_TYPE;
+ 0 != t[n] ? s.blocktype_old[n] == Pe.SHORT_TYPE && (r = Pe.STOP_TYPE) : (r = Pe.SHORT_TYPE, s.blocktype_old[n] == Pe.NORM_TYPE && (s.blocktype_old[n] = Pe.START_TYPE), s.blocktype_old[n] == Pe.STOP_TYPE && (s.blocktype_old[n] = Pe.SHORT_TYPE)), a[n] = s.blocktype_old[n], s.blocktype_old[n] = r;
+ }
+ }(e, A, l);
+ for (k = 0; k < B; k++) {
+ var H, C, V, O;
+ 1 < k ? (H = o, C = -2, V = Pe.NORM_TYPE, l[0] != Pe.SHORT_TYPE && l[1] != Pe.SHORT_TYPE || (V = Pe.SHORT_TYPE), O = r[s][k - 2]) : (H = i, C = 0, V = l[k], O = n[s][k]), H[C + k] = V == Pe.SHORT_TYPE ? ge(O, p.masking_lower) : Se(O, p.masking_lower), e.analysis && (p.pinfo.pe[s][k] = H[C + k]);
}
return 0;
}, this.psymodel_init = function (e) {
var t,
a = e.internal_flags,
- n = !0,
- s = 13,
+ s = !0,
+ n = 13,
r = 0,
i = 0,
o = -8.25,
_ = -4.5,
- l = de(Ae.CBANDS),
- f = de(Ae.CBANDS),
- c = de(Ae.CBANDS),
- u = e.out_samplerate;
+ l = Be(Pe.CBANDS),
+ f = Be(Pe.CBANDS),
+ c = Be(Pe.CBANDS),
+ h = e.out_samplerate;
switch (e.experimentalZ) {
default:
case 0:
- n = !0;
+ s = !0;
break;
case 1:
- n = e.VBR != Me.vbr_mtrh && e.VBR != Me.vbr_mt;
+ s = e.VBR != xe.vbr_mtrh && e.VBR != xe.vbr_mt;
break;
case 2:
- n = !1;
+ s = !1;
break;
case 3:
- s = 8, r = -1.75, i = -.0125, o = -8.25, _ = -2.25;
+ n = 8, r = -1.75, i = -.0125, o = -8.25, _ = -2.25;
}
- for (a.ms_ener_ratio_old = .25, a.blocktype_old[0] = a.blocktype_old[1] = Ae.NORM_TYPE, t = 0; t < 4; ++t) {
- for (var h = 0; h < Ae.CBANDS; ++h) a.nb_1[t][h] = 1e20, a.nb_2[t][h] = 1e20, a.nb_s1[t][h] = a.nb_s2[t][h] = 1;
- for (var b = 0; b < Ae.SBMAX_l; b++) a.en[t].l[b] = 1e20, a.thm[t].l[b] = 1e20;
- for (var h = 0; h < 3; ++h) {
- for (var b = 0; b < Ae.SBMAX_s; b++) a.en[t].s[b][h] = 1e20, a.thm[t].s[b][h] = 1e20;
+ for (a.ms_ener_ratio_old = .25, a.blocktype_old[0] = a.blocktype_old[1] = Pe.NORM_TYPE, t = 0; t < 4; ++t) {
+ for (var u = 0; u < Pe.CBANDS; ++u) a.nb_1[t][u] = 1e20, a.nb_2[t][u] = 1e20, a.nb_s1[t][u] = a.nb_s2[t][u] = 1;
+ for (var m = 0; m < Pe.SBMAX_l; m++) a.en[t].l[m] = 1e20, a.thm[t].l[m] = 1e20;
+ for (u = 0; u < 3; ++u) {
+ for (m = 0; m < Pe.SBMAX_s; m++) a.en[t].s[m][u] = 1e20, a.thm[t].s[m][u] = 1e20;
a.nsPsy.lastAttacks[t] = 0;
}
- for (var h = 0; h < 9; h++) a.nsPsy.last_en_subshort[t][h] = 10;
+ for (u = 0; u < 9; u++) a.nsPsy.last_en_subshort[t][u] = 10;
}
- for (a.loudness_sq_save[0] = a.loudness_sq_save[1] = 0, a.npart_l = H(a.numlines_l, a.bo_l, a.bm_l, l, f, a.mld_l, a.PSY.bo_l_weight, u, Ae.BLKSIZE, a.scalefac_band.l, Ae.BLKSIZE / 1152, Ae.SBMAX_l), t = 0; t < a.npart_l; t++) {
+ for (a.loudness_sq_save[0] = a.loudness_sq_save[1] = 0, a.npart_l = C(a.numlines_l, a.bo_l, a.bm_l, l, f, a.mld_l, a.PSY.bo_l_weight, h, Pe.BLKSIZE, a.scalefac_band.l, Pe.BLKSIZE / 1152, Pe.SBMAX_l), t = 0; t < a.npart_l; t++) {
var p = r;
- l[t] >= s && (p = i * (l[t] - s) / (24 - s) + r * (24 - l[t]) / (24 - s)), c[t] = Math.pow(10, p / 10), 0 < a.numlines_l[t] ? a.rnumlines_l[t] = 1 / a.numlines_l[t] : a.rnumlines_l[t] = 0;
+ l[t] >= n && (p = i * (l[t] - n) / (24 - n) + r * (24 - l[t]) / (24 - n)), c[t] = Math.pow(10, p / 10), 0 < a.numlines_l[t] ? a.rnumlines_l[t] = 1 / a.numlines_l[t] : a.rnumlines_l[t] = 0;
}
- a.s3_ll = O(a.s3ind, a.npart_l, l, f, c, n);
- var m,
- h = 0;
+ a.s3_ll = V(a.s3ind, a.npart_l, l, f, c, s);
+ var b;
+ u = 0;
for (t = 0; t < a.npart_l; t++) {
- g = D.MAX_VALUE;
- for (var v = 0; v < a.numlines_l[t]; v++, h++) {
- var d = u * h / (1e3 * Ae.BLKSIZE);
- w = this.ATHformula(1e3 * d, e) - 20, w = Math.pow(10, .1 * w), (w *= a.numlines_l[t]) < g && (g = w);
+ g = K.MAX_VALUE;
+ for (var v = 0; v < a.numlines_l[t]; v++, u++) {
+ var d = h * u / (1e3 * Pe.BLKSIZE);
+ S = this.ATHformula(1e3 * d, e) - 20, S = Math.pow(10, .1 * S), (S *= a.numlines_l[t]) < g && (g = S);
}
a.ATH.cb_l[t] = g, 6 < (g = 20 * l[t] / 10 - 20) && (g = 100), g < -15 && (g = -15), g -= 8, a.minval_l[t] = Math.pow(10, g / 10) * a.numlines_l[t];
}
- for (a.npart_s = H(a.numlines_s, a.bo_s, a.bm_s, l, f, a.mld_s, a.PSY.bo_s_weight, u, Ae.BLKSIZE_s, a.scalefac_band.s, Ae.BLKSIZE_s / 384, Ae.SBMAX_s), t = h = 0; t < a.npart_s; t++) {
- var g,
- p = o;
- l[t] >= s && (p = _ * (l[t] - s) / (24 - s) + o * (24 - l[t]) / (24 - s)), c[t] = Math.pow(10, p / 10), g = D.MAX_VALUE;
- for (var v = 0; v < a.numlines_s[t]; v++, h++) {
- var w,
- d = u * h / (1e3 * Ae.BLKSIZE_s);
- w = this.ATHformula(1e3 * d, e) - 20, w = Math.pow(10, .1 * w), (w *= a.numlines_s[t]) < g && (g = w);
+ for (a.npart_s = C(a.numlines_s, a.bo_s, a.bm_s, l, f, a.mld_s, a.PSY.bo_s_weight, h, Pe.BLKSIZE_s, a.scalefac_band.s, Pe.BLKSIZE_s / 384, Pe.SBMAX_s), t = u = 0; t < a.npart_s; t++) {
+ var g;
+ p = o;
+ l[t] >= n && (p = _ * (l[t] - n) / (24 - n) + o * (24 - l[t]) / (24 - n)), c[t] = Math.pow(10, p / 10), g = K.MAX_VALUE;
+ for (v = 0; v < a.numlines_s[t]; v++, u++) {
+ var S;
+ d = h * u / (1e3 * Pe.BLKSIZE_s);
+ S = this.ATHformula(1e3 * d, e) - 20, S = Math.pow(10, .1 * S), (S *= a.numlines_s[t]) < g && (g = S);
}
a.ATH.cb_s[t] = g, g = 7 * l[t] / 12 - 7, 12 < l[t] && (g *= 1 + 3.1 * Math.log(1 + g)), l[t] < 12 && (g *= 1 + 2.3 * Math.log(1 - g)), g < -15 && (g = -15), g -= 8, a.minval_s[t] = Math.pow(10, g / 10) * a.numlines_s[t];
}
- a.s3_ss = O(a.s3ind_s, a.npart_s, l, f, c, n), x = Math.pow(10, (C + 1) / 16), B = Math.pow(10, (I + 1) / 16), T = Math.pow(10, L / 10), k.init_fft(a), a.decay = Math.exp(-1 * R / (.01 * u / 192)), m = 3.5, 0 != (2 & e.exp_nspsytune) && (m = 1), 0 < Math.abs(e.msfix) && (m = e.msfix), e.msfix = m;
- for (var S = 0; S < a.npart_l; S++) a.s3ind[S][1] > a.npart_l - 1 && (a.s3ind[S][1] = a.npart_l - 1);
- var M = 576 * a.mode_gr / u;
- if (a.ATH.decay = Math.pow(10, -1.2 * M), a.ATH.adjust = .01, -(a.ATH.adjustLimit = 1) != e.ATHtype) {
- var y = e.out_samplerate / Ae.BLKSIZE,
+ a.s3_ss = V(a.s3ind_s, a.npart_s, l, f, c, s), y = Math.pow(10, (P + 1) / 16), T = Math.pow(10, (L + 1) / 16), x = Math.pow(10, I / 10), B.init_fft(a), a.decay = Math.exp(-1 * k / (.01 * h / 192)), b = 3.5, 0 != (2 & e.exp_nspsytune) && (b = 1), 0 < Math.abs(e.msfix) && (b = e.msfix), e.msfix = b;
+ for (var M = 0; M < a.npart_l; M++) a.s3ind[M][1] > a.npart_l - 1 && (a.s3ind[M][1] = a.npart_l - 1);
+ var w = 576 * a.mode_gr / h;
+ if (a.ATH.decay = Math.pow(10, -1.2 * w), a.ATH.adjust = .01, -(a.ATH.adjustLimit = 1) != e.ATHtype) {
+ var R = e.out_samplerate / Pe.BLKSIZE,
A = 0;
- for (t = d = 0; t < Ae.BLKSIZE / 2; ++t) d += y, a.ATH.eql_w[t] = 1 / Math.pow(10, this.ATHformula(d, e) / 10), A += a.ATH.eql_w[t];
- for (A = 1 / A, t = Ae.BLKSIZE / 2; 0 <= --t;) a.ATH.eql_w[t] *= A;
+ for (t = d = 0; t < Pe.BLKSIZE / 2; ++t) d += R, a.ATH.eql_w[t] = 1 / Math.pow(10, this.ATHformula(d, e) / 10), A += a.ATH.eql_w[t];
+ for (A = 1 / A, t = Pe.BLKSIZE / 2; 0 <= --t;) a.ATH.eql_w[t] *= A;
}
- for (var S = h = 0; S < a.npart_s; ++S) for (t = 0; t < a.numlines_s[S]; ++t) ++h;
- for (var S = h = 0; S < a.npart_l; ++S) for (t = 0; t < a.numlines_l[S]; ++t) ++h;
- for (t = h = 0; t < a.npart_l; t++) {
- var d = u * (h + a.numlines_l[t] / 2) / (1 * Ae.BLKSIZE);
- a.mld_cb_l[t] = N(d), h += a.numlines_l[t];
+ for (M = u = 0; M < a.npart_s; ++M) for (t = 0; t < a.numlines_s[M]; ++t) ++u;
+ for (M = u = 0; M < a.npart_l; ++M) for (t = 0; t < a.numlines_l[M]; ++t) ++u;
+ for (t = u = 0; t < a.npart_l; t++) {
+ d = h * (u + a.numlines_l[t] / 2) / (1 * Pe.BLKSIZE);
+ a.mld_cb_l[t] = O(d), u += a.numlines_l[t];
}
- for (; t < Ae.CBANDS; ++t) a.mld_cb_l[t] = 1;
- for (t = h = 0; t < a.npart_s; t++) {
- var d = u * (h + a.numlines_s[t] / 2) / (1 * Ae.BLKSIZE_s);
- a.mld_cb_s[t] = N(d), h += a.numlines_s[t];
+ for (; t < Pe.CBANDS; ++t) a.mld_cb_l[t] = 1;
+ for (t = u = 0; t < a.npart_s; t++) {
+ d = h * (u + a.numlines_s[t] / 2) / (1 * Pe.BLKSIZE_s);
+ a.mld_cb_s[t] = O(d), u += a.numlines_s[t];
}
- for (; t < Ae.CBANDS; ++t) a.mld_cb_s[t] = 1;
+ for (; t < Pe.CBANDS; ++t) a.mld_cb_s[t] = 1;
return 0;
}, this.ATHformula = function (e, t) {
var a;
switch (t.ATHtype) {
case 0:
- a = n(e, 9);
+ a = s(e, 9);
break;
case 1:
- a = n(e, -1);
+ a = s(e, -1);
break;
case 2:
- a = n(e, 0);
+ a = s(e, 0);
break;
case 3:
- a = n(e, 1) + 6;
+ a = s(e, 1) + 6;
break;
case 4:
- a = n(e, t.ATHcurve);
+ a = s(e, t.ATHcurve);
break;
default:
- a = n(e, 0);
+ a = s(e, 0);
}
return a;
};
}
- function Y() {
- var T,
- E,
- u,
- h,
- b,
- C = this;
- Y.V9 = 410, Y.V8 = 420, Y.V7 = 430, Y.V6 = 440, Y.V5 = 450, Y.V4 = 460, Y.V3 = 470, Y.V2 = 480, Y.V1 = 490, Y.V0 = 500, Y.R3MIX = 1e3, Y.STANDARD = 1001, Y.EXTREME = 1002, Y.INSANE = 1003, Y.STANDARD_FAST = 1004, Y.EXTREME_FAST = 1005, Y.MEDIUM = 1006, Y.MEDIUM_FAST = 1007, Y.LAME_MAXMP3BUFFER = 147456;
- var p,
- m,
- v = new X();
- function d() {
+ function U() {
+ var o = this;
+ U.V9 = 410, U.V8 = 420, U.V7 = 430, U.V6 = 440, U.V5 = 450, U.V4 = 460, U.V3 = 470, U.V2 = 480, U.V1 = 490, U.V0 = 500, U.R3MIX = 1e3, U.STANDARD = 1001, U.EXTREME = 1002, U.INSANE = 1003, U.STANDARD_FAST = 1004, U.EXTREME_FAST = 1005, U.MEDIUM = 1006, U.MEDIUM_FAST = 1007;
+ var w, R, g, S, M;
+ U.LAME_MAXMP3BUFFER = 147456;
+ var A,
+ B,
+ k,
+ y = new G();
+ function T() {
this.lowerlimit = 0;
}
- function s(e, t) {
+ function n(e, t) {
this.lowpass = t;
}
- this.enc = new Ae(), this.setModules = function (e, t, a, n, s, r, i, o, _) {
- T = e, E = t, u = a, h = n, b = s, p = r, m = o, this.enc.setModules(E, v, h, p);
+ this.enc = new Pe(), this.setModules = function (e, t, a, s, n, r, i, o, _) {
+ w = e, R = t, g = a, S = s, M = n, A = r, B = o, k = _, this.enc.setModules(R, y, S, A);
};
- var I = 4294479419;
- function g(e, t) {
- var a = [new s(8, 2e3), new s(16, 3700), new s(24, 3900), new s(32, 5500), new s(40, 7e3), new s(48, 7500), new s(56, 1e4), new s(64, 11e3), new s(80, 13500), new s(96, 15100), new s(112, 15600), new s(128, 17e3), new s(160, 17500), new s(192, 18600), new s(224, 19400), new s(256, 19700), new s(320, 20500)],
- n = C.nearestBitrateFullIndex(t);
- e.lowerlimit = a[n].lowpass;
+ var x = 4294479419;
+ function E(e) {
+ return 1 < e ? 0 : e <= 0 ? 1 : Math.cos(Math.PI / 2 * e);
}
- function L(e) {
- var t = Ae.BLKSIZE + e.framesize - Ae.FFTOFFSET;
+ function P(e, t) {
+ switch (e) {
+ case 44100:
+ return t.version = 1, 0;
+ case 48e3:
+ return t.version = 1;
+ case 32e3:
+ return t.version = 1, 2;
+ case 22050:
+ return t.version = 0;
+ case 24e3:
+ return t.version = 0, 1;
+ case 16e3:
+ return t.version = 0, 2;
+ case 11025:
+ return t.version = 0;
+ case 12e3:
+ return t.version = 0, 1;
+ case 8e3:
+ return t.version = 0, 2;
+ default:
+ return t.version = 0, -1;
+ }
+ }
+ function L(e, t, a) {
+ a < 16e3 && (t = 2);
+ for (var s = F.bitrate_table[t][1], n = 2; n <= 14; n++) 0 < F.bitrate_table[t][n] && Math.abs(F.bitrate_table[t][n] - e) < Math.abs(s - e) && (s = F.bitrate_table[t][n]);
+ return s;
+ }
+ function I(e, t, a) {
+ a < 16e3 && (t = 2);
+ for (var s = 0; s <= 14; s++) if (0 < F.bitrate_table[t][s] && F.bitrate_table[t][s] == e) return s;
+ return -1;
+ }
+ function H(e, t) {
+ var a = [new n(8, 2e3), new n(16, 3700), new n(24, 3900), new n(32, 5500), new n(40, 7e3), new n(48, 7500), new n(56, 1e4), new n(64, 11e3), new n(80, 13500), new n(96, 15100), new n(112, 15600), new n(128, 17e3), new n(160, 17500), new n(192, 18600), new n(224, 19400), new n(256, 19700), new n(320, 20500)],
+ s = o.nearestBitrateFullIndex(t);
+ e.lowerlimit = a[s].lowpass;
+ }
+ function C(e) {
+ var t = Pe.BLKSIZE + e.framesize - Pe.FFTOFFSET;
return t = Math.max(t, 512 + e.framesize - 32);
}
- function P() {
+ function V(e, t, a, s, n, r) {
+ var i = o.enc.lame_encode_mp3_frame(e, t, a, s, n, r);
+ return e.frameNum++, i;
+ }
+ function O() {
this.n_in = 0, this.n_out = 0;
}
- function H(e, t, a, n, s, r) {
+ function f() {
+ this.num_used = 0;
+ }
+ function N(e, t, a) {
+ var s = Math.PI * t;
+ (e /= a) < 0 && (e = 0), 1 < e && (e = 1);
+ var n = e - .5,
+ r = .42 - .5 * Math.cos(2 * e * Math.PI) + .08 * Math.cos(4 * e * Math.PI);
+ return Math.abs(n) < 1e-9 ? s / Math.PI : r * Math.sin(a * s * n) / (Math.PI * a * n);
+ }
+ function c(e, t, a, s, n, r, i, o, _) {
+ var l,
+ f,
+ c = e.internal_flags,
+ h = 0,
+ u = e.out_samplerate / function e(t, a) {
+ return 0 != a ? e(a, t % a) : t;
+ }(e.out_samplerate, e.in_samplerate);
+ Z.BPC < u && (u = Z.BPC);
+ var m = Math.abs(c.resample_ratio - Math.floor(.5 + c.resample_ratio)) < 1e-4 ? 1 : 0,
+ p = 1 / c.resample_ratio;
+ 1 < p && (p = 1);
+ var b = 31;
+ 0 == b % 2 && --b;
+ var v = (b += m) + 1;
+ if (0 == c.fill_buffer_resample_init) {
+ for (c.inbuf_old[0] = Be(v), c.inbuf_old[1] = Be(v), l = 0; l <= 2 * u; ++l) c.blackfilt[l] = Be(v);
+ for (c.itime[0] = 0, h = c.itime[1] = 0; h <= 2 * u; h++) {
+ var d = 0,
+ g = (h - u) / (2 * u);
+ for (l = 0; l <= b; l++) d += c.blackfilt[h][l] = N(l - g, p, b);
+ for (l = 0; l <= b; l++) c.blackfilt[h][l] /= d;
+ }
+ c.fill_buffer_resample_init = 1;
+ }
+ var S = c.inbuf_old[_];
+ for (f = 0; f < s; f++) {
+ var M, w;
+ if (M = f * c.resample_ratio, i <= b + (h = 0 | Math.floor(M - c.itime[_])) - b / 2) break;
+ g = M - c.itime[_] - (h + b % 2 * .5);
+ w = 0 | Math.floor(2 * g * u + u + .5);
+ var R = 0;
+ for (l = 0; l <= b; ++l) {
+ var A = l + h - b / 2;
+ R += (A < 0 ? S[v + A] : n[r + A]) * c.blackfilt[w][l];
+ }
+ t[a + f] = R;
+ }
+ if (o.num_used = Math.min(i, b + h - b / 2), c.itime[_] += o.num_used - f * c.resample_ratio, o.num_used >= v) for (l = 0; l < v; l++) S[l] = n[r + o.num_used + l - v];else {
+ var B = v - o.num_used;
+ for (l = 0; l < B; ++l) S[l] = S[l + o.num_used];
+ for (h = 0; l < v; ++l, ++h) S[l] = n[r + h];
+ }
+ return f;
+ }
+ function D(e, t, a, s, n, r) {
var i = e.internal_flags;
- if (i.resample_ratio < .9999 || 1.0001 < i.resample_ratio) me();else {
- r.n_out = Math.min(e.framesize, s), r.n_in = r.n_out;
- for (var o = 0; o < r.n_out; ++o) t[0][i.mf_size + o] = a[0][n + o], 2 == i.channels_out && (t[1][i.mf_size + o] = a[1][n + o]);
+ if (i.resample_ratio < .9999 || 1.0001 < i.resample_ratio) for (var o = 0; o < i.channels_out; o++) {
+ var _ = new f();
+ r.n_out = c(e, t[o], i.mf_size, e.framesize, a[o], s, n, _, o), r.n_in = _.num_used;
+ } else {
+ r.n_out = Math.min(e.framesize, n), r.n_in = r.n_out;
+ for (var l = 0; l < r.n_out; ++l) t[0][i.mf_size + l] = a[0][s + l], 2 == i.channels_out && (t[1][i.mf_size + l] = a[1][s + l]);
}
}
this.lame_init = function () {
var e,
t,
a = new function () {
- this.class_id = 0, this.num_samples = 0, this.num_channels = 0, this.in_samplerate = 0, this.out_samplerate = 0, this.scale = 0, this.scale_left = 0, this.scale_right = 0, this.analysis = !1, this.bWriteVbrTag = !1, this.decode_only = !1, this.quality = 0, this.mode = ye.STEREO, this.force_ms = !1, this.free_format = !1, this.findReplayGain = !1, this.decode_on_the_fly = !1, this.write_id3tag_automatic = !1, this.brate = 0, this.compression_ratio = 0, this.copyright = 0, this.original = 0, this.extension = 0, this.emphasis = 0, this.error_protection = 0, this.strict_ISO = !1, this.disable_reservoir = !1, this.quant_comp = 0, this.quant_comp_short = 0, this.experimentalY = !1, this.experimentalZ = 0, this.exp_nspsytune = 0, this.preset = 0, this.VBR = null, this.VBR_q_frac = 0, this.VBR_q = 0, this.VBR_mean_bitrate_kbps = 0, this.VBR_min_bitrate_kbps = 0, this.VBR_max_bitrate_kbps = 0, this.VBR_hard_min = 0, this.lowpassfreq = 0, this.highpassfreq = 0, this.lowpasswidth = 0, this.highpasswidth = 0, this.maskingadjust = 0, this.maskingadjust_short = 0, this.ATHonly = !1, this.ATHshort = !1, this.noATH = !1, this.ATHtype = 0, this.ATHcurve = 0, this.ATHlower = 0, this.athaa_type = 0, this.athaa_loudapprox = 0, this.athaa_sensitivity = 0, this.short_blocks = null, this.useTemporal = !1, this.interChRatio = 0, this.msfix = 0, this.tune = !1, this.tune_value_a = 0, this.version = 0, this.encoder_delay = 0, this.encoder_padding = 0, this.framesize = 0, this.frameNum = 0, this.lame_allocated_gfp = 0, this.internal_flags = null;
- }(),
- n = ((e = a).class_id = I, t = e.internal_flags = new j(), e.mode = ye.NOT_SET, e.original = 1, e.in_samplerate = 44100, e.num_channels = 2, e.num_samples = -1, e.bWriteVbrTag = !0, e.quality = -1, e.short_blocks = null, t.subblock_gain = -1, e.lowpassfreq = 0, e.highpassfreq = 0, e.lowpasswidth = -1, e.highpasswidth = -1, e.VBR = Me.vbr_off, e.VBR_q = 4, e.ATHcurve = -1, e.VBR_mean_bitrate_kbps = 128, e.VBR_min_bitrate_kbps = 0, e.VBR_max_bitrate_kbps = 0, e.VBR_hard_min = 0, t.VBR_min_bitrate = 1, t.VBR_max_bitrate = 13, e.quant_comp = -1, e.quant_comp_short = -1, e.msfix = -1, t.resample_ratio = 1, t.OldValue[0] = 180, t.OldValue[1] = 180, t.CurrentStep[0] = 4, t.CurrentStep[1] = 4, t.masking_lower = 1, t.nsPsy.attackthre = -1, t.nsPsy.attackthre_s = -1, e.scale = -1, e.athaa_type = -1, e.ATHtype = -1, e.athaa_loudapprox = -1, e.athaa_sensitivity = 0, e.useTemporal = null, e.interChRatio = -1, t.mf_samples_to_encode = Ae.ENCDELAY + Ae.POSTDELAY, e.encoder_padding = 0, t.mf_size = Ae.ENCDELAY - Ae.MDCTDELAY, e.findReplayGain = !1, e.decode_on_the_fly = !1, t.decode_on_the_fly = !1, t.findReplayGain = !1, t.findPeakSample = !1, t.RadioGain = 0, t.AudiophileGain = 0, t.noclipGainChange = 0, t.noclipScale = -1, e.preset = 0, e.write_id3tag_automatic = !0, 0);
- return 0 != n ? null : (a.lame_allocated_gfp = 1, a);
+ this.class_id = 0, this.num_samples = 0, this.num_channels = 0, this.in_samplerate = 0, this.out_samplerate = 0, this.scale = 0, this.scale_left = 0, this.scale_right = 0, this.analysis = !1, this.bWriteVbrTag = !1, this.decode_only = !1, this.quality = 0, this.mode = Ee.STEREO, this.force_ms = !1, this.free_format = !1, this.findReplayGain = !1, this.decode_on_the_fly = !1, this.write_id3tag_automatic = !1, this.brate = 0, this.compression_ratio = 0, this.copyright = 0, this.original = 0, this.extension = 0, this.emphasis = 0, this.error_protection = 0, this.strict_ISO = !1, this.disable_reservoir = !1, this.quant_comp = 0, this.quant_comp_short = 0, this.experimentalY = !1, this.experimentalZ = 0, this.exp_nspsytune = 0, this.preset = 0, this.VBR = null, this.VBR_q_frac = 0, this.VBR_q = 0, this.VBR_mean_bitrate_kbps = 0, this.VBR_min_bitrate_kbps = 0, this.VBR_max_bitrate_kbps = 0, this.VBR_hard_min = 0, this.lowpassfreq = 0, this.highpassfreq = 0, this.lowpasswidth = 0, this.highpasswidth = 0, this.maskingadjust = 0, this.maskingadjust_short = 0, this.ATHonly = !1, this.ATHshort = !1, this.noATH = !1, this.ATHtype = 0, this.ATHcurve = 0, this.ATHlower = 0, this.athaa_type = 0, this.athaa_loudapprox = 0, this.athaa_sensitivity = 0, this.short_blocks = null, this.useTemporal = !1, this.interChRatio = 0, this.msfix = 0, this.tune = !1, this.tune_value_a = 0, this.version = 0, this.encoder_delay = 0, this.encoder_padding = 0, this.framesize = 0, this.frameNum = 0, this.lame_allocated_gfp = 0, this.internal_flags = null;
+ }();
+ return 0 != ((e = a).class_id = x, t = e.internal_flags = new Z(), e.mode = Ee.NOT_SET, e.original = 1, e.in_samplerate = 44100, e.num_channels = 2, e.num_samples = -1, e.bWriteVbrTag = !0, e.quality = -1, e.short_blocks = null, t.subblock_gain = -1, e.lowpassfreq = 0, e.highpassfreq = 0, e.lowpasswidth = -1, e.highpasswidth = -1, e.VBR = xe.vbr_off, e.VBR_q = 4, e.ATHcurve = -1, e.VBR_mean_bitrate_kbps = 128, e.VBR_min_bitrate_kbps = 0, e.VBR_max_bitrate_kbps = 0, e.VBR_hard_min = 0, t.VBR_min_bitrate = 1, t.VBR_max_bitrate = 13, e.quant_comp = -1, e.quant_comp_short = -1, e.msfix = -1, t.resample_ratio = 1, t.OldValue[0] = 180, t.OldValue[1] = 180, t.CurrentStep[0] = 4, t.CurrentStep[1] = 4, t.masking_lower = 1, t.nsPsy.attackthre = -1, t.nsPsy.attackthre_s = -1, e.scale = -1, e.athaa_type = -1, e.ATHtype = -1, e.athaa_loudapprox = -1, e.athaa_sensitivity = 0, e.useTemporal = null, e.interChRatio = -1, t.mf_samples_to_encode = Pe.ENCDELAY + Pe.POSTDELAY, e.encoder_padding = 0, t.mf_size = Pe.ENCDELAY - Pe.MDCTDELAY, e.findReplayGain = !1, e.decode_on_the_fly = !1, t.decode_on_the_fly = !1, t.findReplayGain = !1, t.findPeakSample = !1, t.RadioGain = 0, t.AudiophileGain = 0, t.noclipGainChange = 0, t.noclipScale = -1, e.preset = 0, e.write_id3tag_automatic = !0, 0) ? null : (a.lame_allocated_gfp = 1, a);
}, this.nearestBitrateFullIndex = function (e) {
var t = [8, 16, 24, 32, 40, 48, 56, 64, 80, 96, 112, 128, 160, 192, 224, 256, 320],
a = 0,
- n = 0,
s = 0,
+ n = 0,
r = 0;
- r = t[16], n = t[s = 16], a = 16;
+ r = t[16], s = t[n = 16], a = 16;
for (var i = 0; i < 16; i++) if (Math.max(e, t[i + 1]) != e) {
- r = t[i + 1], s = i + 1, n = t[i], a = i;
+ r = t[i + 1], n = i + 1, s = t[i], a = i;
break;
}
- return e - n < r - e ? a : s;
+ return e - s < r - e ? a : n;
}, this.lame_init_params = function (e) {
var t,
a,
+ s,
n = e.internal_flags;
if (n.Class_ID = 0, null == n.ATH && (n.ATH = new function () {
- this.useAdjust = 0, this.aaSensitivityP = 0, this.adjust = 0, this.adjustLimit = 0, this.decay = 0, this.floor = 0, this.l = de(Ae.SBMAX_l), this.s = de(Ae.SBMAX_s), this.psfb21 = de(Ae.PSFB21), this.psfb12 = de(Ae.PSFB12), this.cb_l = de(Ae.CBANDS), this.cb_s = de(Ae.CBANDS), this.eql_w = de(Ae.BLKSIZE / 2);
+ this.useAdjust = 0, this.aaSensitivityP = 0, this.adjust = 0, this.adjustLimit = 0, this.decay = 0, this.floor = 0, this.l = Be(Pe.SBMAX_l), this.s = Be(Pe.SBMAX_s), this.psfb21 = Be(Pe.PSFB21), this.psfb12 = Be(Pe.PSFB12), this.cb_l = Be(Pe.CBANDS), this.cb_s = Be(Pe.CBANDS), this.eql_w = Be(Pe.BLKSIZE / 2);
}()), null == n.PSY && (n.PSY = new function () {
- this.mask_adjust = 0, this.mask_adjust_short = 0, this.bo_l_weight = de(Ae.SBMAX_l), this.bo_s_weight = de(Ae.SBMAX_s);
- }()), null == n.rgdata && (n.rgdata = new function () {}()), n.channels_in = e.num_channels, 1 == n.channels_in && (e.mode = ye.MONO), n.channels_out = e.mode == ye.MONO ? 1 : 2, n.mode_ext = Ae.MPG_MD_MS_LR, e.mode == ye.MONO && (e.force_ms = !1), e.VBR == Me.vbr_off && 128 != e.VBR_mean_bitrate_kbps && 0 == e.brate && (e.brate = e.VBR_mean_bitrate_kbps), e.VBR == Me.vbr_off || e.VBR == Me.vbr_mtrh || e.VBR == Me.vbr_mt || (e.free_format = !1), e.VBR == Me.vbr_off && 0 == e.brate && me(), e.VBR == Me.vbr_off && 0 < e.compression_ratio && me(), 0 != e.out_samplerate && (e.out_samplerate < 16e3 ? (e.VBR_mean_bitrate_kbps = Math.max(e.VBR_mean_bitrate_kbps, 8), e.VBR_mean_bitrate_kbps = Math.min(e.VBR_mean_bitrate_kbps, 64)) : e.out_samplerate < 32e3 ? (e.VBR_mean_bitrate_kbps = Math.max(e.VBR_mean_bitrate_kbps, 8), e.VBR_mean_bitrate_kbps = Math.min(e.VBR_mean_bitrate_kbps, 160)) : (e.VBR_mean_bitrate_kbps = Math.max(e.VBR_mean_bitrate_kbps, 32), e.VBR_mean_bitrate_kbps = Math.min(e.VBR_mean_bitrate_kbps, 320))), 0 == e.lowpassfreq) {
- var s = 16e3;
+ this.mask_adjust = 0, this.mask_adjust_short = 0, this.bo_l_weight = Be(Pe.SBMAX_l), this.bo_s_weight = Be(Pe.SBMAX_s);
+ }()), null == n.rgdata && (n.rgdata = new function () {}()), n.channels_in = e.num_channels, 1 == n.channels_in && (e.mode = Ee.MONO), n.channels_out = e.mode == Ee.MONO ? 1 : 2, n.mode_ext = Pe.MPG_MD_MS_LR, e.mode == Ee.MONO && (e.force_ms = !1), e.VBR == xe.vbr_off && 128 != e.VBR_mean_bitrate_kbps && 0 == e.brate && (e.brate = e.VBR_mean_bitrate_kbps), e.VBR == xe.vbr_off || e.VBR == xe.vbr_mtrh || e.VBR == xe.vbr_mt || (e.free_format = !1), e.VBR == xe.vbr_off && 0 == e.brate && q.EQ(e.compression_ratio, 0) && (e.compression_ratio = 11.025), e.VBR == xe.vbr_off && 0 < e.compression_ratio && (0 == e.out_samplerate && (e.out_samplerate = map2MP3Frequency(int(.97 * e.in_samplerate))), e.brate = 0 | 16 * e.out_samplerate * n.channels_out / (1e3 * e.compression_ratio), n.samplerate_index = P(e.out_samplerate, e), e.free_format || (e.brate = L(e.brate, e.version, e.out_samplerate))), 0 != e.out_samplerate && (e.out_samplerate < 16e3 ? (e.VBR_mean_bitrate_kbps = Math.max(e.VBR_mean_bitrate_kbps, 8), e.VBR_mean_bitrate_kbps = Math.min(e.VBR_mean_bitrate_kbps, 64)) : e.out_samplerate < 32e3 ? (e.VBR_mean_bitrate_kbps = Math.max(e.VBR_mean_bitrate_kbps, 8), e.VBR_mean_bitrate_kbps = Math.min(e.VBR_mean_bitrate_kbps, 160)) : (e.VBR_mean_bitrate_kbps = Math.max(e.VBR_mean_bitrate_kbps, 32), e.VBR_mean_bitrate_kbps = Math.min(e.VBR_mean_bitrate_kbps, 320))), 0 == e.lowpassfreq) {
+ var r = 16e3;
switch (e.VBR) {
- case Me.vbr_off:
- var r = new d();
- g(r, e.brate), s = r.lowerlimit;
+ case xe.vbr_off:
+ H(i = new T(), e.brate), r = i.lowerlimit;
break;
- case Me.vbr_abr:
- var r = new d();
- g(r, e.VBR_mean_bitrate_kbps), s = r.lowerlimit;
+ case xe.vbr_abr:
+ var i;
+ H(i = new T(), e.VBR_mean_bitrate_kbps), r = i.lowerlimit;
+ break;
+ case xe.vbr_rh:
+ var o = [19500, 19e3, 18600, 18e3, 17500, 16e3, 15600, 14900, 12500, 1e4, 3950];
+ if (0 <= e.VBR_q && e.VBR_q <= 9) {
+ var _ = o[e.VBR_q],
+ l = o[e.VBR_q + 1],
+ f = e.VBR_q_frac;
+ r = linear_int(_, l, f);
+ } else r = 19500;
break;
- case Me.vbr_rh:
- me();
default:
- me();
+ o = [19500, 19e3, 18500, 18e3, 17500, 16500, 15500, 14500, 12500, 9500, 3950];
+ if (0 <= e.VBR_q && e.VBR_q <= 9) {
+ _ = o[e.VBR_q], l = o[e.VBR_q + 1], f = e.VBR_q_frac;
+ r = linear_int(_, l, f);
+ } else r = 19500;
}
- e.mode != ye.MONO || e.VBR != Me.vbr_off && e.VBR != Me.vbr_abr || (s *= 1.5), e.lowpassfreq = 0 | s;
+ e.mode != Ee.MONO || e.VBR != xe.vbr_off && e.VBR != xe.vbr_abr || (r *= 1.5), e.lowpassfreq = 0 | r;
}
- switch (0 == e.out_samplerate && me(), e.lowpassfreq = Math.min(20500, e.lowpassfreq), e.lowpassfreq = Math.min(e.out_samplerate / 2, e.lowpassfreq), e.VBR == Me.vbr_off && (e.compression_ratio = 16 * e.out_samplerate * n.channels_out / (1e3 * e.brate)), e.VBR == Me.vbr_abr && me(), e.bWriteVbrTag || (e.findReplayGain = !1, e.decode_on_the_fly = !1, n.findPeakSample = !1), n.findReplayGain = e.findReplayGain, n.decode_on_the_fly = e.decode_on_the_fly, n.decode_on_the_fly && (n.findPeakSample = !0), n.findReplayGain && me(), n.decode_on_the_fly && !e.decode_only && me(), n.mode_gr = e.out_samplerate <= 24e3 ? 1 : 2, e.framesize = 576 * n.mode_gr, e.encoder_delay = Ae.ENCDELAY, n.resample_ratio = e.in_samplerate / e.out_samplerate, e.VBR) {
- case Me.vbr_mt:
- case Me.vbr_rh:
- case Me.vbr_mtrh:
+ if (0 == e.out_samplerate && (2 * e.lowpassfreq > e.in_samplerate && (e.lowpassfreq = e.in_samplerate / 2), e.out_samplerate = (t = 0 | e.lowpassfreq, a = e.in_samplerate, s = 44100, 48e3 <= a ? s = 48e3 : 44100 <= a ? s = 44100 : 32e3 <= a ? s = 32e3 : 24e3 <= a ? s = 24e3 : 22050 <= a ? s = 22050 : 16e3 <= a ? s = 16e3 : 12e3 <= a ? s = 12e3 : 11025 <= a ? s = 11025 : 8e3 <= a && (s = 8e3), -1 == t ? s : (t <= 15960 && (s = 44100), t <= 15250 && (s = 32e3), t <= 11220 && (s = 24e3), t <= 9970 && (s = 22050), t <= 7230 && (s = 16e3), t <= 5420 && (s = 12e3), t <= 4510 && (s = 11025), t <= 3970 && (s = 8e3), a < s ? 44100 < a ? 48e3 : 32e3 < a ? 44100 : 24e3 < a ? 32e3 : 22050 < a ? 24e3 : 16e3 < a ? 22050 : 12e3 < a ? 16e3 : 11025 < a ? 12e3 : 8e3 < a ? 11025 : 8e3 : s))), e.lowpassfreq = Math.min(20500, e.lowpassfreq), e.lowpassfreq = Math.min(e.out_samplerate / 2, e.lowpassfreq), e.VBR == xe.vbr_off && (e.compression_ratio = 16 * e.out_samplerate * n.channels_out / (1e3 * e.brate)), e.VBR == xe.vbr_abr && (e.compression_ratio = 16 * e.out_samplerate * n.channels_out / (1e3 * e.VBR_mean_bitrate_kbps)), e.bWriteVbrTag || (e.findReplayGain = !1, e.decode_on_the_fly = !1, n.findPeakSample = !1), n.findReplayGain = e.findReplayGain, n.decode_on_the_fly = e.decode_on_the_fly, n.decode_on_the_fly && (n.findPeakSample = !0), n.findReplayGain && w.InitGainAnalysis(n.rgdata, e.out_samplerate) == X.INIT_GAIN_ANALYSIS_ERROR) return e.internal_flags = null, -6;
+ switch (n.decode_on_the_fly && !e.decode_only && (null != n.hip && k.hip_decode_exit(n.hip), n.hip = k.hip_decode_init()), n.mode_gr = e.out_samplerate <= 24e3 ? 1 : 2, e.framesize = 576 * n.mode_gr, e.encoder_delay = Pe.ENCDELAY, n.resample_ratio = e.in_samplerate / e.out_samplerate, e.VBR) {
+ case xe.vbr_mt:
+ case xe.vbr_rh:
+ case xe.vbr_mtrh:
e.compression_ratio = [5.7, 6.5, 7.3, 8.2, 10, 11.9, 13, 14, 15, 16.5][e.VBR_q];
break;
- case Me.vbr_abr:
+ case xe.vbr_abr:
e.compression_ratio = 16 * e.out_samplerate * n.channels_out / (1e3 * e.VBR_mean_bitrate_kbps);
break;
default:
e.compression_ratio = 16 * e.out_samplerate * n.channels_out / (1e3 * e.brate);
}
- e.mode == ye.NOT_SET && (e.mode = ye.JOINT_STEREO), 0 < e.highpassfreq ? me() : (n.highpass1 = 0, n.highpass2 = 0), 0 < e.lowpassfreq ? (n.lowpass2 = 2 * e.lowpassfreq, 0 <= e.lowpasswidth ? me() : n.lowpass1 = 2 * e.lowpassfreq, n.lowpass1 /= e.out_samplerate, n.lowpass2 /= e.out_samplerate) : me(), function (e) {
- var t,
- a = e.internal_flags,
- n = 32;
- if (0 < a.lowpass1) {
- for (var s = 999, r = 0; r <= 31; r++) {
- var i = r / 31;
- i >= a.lowpass2 && (n = Math.min(n, r)), a.lowpass1 < i && i < a.lowpass2 && (s = Math.min(s, r));
- }
- a.lowpass1 = 999 == s ? (n - .75) / 31 : (s - .75) / 31, a.lowpass2 = n / 31;
+ if (e.mode == Ee.NOT_SET && (e.mode = Ee.JOINT_STEREO), 0 < e.highpassfreq ? (n.highpass1 = 2 * e.highpassfreq, 0 <= e.highpasswidth ? n.highpass2 = 2 * (e.highpassfreq + e.highpasswidth) : n.highpass2 = 2 * e.highpassfreq, n.highpass1 /= e.out_samplerate, n.highpass2 /= e.out_samplerate) : (n.highpass1 = 0, n.highpass2 = 0), 0 < e.lowpassfreq ? (n.lowpass2 = 2 * e.lowpassfreq, 0 <= e.lowpasswidth ? (n.lowpass1 = 2 * (e.lowpassfreq - e.lowpasswidth), n.lowpass1 < 0 && (n.lowpass1 = 0)) : n.lowpass1 = 2 * e.lowpassfreq, n.lowpass1 /= e.out_samplerate, n.lowpass2 /= e.out_samplerate) : (n.lowpass1 = 0, n.lowpass2 = 0), function (e) {
+ var t = e.internal_flags,
+ a = 32,
+ s = -1;
+ if (0 < t.lowpass1) {
+ for (var n = 999, r = 0; r <= 31; r++) (l = r / 31) >= t.lowpass2 && (a = Math.min(a, r)), t.lowpass1 < l && l < t.lowpass2 && (n = Math.min(n, r));
+ t.lowpass1 = 999 == n ? (a - .75) / 31 : (n - .75) / 31, t.lowpass2 = a / 31;
}
- 0 < a.highpass2 && me(), 0 < a.highpass2 && me();
- for (var r = 0; r < 32; r++) {
+ if (0 < t.highpass2 && t.highpass2 < .75 / 31 * .9 && (t.highpass1 = 0, t.highpass2 = 0, $.err.println("Warning: highpass filter disabled. highpass frequency too small\n")), 0 < t.highpass2) {
+ var i = -1;
+ for (r = 0; r <= 31; r++) (l = r / 31) <= t.highpass1 && (s = Math.max(s, r)), t.highpass1 < l && l < t.highpass2 && (i = Math.max(i, r));
+ t.highpass1 = s / 31, t.highpass2 = -1 == i ? (s + .75) / 31 : (i + .75) / 31;
+ }
+ for (r = 0; r < 32; r++) {
var o,
_,
- i = r / 31;
- a.highpass2 > a.highpass1 ? me() : o = 1, _ = a.lowpass2 > a.lowpass1 ? 1 < (t = (i - a.lowpass1) / (a.lowpass2 - a.lowpass1 + 1e-20)) ? 0 : t <= 0 ? 1 : Math.cos(Math.PI / 2 * t) : 1, a.amp_filter[r] = o * _;
+ l = r / 31;
+ o = t.highpass2 > t.highpass1 ? E((t.highpass2 - l) / (t.highpass2 - t.highpass1 + 1e-20)) : 1, _ = t.lowpass2 > t.lowpass1 ? E((l - t.lowpass1) / (t.lowpass2 - t.lowpass1 + 1e-20)) : 1, t.amp_filter[r] = o * _;
}
- }(e), n.samplerate_index = function (e, t) {
- switch (e) {
- case 44100:
- return t.version = 1, 0;
- case 48e3:
- return t.version = 1;
- case 32e3:
- return t.version = 1, 2;
- case 22050:
- return t.version = 0;
- case 24e3:
- return t.version = 0, 1;
- case 16e3:
- return t.version = 0, 2;
- case 11025:
- return t.version = 0;
- case 12e3:
- return t.version = 0, 1;
- case 8e3:
- return t.version = 0, 2;
- default:
- return t.version = 0, -1;
- }
- }(e.out_samplerate, e), n.samplerate_index < 0 && me(), e.VBR == Me.vbr_off ? e.free_format ? n.bitrate_index = 0 : (e.brate = function (e, t, a) {
- a < 16e3 && (t = 2);
- for (var n = k.bitrate_table[t][1], s = 2; s <= 14; s++) 0 < k.bitrate_table[t][s] && Math.abs(k.bitrate_table[t][s] - e) < Math.abs(n - e) && (n = k.bitrate_table[t][s]);
- return n;
- }(e.brate, e.version, e.out_samplerate), n.bitrate_index = function (e, t, a) {
- a < 16e3 && (t = 2);
- for (var n = 0; n <= 14; n++) if (0 < k.bitrate_table[t][n] && k.bitrate_table[t][n] == e) return n;
- return -1;
- }(e.brate, e.version, e.out_samplerate), n.bitrate_index <= 0 && me()) : n.bitrate_index = 1, e.analysis && (e.bWriteVbrTag = !1), null != n.pinfo && (e.bWriteVbrTag = !1), E.init_bit_stream_w(n);
- for (var i, o = n.samplerate_index + 3 * e.version + 6 * (e.out_samplerate < 16e3 ? 1 : 0), _ = 0; _ < Ae.SBMAX_l + 1; _++) n.scalefac_band.l[_] = h.sfBandIndex[o].l[_];
- for (var _ = 0; _ < Ae.PSFB21 + 1; _++) {
- var l = (n.scalefac_band.l[22] - n.scalefac_band.l[21]) / Ae.PSFB21,
- f = n.scalefac_band.l[21] + _ * l;
- n.scalefac_band.psfb21[_] = f;
+ }(e), n.samplerate_index = P(e.out_samplerate, e), n.samplerate_index < 0) return e.internal_flags = null, -1;
+ if (e.VBR == xe.vbr_off) {
+ if (e.free_format) n.bitrate_index = 0;else if (e.brate = L(e.brate, e.version, e.out_samplerate), n.bitrate_index = I(e.brate, e.version, e.out_samplerate), n.bitrate_index <= 0) return e.internal_flags = null, -1;
+ } else n.bitrate_index = 1;
+ e.analysis && (e.bWriteVbrTag = !1), null != n.pinfo && (e.bWriteVbrTag = !1), R.init_bit_stream_w(n);
+ for (var c, h, u, m = n.samplerate_index + 3 * e.version + 6 * (e.out_samplerate < 16e3 ? 1 : 0), p = 0; p < Pe.SBMAX_l + 1; p++) n.scalefac_band.l[p] = S.sfBandIndex[m].l[p];
+ for (p = 0; p < Pe.PSFB21 + 1; p++) {
+ var b = (n.scalefac_band.l[22] - n.scalefac_band.l[21]) / Pe.PSFB21,
+ v = n.scalefac_band.l[21] + p * b;
+ n.scalefac_band.psfb21[p] = v;
}
- n.scalefac_band.psfb21[Ae.PSFB21] = 576;
- for (var _ = 0; _ < Ae.SBMAX_s + 1; _++) n.scalefac_band.s[_] = h.sfBandIndex[o].s[_];
- for (var _ = 0; _ < Ae.PSFB12 + 1; _++) {
- var l = (n.scalefac_band.s[13] - n.scalefac_band.s[12]) / Ae.PSFB12,
- f = n.scalefac_band.s[12] + _ * l;
- n.scalefac_band.psfb12[_] = f;
+ n.scalefac_band.psfb21[Pe.PSFB21] = 576;
+ for (p = 0; p < Pe.SBMAX_s + 1; p++) n.scalefac_band.s[p] = S.sfBandIndex[m].s[p];
+ for (p = 0; p < Pe.PSFB12 + 1; p++) {
+ b = (n.scalefac_band.s[13] - n.scalefac_band.s[12]) / Pe.PSFB12, v = n.scalefac_band.s[12] + p * b;
+ n.scalefac_band.psfb12[p] = v;
}
- for (n.scalefac_band.psfb12[Ae.PSFB12] = 192, 1 == e.version ? n.sideinfo_len = 1 == n.channels_out ? 21 : 36 : n.sideinfo_len = 1 == n.channels_out ? 13 : 21, e.error_protection && (n.sideinfo_len += 2), a = void 0, a = (t = e).internal_flags, t.frameNum = 0, t.write_id3tag_automatic && m.id3tag_write_v2(t), a.bitrate_stereoMode_Hist = w([16, 5]), a.bitrate_blockType_Hist = w([16, 6]), a.PeakSample = 0, t.bWriteVbrTag && p.InitVbrTag(t), n.Class_ID = I, i = 0; i < 19; i++) n.nsPsy.pefirbuf[i] = 700 * n.mode_gr * n.channels_out;
+ for (n.scalefac_band.psfb12[Pe.PSFB12] = 192, 1 == e.version ? n.sideinfo_len = 1 == n.channels_out ? 21 : 36 : n.sideinfo_len = 1 == n.channels_out ? 13 : 21, e.error_protection && (n.sideinfo_len += 2), h = (c = e).internal_flags, c.frameNum = 0, c.write_id3tag_automatic && B.id3tag_write_v2(c), h.bitrate_stereoMode_Hist = Y([16, 5]), h.bitrate_blockType_Hist = Y([16, 6]), h.PeakSample = 0, c.bWriteVbrTag && A.InitVbrTag(c), n.Class_ID = x, u = 0; u < 19; u++) n.nsPsy.pefirbuf[u] = 700 * n.mode_gr * n.channels_out;
switch (-1 == e.ATHtype && (e.ATHtype = 4), e.VBR) {
- case Me.vbr_mt:
- e.VBR = Me.vbr_mtrh;
- case Me.vbr_mtrh:
- null == e.useTemporal && (e.useTemporal = !1), u.apply_preset(e, 500 - 10 * e.VBR_q, 0), e.quality < 0 && (e.quality = LAME_DEFAULT_QUALITY), e.quality < 5 && (e.quality = 0), 5 < e.quality && (e.quality = 5), n.PSY.mask_adjust = e.maskingadjust, n.PSY.mask_adjust_short = e.maskingadjust_short, e.experimentalY ? n.sfb21_extra = !1 : n.sfb21_extra = 44e3 < e.out_samplerate, n.iteration_loop = new VBRNewIterationLoop(b);
+ case xe.vbr_mt:
+ e.VBR = xe.vbr_mtrh;
+ case xe.vbr_mtrh:
+ null == e.useTemporal && (e.useTemporal = !1), g.apply_preset(e, 500 - 10 * e.VBR_q, 0), e.quality < 0 && (e.quality = LAME_DEFAULT_QUALITY), e.quality < 5 && (e.quality = 0), 5 < e.quality && (e.quality = 5), n.PSY.mask_adjust = e.maskingadjust, n.PSY.mask_adjust_short = e.maskingadjust_short, e.experimentalY ? n.sfb21_extra = !1 : n.sfb21_extra = 44e3 < e.out_samplerate, n.iteration_loop = new VBRNewIterationLoop(M);
break;
- case Me.vbr_rh:
- u.apply_preset(e, 500 - 10 * e.VBR_q, 0), n.PSY.mask_adjust = e.maskingadjust, n.PSY.mask_adjust_short = e.maskingadjust_short, e.experimentalY ? n.sfb21_extra = !1 : n.sfb21_extra = 44e3 < e.out_samplerate, 6 < e.quality && (e.quality = 6), e.quality < 0 && (e.quality = LAME_DEFAULT_QUALITY), n.iteration_loop = new VBROldIterationLoop(b);
+ case xe.vbr_rh:
+ g.apply_preset(e, 500 - 10 * e.VBR_q, 0), n.PSY.mask_adjust = e.maskingadjust, n.PSY.mask_adjust_short = e.maskingadjust_short, e.experimentalY ? n.sfb21_extra = !1 : n.sfb21_extra = 44e3 < e.out_samplerate, 6 < e.quality && (e.quality = 6), e.quality < 0 && (e.quality = LAME_DEFAULT_QUALITY), n.iteration_loop = new VBROldIterationLoop(M);
break;
default:
- var c;
- n.sfb21_extra = !1, e.quality < 0 && (e.quality = LAME_DEFAULT_QUALITY), (c = e.VBR) == Me.vbr_off && (e.VBR_mean_bitrate_kbps = e.brate), u.apply_preset(e, e.VBR_mean_bitrate_kbps, 0), e.VBR = c, n.PSY.mask_adjust = e.maskingadjust, n.PSY.mask_adjust_short = e.maskingadjust_short, c == Me.vbr_off ? n.iteration_loop = new function (e) {
+ var d;
+ n.sfb21_extra = !1, e.quality < 0 && (e.quality = LAME_DEFAULT_QUALITY), (d = e.VBR) == xe.vbr_off && (e.VBR_mean_bitrate_kbps = e.brate), g.apply_preset(e, e.VBR_mean_bitrate_kbps, 0), e.VBR = d, n.PSY.mask_adjust = e.maskingadjust, n.PSY.mask_adjust_short = e.maskingadjust_short, n.iteration_loop = d == xe.vbr_off ? new function (e) {
var t = e;
- this.quantize = t, this.iteration_loop = function (e, t, a, n) {
- var s = e.internal_flags,
- r = de(F.SFBMAX),
- i = de(576),
- o = ve(2),
- _ = 0,
- l = s.l3_side,
- f = new R(_);
- this.quantize.rv.ResvFrameBegin(e, f), _ = f.bits;
- for (var c = 0; c < s.mode_gr; c++) {
- this.quantize.qupvt.on_pe(e, t, o, _, c, c), s.mode_ext == Ae.MPG_MD_MS_LR && me();
- for (var u = 0; u < s.channels_out; u++) {
- var h,
- b,
- p = l.tt[c][u];
- p.block_type != Ae.SHORT_TYPE ? (h = 0, b = s.PSY.mask_adjust - h) : (h = 0, b = s.PSY.mask_adjust_short - h), s.masking_lower = Math.pow(10, .1 * b), this.quantize.init_outer_loop(s, p), this.quantize.init_xrpow(s, p, i) && (this.quantize.qupvt.calc_xmin(e, n[c][u], p, r), this.quantize.outer_loop(e, p, r, i, u, o[u])), this.quantize.iteration_finish_one(s, c, u);
+ this.quantize = t, this.iteration_loop = function (e, t, a, s) {
+ var n,
+ r = e.internal_flags,
+ i = Be(z.SFBMAX),
+ o = Be(576),
+ _ = Ae(2),
+ l = 0,
+ f = r.l3_side,
+ c = new j(l);
+ this.quantize.rv.ResvFrameBegin(e, c), l = c.bits;
+ for (var h = 0; h < r.mode_gr; h++) {
+ n = this.quantize.qupvt.on_pe(e, t, _, l, h, h), r.mode_ext == Pe.MPG_MD_MS_LR && (this.quantize.ms_convert(r.l3_side, h), this.quantize.qupvt.reduce_side(_, a[h], l, n));
+ for (var u = 0; u < r.channels_out; u++) {
+ var m,
+ p,
+ b = f.tt[h][u];
+ b.block_type != Pe.SHORT_TYPE ? (m = 0, p = r.PSY.mask_adjust - m) : (m = 0, p = r.PSY.mask_adjust_short - m), r.masking_lower = Math.pow(10, .1 * p), this.quantize.init_outer_loop(r, b), this.quantize.init_xrpow(r, b, o) && (this.quantize.qupvt.calc_xmin(e, s[h][u], b, i), this.quantize.outer_loop(e, b, i, o, u, _[u])), this.quantize.iteration_finish_one(r, h, u);
}
}
- this.quantize.rv.ResvFrameEnd(s, _);
+ this.quantize.rv.ResvFrameEnd(r, l);
};
- }(b) : me();
+ }(M) : new ABRIterationLoop(M);
}
- return e.VBR != Me.vbr_off && me(), e.tune && me(), function (e) {
+ if (e.VBR != xe.vbr_off) {
+ if (n.VBR_min_bitrate = 1, n.VBR_max_bitrate = 14, e.out_samplerate < 16e3 && (n.VBR_max_bitrate = 8), 0 != e.VBR_min_bitrate_kbps && (e.VBR_min_bitrate_kbps = L(e.VBR_min_bitrate_kbps, e.version, e.out_samplerate), n.VBR_min_bitrate = I(e.VBR_min_bitrate_kbps, e.version, e.out_samplerate), n.VBR_min_bitrate < 0)) return -1;
+ if (0 != e.VBR_max_bitrate_kbps && (e.VBR_max_bitrate_kbps = L(e.VBR_max_bitrate_kbps, e.version, e.out_samplerate), n.VBR_max_bitrate = I(e.VBR_max_bitrate_kbps, e.version, e.out_samplerate), n.VBR_max_bitrate < 0)) return -1;
+ e.VBR_min_bitrate_kbps = F.bitrate_table[e.version][n.VBR_min_bitrate], e.VBR_max_bitrate_kbps = F.bitrate_table[e.version][n.VBR_max_bitrate], e.VBR_mean_bitrate_kbps = Math.min(F.bitrate_table[e.version][n.VBR_max_bitrate], e.VBR_mean_bitrate_kbps), e.VBR_mean_bitrate_kbps = Math.max(F.bitrate_table[e.version][n.VBR_min_bitrate], e.VBR_mean_bitrate_kbps);
+ }
+ return e.tune && (n.PSY.mask_adjust += e.tune_value_a, n.PSY.mask_adjust_short += e.tune_value_a), function (e) {
var t = e.internal_flags;
switch (e.quality) {
default:
@@ -37013,229 +37315,252 @@ src: recorder-core.js,engine/mp3.js,engine/mp3-engine.js
case 0:
t.psymodel = 1, 0 == t.noise_shaping && (t.noise_shaping = 1), 0 == t.substep_shaping && (t.substep_shaping = 2), t.noise_shaping_amp = 2, -(t.noise_shaping_stop = 1) == t.subblock_gain && (t.subblock_gain = 1), t.use_best_huffman = 1, t.full_outer_loop = 0;
}
- }(e), e.athaa_type < 0 ? n.ATH.useAdjust = 3 : n.ATH.useAdjust = e.athaa_type, n.ATH.aaSensitivityP = Math.pow(10, e.athaa_sensitivity / -10), null == e.short_blocks && (e.short_blocks = Se.short_block_allowed), e.short_blocks != Se.short_block_allowed || e.mode != ye.JOINT_STEREO && e.mode != ye.STEREO || (e.short_blocks = Se.short_block_coupled), e.quant_comp < 0 && (e.quant_comp = 1), e.quant_comp_short < 0 && (e.quant_comp_short = 0), e.msfix < 0 && (e.msfix = 0), e.exp_nspsytune = 1 | e.exp_nspsytune, e.internal_flags.nsPsy.attackthre < 0 && (e.internal_flags.nsPsy.attackthre = X.NSATTACKTHRE), e.internal_flags.nsPsy.attackthre_s < 0 && (e.internal_flags.nsPsy.attackthre_s = X.NSATTACKTHRE_S), e.scale < 0 && (e.scale = 1), e.ATHtype < 0 && (e.ATHtype = 4), e.ATHcurve < 0 && (e.ATHcurve = 4), e.athaa_loudapprox < 0 && (e.athaa_loudapprox = 2), e.interChRatio < 0 && (e.interChRatio = 0), null == e.useTemporal && (e.useTemporal = !0), n.slot_lag = n.frac_SpF = 0, e.VBR == Me.vbr_off && (n.slot_lag = n.frac_SpF = 72e3 * (e.version + 1) * e.brate % e.out_samplerate | 0), h.iteration_init(e), v.psymodel_init(e), 0;
- }, this.lame_encode_flush = function (e, t, a, n) {
- var s,
+ }(e), e.athaa_type < 0 ? n.ATH.useAdjust = 3 : n.ATH.useAdjust = e.athaa_type, n.ATH.aaSensitivityP = Math.pow(10, e.athaa_sensitivity / -10), null == e.short_blocks && (e.short_blocks = Te.short_block_allowed), e.short_blocks != Te.short_block_allowed || e.mode != Ee.JOINT_STEREO && e.mode != Ee.STEREO || (e.short_blocks = Te.short_block_coupled), e.quant_comp < 0 && (e.quant_comp = 1), e.quant_comp_short < 0 && (e.quant_comp_short = 0), e.msfix < 0 && (e.msfix = 0), e.exp_nspsytune = 1 | e.exp_nspsytune, e.internal_flags.nsPsy.attackthre < 0 && (e.internal_flags.nsPsy.attackthre = G.NSATTACKTHRE), e.internal_flags.nsPsy.attackthre_s < 0 && (e.internal_flags.nsPsy.attackthre_s = G.NSATTACKTHRE_S), e.scale < 0 && (e.scale = 1), e.ATHtype < 0 && (e.ATHtype = 4), e.ATHcurve < 0 && (e.ATHcurve = 4), e.athaa_loudapprox < 0 && (e.athaa_loudapprox = 2), e.interChRatio < 0 && (e.interChRatio = 0), null == e.useTemporal && (e.useTemporal = !0), n.slot_lag = n.frac_SpF = 0, e.VBR == xe.vbr_off && (n.slot_lag = n.frac_SpF = 72e3 * (e.version + 1) * e.brate % e.out_samplerate | 0), S.iteration_init(e), y.psymodel_init(e), 0;
+ }, this.lame_encode_flush = function (e, t, a, s) {
+ var n,
r,
i,
o,
_ = e.internal_flags,
- l = M([2, 1152]),
+ l = p([2, 1152]),
f = 0,
- c = _.mf_samples_to_encode - Ae.POSTDELAY,
- u = L(e);
+ c = _.mf_samples_to_encode - Pe.POSTDELAY,
+ h = C(e);
if (_.mf_samples_to_encode < 1) return 0;
- for (s = 0, e.in_samplerate != e.out_samplerate && me(), (i = e.framesize - c % e.framesize) < 576 && (i += e.framesize), e.encoder_padding = i, o = (c + i) / e.framesize; 0 < o && 0 <= f;) {
- var h = u - _.mf_size,
- b = e.frameNum;
- h *= e.in_samplerate, 1152 < (h /= e.out_samplerate) && (h = 1152), h < 1 && (h = 1), r = n - s, 0 == n && (r = 0), f = this.lame_encode_buffer(e, l[0], l[1], h, t, a, r), a += f, s += f, o -= b != e.frameNum ? 1 : 0;
+ for (n = 0, e.in_samplerate != e.out_samplerate && (c += 16 * e.out_samplerate / e.in_samplerate), (i = e.framesize - c % e.framesize) < 576 && (i += e.framesize), o = (c + (e.encoder_padding = i)) / e.framesize; 0 < o && 0 <= f;) {
+ var u = h - _.mf_size,
+ m = e.frameNum;
+ u *= e.in_samplerate, 1152 < (u /= e.out_samplerate) && (u = 1152), u < 1 && (u = 1), r = s - n, 0 == s && (r = 0), a += f = this.lame_encode_buffer(e, l[0], l[1], u, t, a, r), n += f, o -= m != e.frameNum ? 1 : 0;
}
- return _.mf_samples_to_encode = 0, f < 0 ? f : (r = n - s, 0 == n && (r = 0), E.flush_bitstream(e), (f = E.copy_buffer(_, t, a, r, 1)) < 0 ? f : (a += f, r = n - (s += f), 0 == n && (r = 0), e.write_id3tag_automatic && me(), s));
- }, this.lame_encode_buffer = function (e, t, a, n, s, r, i) {
+ if (f < (_.mf_samples_to_encode = 0)) return f;
+ if (r = s - n, 0 == s && (r = 0), R.flush_bitstream(e), (f = R.copy_buffer(_, t, a, r, 1)) < 0) return f;
+ if (a += f, r = s - (n += f), 0 == s && (r = 0), e.write_id3tag_automatic) {
+ if (B.id3tag_write_v1(e), (f = R.copy_buffer(_, t, a, r, 0)) < 0) return f;
+ n += f;
+ }
+ return n;
+ }, this.lame_encode_buffer = function (e, t, a, s, n, r, i) {
var o,
_,
l = e.internal_flags,
f = [null, null];
- if (l.Class_ID != I) return -3;
- if (0 == n) return 0;
- _ = n, (null == (o = l).in_buffer_0 || o.in_buffer_nsamples < _) && (o.in_buffer_0 = de(_), o.in_buffer_1 = de(_), o.in_buffer_nsamples = _), f[0] = l.in_buffer_0, f[1] = l.in_buffer_1;
- for (var c = 0; c < n; c++) f[0][c] = t[c], 1 < l.channels_in && (f[1][c] = a[c]);
- return function (e, t, a, n, s, r, i) {
+ if (l.Class_ID != x) return -3;
+ if (0 == s) return 0;
+ _ = s, (null == (o = l).in_buffer_0 || o.in_buffer_nsamples < _) && (o.in_buffer_0 = Be(_), o.in_buffer_1 = Be(_), o.in_buffer_nsamples = _), f[0] = l.in_buffer_0, f[1] = l.in_buffer_1;
+ for (var c = 0; c < s; c++) f[0][c] = t[c], 1 < l.channels_in && (f[1][c] = a[c]);
+ return function (e, t, a, s, n, r, i) {
var o,
_,
l,
f,
c,
- u = e.internal_flags,
- h = 0,
- b = [null, null],
+ h = e.internal_flags,
+ u = 0,
+ m = [null, null],
p = [null, null];
- if (u.Class_ID != I) return -3;
- if (0 == n) return 0;
- if ((c = E.copy_buffer(u, s, r, i, 0)) < 0) return c;
- if (r += c, h += c, p[0] = t, p[1] = a, N.NEQ(e.scale, 0) && N.NEQ(e.scale, 1)) for (_ = 0; _ < n; ++_) p[0][_] *= e.scale, 2 == u.channels_out && (p[1][_] *= e.scale);
- if (N.NEQ(e.scale_left, 0) && N.NEQ(e.scale_left, 1)) for (_ = 0; _ < n; ++_) p[0][_] *= e.scale_left;
- if (N.NEQ(e.scale_right, 0) && N.NEQ(e.scale_right, 1)) for (_ = 0; _ < n; ++_) p[1][_] *= e.scale_right;
- 2 == e.num_channels && 1 == u.channels_out && me(), f = L(e), b[0] = u.mfbuf[0], b[1] = u.mfbuf[1];
- for (var m, v, d, g, w, S, M, y = 0; 0 < n;) {
- var A = [null, null],
- k = 0,
- R = 0;
- A[0] = p[0], A[1] = p[1];
- var x = new P();
- if (H(e, b, A, y, n, x), k = x.n_in, R = x.n_out, u.findReplayGain && !u.decode_on_the_fly && T.AnalyzeSamples(u.rgdata, b[0], u.mf_size, b[1], u.mf_size, R, u.channels_out) == O.GAIN_ANALYSIS_ERROR) return -6;
- if (n -= k, y += k, u.channels_out, u.mf_size += R, u.mf_samples_to_encode < 1 && me(), u.mf_samples_to_encode += R, u.mf_size >= f) {
- var B = i - h;
- if (0 == i && (B = 0), m = e, v = b[0], d = b[1], g = s, w = r, S = B, M = C.enc.lame_encode_mp3_frame(m, v, d, g, w, S), m.frameNum++, (o = M) < 0) return o;
- for (r += o, h += o, u.mf_size -= e.framesize, u.mf_samples_to_encode -= e.framesize, l = 0; l < u.channels_out; l++) for (_ = 0; _ < u.mf_size; _++) b[l][_] = b[l][_ + e.framesize];
+ if (h.Class_ID != x) return -3;
+ if (0 == s) return 0;
+ if ((c = R.copy_buffer(h, n, r, i, 0)) < 0) return c;
+ if (r += c, u += c, p[0] = t, p[1] = a, q.NEQ(e.scale, 0) && q.NEQ(e.scale, 1)) for (_ = 0; _ < s; ++_) p[0][_] *= e.scale, 2 == h.channels_out && (p[1][_] *= e.scale);
+ if (q.NEQ(e.scale_left, 0) && q.NEQ(e.scale_left, 1)) for (_ = 0; _ < s; ++_) p[0][_] *= e.scale_left;
+ if (q.NEQ(e.scale_right, 0) && q.NEQ(e.scale_right, 1)) for (_ = 0; _ < s; ++_) p[1][_] *= e.scale_right;
+ if (2 == e.num_channels && 1 == h.channels_out) for (_ = 0; _ < s; ++_) p[0][_] = .5 * (p[0][_] + p[1][_]), p[1][_] = 0;
+ f = C(e), m[0] = h.mfbuf[0], m[1] = h.mfbuf[1];
+ var b = 0;
+ for (; 0 < s;) {
+ var v = [null, null],
+ d = 0,
+ g = 0;
+ v[0] = p[0], v[1] = p[1];
+ var S = new O();
+ if (D(e, m, v, b, s, S), d = S.n_in, g = S.n_out, h.findReplayGain && !h.decode_on_the_fly && w.AnalyzeSamples(h.rgdata, m[0], h.mf_size, m[1], h.mf_size, g, h.channels_out) == X.GAIN_ANALYSIS_ERROR) return -6;
+ if (s -= d, b += d, h.channels_out, h.mf_size += g, h.mf_samples_to_encode < 1 && (h.mf_samples_to_encode = Pe.ENCDELAY + Pe.POSTDELAY), h.mf_samples_to_encode += g, h.mf_size >= f) {
+ var M = i - u;
+ if (0 == i && (M = 0), (o = V(e, m[0], m[1], n, r, M)) < 0) return o;
+ for (r += o, u += o, h.mf_size -= e.framesize, h.mf_samples_to_encode -= e.framesize, l = 0; l < h.channels_out; l++) for (_ = 0; _ < h.mf_size; _++) m[l][_] = m[l][_ + e.framesize];
}
}
- return h;
- }(e, f[0], f[1], n, s, r, i);
+ return u;
+ }(e, f[0], f[1], s, n, r, i);
};
}
- F.SFBMAX = 3 * Ae.SBMAX_s, Ae.ENCDELAY = 576, Ae.POSTDELAY = 1152, Ae.FFTOFFSET = 224 + (Ae.MDCTDELAY = 48), Ae.DECDELAY = 528, Ae.SBLIMIT = 32, Ae.CBANDS = 64, Ae.SBPSY_l = 21, Ae.SBPSY_s = 12, Ae.SBMAX_l = 22, Ae.SBMAX_s = 13, Ae.PSFB21 = 6, Ae.PSFB12 = 6, Ae.HBLKSIZE = (Ae.BLKSIZE = 1024) / 2 + 1, Ae.HBLKSIZE_s = (Ae.BLKSIZE_s = 256) / 2 + 1, Ae.NORM_TYPE = 0, Ae.START_TYPE = 1, Ae.SHORT_TYPE = 2, Ae.STOP_TYPE = 3, Ae.MPG_MD_LR_LR = 0, Ae.MPG_MD_LR_I = 1, Ae.MPG_MD_MS_LR = 2, Ae.MPG_MD_MS_I = 3, Ae.fircoef = [-.1039435, -.1892065, 5 * -.0432472, -.155915, 3.898045e-17, .0467745 * 5, .50455, .756825, .187098 * 5], j.MFSIZE = 3456 + Ae.ENCDELAY - Ae.MDCTDELAY, j.MAX_HEADER_BUF = 256, j.MAX_BITS_PER_CHANNEL = 4095, j.MAX_BITS_PER_GRANULE = 7680, j.BPC = 320, F.SFBMAX = 3 * Ae.SBMAX_s, t.Mp3Encoder = function (n, e, t) {
- 1 != n && me("fix cc: only supports mono");
- var s = new Y(),
+ z.SFBMAX = 3 * Pe.SBMAX_s, Pe.ENCDELAY = 576, Pe.POSTDELAY = 1152, Pe.FFTOFFSET = 224 + (Pe.MDCTDELAY = 48), Pe.DECDELAY = 528, Pe.SBLIMIT = 32, Pe.CBANDS = 64, Pe.SBPSY_l = 21, Pe.SBPSY_s = 12, Pe.SBMAX_l = 22, Pe.SBMAX_s = 13, Pe.PSFB21 = 6, Pe.PSFB12 = 6, Pe.HBLKSIZE = (Pe.BLKSIZE = 1024) / 2 + 1, Pe.HBLKSIZE_s = (Pe.BLKSIZE_s = 256) / 2 + 1, Pe.NORM_TYPE = 0, Pe.START_TYPE = 1, Pe.SHORT_TYPE = 2, Pe.STOP_TYPE = 3, Pe.MPG_MD_LR_LR = 0, Pe.MPG_MD_LR_I = 1, Pe.MPG_MD_MS_LR = 2, Pe.MPG_MD_MS_I = 3, Pe.fircoef = [-.1039435, -.1892065, 5 * -.0432472, -.155915, 3.898045e-17, .0467745 * 5, .50455, .756825, .187098 * 5], Z.MFSIZE = 3456 + Pe.ENCDELAY - Pe.MDCTDELAY, Z.MAX_HEADER_BUF = 256, Z.MAX_BITS_PER_CHANNEL = 4095, Z.MAX_BITS_PER_GRANULE = 7680, Z.BPC = 320, z.SFBMAX = 3 * Pe.SBMAX_s, t.Mp3Encoder = function (s, e, t) {
+ 3 != arguments.length && (console.error("WARN: Mp3Encoder(channels, samplerate, kbps) not specified"), s = 1, e = 44100, t = 128);
+ var n = new U(),
a = new function () {
this.setModules = function (e, t) {};
}(),
- r = new O(),
- i = new N(),
+ r = new X(),
+ i = new q(),
o = new function () {
- function e(e, t, a, n, s, r, i, o, _, l, f, c, u, h) {
- this.quant_comp = t, this.quant_comp_s = a, this.safejoint = n, this.nsmsfix = s, this.st_lrm = r, this.st_s = i, this.nsbass = o, this.scale = _, this.masking_adj = l, this.ath_lower = f, this.ath_curve = c, this.interch = u, this.sfscale = h;
+ function e(e, t, a, s, n, r, i, o, _, l, f, c, h, u, m) {
+ this.vbr_q = e, this.quant_comp = t, this.quant_comp_s = a, this.expY = s, this.st_lrm = n, this.st_s = r, this.masking_adj = i, this.masking_adj_short = o, this.ath_lower = _, this.ath_curve = l, this.ath_sensitivity = f, this.interch = c, this.safejoint = h, this.sfb21mod = u, this.msfix = m;
+ }
+ function t(e, t, a, s, n, r, i, o, _, l, f, c, h, u) {
+ this.quant_comp = t, this.quant_comp_s = a, this.safejoint = s, this.nsmsfix = n, this.st_lrm = r, this.st_s = i, this.nsbass = o, this.scale = _, this.masking_adj = l, this.ath_lower = f, this.ath_curve = c, this.interch = h, this.sfscale = u;
}
var i;
- function n(e, t, a) {
- me();
- }
this.setModules = function (e) {
i = e;
};
- var o = [new e(8, 9, 9, 0, 0, 6.6, 145, 0, .95, 0, -30, 11, .0012, 1), new e(16, 9, 9, 0, 0, 6.6, 145, 0, .95, 0, -25, 11, .001, 1), new e(24, 9, 9, 0, 0, 6.6, 145, 0, .95, 0, -20, 11, .001, 1), new e(32, 9, 9, 0, 0, 6.6, 145, 0, .95, 0, -15, 11, .001, 1), new e(40, 9, 9, 0, 0, 6.6, 145, 0, .95, 0, -10, 11, 9e-4, 1), new e(48, 9, 9, 0, 0, 6.6, 145, 0, .95, 0, -10, 11, 9e-4, 1), new e(56, 9, 9, 0, 0, 6.6, 145, 0, .95, 0, -6, 11, 8e-4, 1), new e(64, 9, 9, 0, 0, 6.6, 145, 0, .95, 0, -2, 11, 8e-4, 1), new e(80, 9, 9, 0, 0, 6.6, 145, 0, .95, 0, 0, 8, 7e-4, 1), new e(96, 9, 9, 0, 2.5, 6.6, 145, 0, .95, 0, 1, 5.5, 6e-4, 1), new e(112, 9, 9, 0, 2.25, 6.6, 145, 0, .95, 0, 2, 4.5, 5e-4, 1), new e(128, 9, 9, 0, 1.95, 6.4, 140, 0, .95, 0, 3, 4, 2e-4, 1), new e(160, 9, 9, 1, 1.79, 6, 135, 0, .95, -2, 5, 3.5, 0, 1), new e(192, 9, 9, 1, 1.49, 5.6, 125, 0, .97, -4, 7, 3, 0, 0), new e(224, 9, 9, 1, 1.25, 5.2, 125, 0, .98, -6, 9, 2, 0, 0), new e(256, 9, 9, 1, .97, 5.2, 125, 0, 1, -8, 10, 1, 0, 0), new e(320, 9, 9, 1, .9, 5.2, 125, 0, 1, -10, 12, 0, 0, 0)];
+ var f = [new e(0, 9, 9, 0, 5.2, 125, -4.2, -6.3, 4.8, 1, 0, 0, 2, 21, .97), new e(1, 9, 9, 0, 5.3, 125, -3.6, -5.6, 4.5, 1.5, 0, 0, 2, 21, 1.35), new e(2, 9, 9, 0, 5.6, 125, -2.2, -3.5, 2.8, 2, 0, 0, 2, 21, 1.49), new e(3, 9, 9, 1, 5.8, 130, -1.8, -2.8, 2.6, 3, -4, 0, 2, 20, 1.64), new e(4, 9, 9, 1, 6, 135, -.7, -1.1, 1.1, 3.5, -8, 0, 2, 0, 1.79), new e(5, 9, 9, 1, 6.4, 140, .5, .4, -7.5, 4, -12, 2e-4, 0, 0, 1.95), new e(6, 9, 9, 1, 6.6, 145, .67, .65, -14.7, 6.5, -19, 4e-4, 0, 0, 2.3), new e(7, 9, 9, 1, 6.6, 145, .8, .75, -19.7, 8, -22, 6e-4, 0, 0, 2.7), new e(8, 9, 9, 1, 6.6, 145, 1.2, 1.15, -27.5, 10, -23, 7e-4, 0, 0, 0), new e(9, 9, 9, 1, 6.6, 145, 1.6, 1.6, -36, 11, -25, 8e-4, 0, 0, 0), new e(10, 9, 9, 1, 6.6, 145, 2, 2, -36, 12, -25, 8e-4, 0, 0, 0)],
+ c = [new e(0, 9, 9, 0, 4.2, 25, -7, -4, 7.5, 1, 0, 0, 2, 26, .97), new e(1, 9, 9, 0, 4.2, 25, -5.6, -3.6, 4.5, 1.5, 0, 0, 2, 21, 1.35), new e(2, 9, 9, 0, 4.2, 25, -4.4, -1.8, 2, 2, 0, 0, 2, 18, 1.49), new e(3, 9, 9, 1, 4.2, 25, -3.4, -1.25, 1.1, 3, -4, 0, 2, 15, 1.64), new e(4, 9, 9, 1, 4.2, 25, -2.2, .1, 0, 3.5, -8, 0, 2, 0, 1.79), new e(5, 9, 9, 1, 4.2, 25, -1, 1.65, -7.7, 4, -12, 2e-4, 0, 0, 1.95), new e(6, 9, 9, 1, 4.2, 25, -0, 2.47, -7.7, 6.5, -19, 4e-4, 0, 0, 2), new e(7, 9, 9, 1, 4.2, 25, .5, 2, -14.5, 8, -22, 6e-4, 0, 0, 2), new e(8, 9, 9, 1, 4.2, 25, 1, 2.4, -22, 10, -23, 7e-4, 0, 0, 2), new e(9, 9, 9, 1, 4.2, 25, 1.5, 2.95, -30, 11, -25, 8e-4, 0, 0, 2), new e(10, 9, 9, 1, 4.2, 25, 2, 2.95, -36, 12, -30, 8e-4, 0, 0, 2)];
function s(e, t, a) {
- var n = t,
- s = i.nearestBitrateFullIndex(t);
- if (e.VBR = Me.vbr_abr, e.VBR_mean_bitrate_kbps = n, e.VBR_mean_bitrate_kbps = Math.min(e.VBR_mean_bitrate_kbps, 320), e.VBR_mean_bitrate_kbps = Math.max(e.VBR_mean_bitrate_kbps, 8), e.brate = e.VBR_mean_bitrate_kbps, 320 < e.VBR_mean_bitrate_kbps && (e.disable_reservoir = !0), 0 < o[s].safejoint && (e.exp_nspsytune = 2 | e.exp_nspsytune), 0 < o[s].sfscale && (e.internal_flags.noise_shaping = 2), 0 < Math.abs(o[s].nsbass)) {
- var r = int(4 * o[s].nsbass);
+ var s,
+ n,
+ r = e.VBR == xe.vbr_rh ? f : c,
+ i = e.VBR_q_frac,
+ o = r[t],
+ _ = r[t + 1],
+ l = o;
+ o.st_lrm = o.st_lrm + i * (_.st_lrm - o.st_lrm), o.st_s = o.st_s + i * (_.st_s - o.st_s), o.masking_adj = o.masking_adj + i * (_.masking_adj - o.masking_adj), o.masking_adj_short = o.masking_adj_short + i * (_.masking_adj_short - o.masking_adj_short), o.ath_lower = o.ath_lower + i * (_.ath_lower - o.ath_lower), o.ath_curve = o.ath_curve + i * (_.ath_curve - o.ath_curve), o.ath_sensitivity = o.ath_sensitivity + i * (_.ath_sensitivity - o.ath_sensitivity), o.interch = o.interch + i * (_.interch - o.interch), o.msfix = o.msfix + i * (_.msfix - o.msfix), s = e, (n = l.vbr_q) < 0 && (n = 0), 9 < n && (n = 9), s.VBR_q = n, (s.VBR_q_frac = 0) != a ? e.quant_comp = l.quant_comp : 0 < Math.abs(e.quant_comp - -1) || (e.quant_comp = l.quant_comp), 0 != a ? e.quant_comp_short = l.quant_comp_s : 0 < Math.abs(e.quant_comp_short - -1) || (e.quant_comp_short = l.quant_comp_s), 0 != l.expY && (e.experimentalY = 0 != l.expY), 0 != a ? e.internal_flags.nsPsy.attackthre = l.st_lrm : 0 < Math.abs(e.internal_flags.nsPsy.attackthre - -1) || (e.internal_flags.nsPsy.attackthre = l.st_lrm), 0 != a ? e.internal_flags.nsPsy.attackthre_s = l.st_s : 0 < Math.abs(e.internal_flags.nsPsy.attackthre_s - -1) || (e.internal_flags.nsPsy.attackthre_s = l.st_s), 0 != a ? e.maskingadjust = l.masking_adj : 0 < Math.abs(e.maskingadjust - 0) || (e.maskingadjust = l.masking_adj), 0 != a ? e.maskingadjust_short = l.masking_adj_short : 0 < Math.abs(e.maskingadjust_short - 0) || (e.maskingadjust_short = l.masking_adj_short), 0 != a ? e.ATHlower = -l.ath_lower / 10 : 0 < Math.abs(10 * -e.ATHlower - 0) || (e.ATHlower = -l.ath_lower / 10), 0 != a ? e.ATHcurve = l.ath_curve : 0 < Math.abs(e.ATHcurve - -1) || (e.ATHcurve = l.ath_curve), 0 != a ? e.athaa_sensitivity = l.ath_sensitivity : 0 < Math.abs(e.athaa_sensitivity - -1) || (e.athaa_sensitivity = l.ath_sensitivity), 0 < l.interch && (0 != a ? e.interChRatio = l.interch : 0 < Math.abs(e.interChRatio - -1) || (e.interChRatio = l.interch)), 0 < l.safejoint && (e.exp_nspsytune = e.exp_nspsytune | l.safejoint), 0 < l.sfb21mod && (e.exp_nspsytune = e.exp_nspsytune | l.sfb21mod << 20), 0 != a ? e.msfix = l.msfix : 0 < Math.abs(e.msfix - -1) || (e.msfix = l.msfix), 0 == a && (e.VBR_q = t, e.VBR_q_frac = i);
+ }
+ var o = [new t(8, 9, 9, 0, 0, 6.6, 145, 0, .95, 0, -30, 11, .0012, 1), new t(16, 9, 9, 0, 0, 6.6, 145, 0, .95, 0, -25, 11, .001, 1), new t(24, 9, 9, 0, 0, 6.6, 145, 0, .95, 0, -20, 11, .001, 1), new t(32, 9, 9, 0, 0, 6.6, 145, 0, .95, 0, -15, 11, .001, 1), new t(40, 9, 9, 0, 0, 6.6, 145, 0, .95, 0, -10, 11, 9e-4, 1), new t(48, 9, 9, 0, 0, 6.6, 145, 0, .95, 0, -10, 11, 9e-4, 1), new t(56, 9, 9, 0, 0, 6.6, 145, 0, .95, 0, -6, 11, 8e-4, 1), new t(64, 9, 9, 0, 0, 6.6, 145, 0, .95, 0, -2, 11, 8e-4, 1), new t(80, 9, 9, 0, 0, 6.6, 145, 0, .95, 0, 0, 8, 7e-4, 1), new t(96, 9, 9, 0, 2.5, 6.6, 145, 0, .95, 0, 1, 5.5, 6e-4, 1), new t(112, 9, 9, 0, 2.25, 6.6, 145, 0, .95, 0, 2, 4.5, 5e-4, 1), new t(128, 9, 9, 0, 1.95, 6.4, 140, 0, .95, 0, 3, 4, 2e-4, 1), new t(160, 9, 9, 1, 1.79, 6, 135, 0, .95, -2, 5, 3.5, 0, 1), new t(192, 9, 9, 1, 1.49, 5.6, 125, 0, .97, -4, 7, 3, 0, 0), new t(224, 9, 9, 1, 1.25, 5.2, 125, 0, .98, -6, 9, 2, 0, 0), new t(256, 9, 9, 1, .97, 5.2, 125, 0, 1, -8, 10, 1, 0, 0), new t(320, 9, 9, 1, .9, 5.2, 125, 0, 1, -10, 12, 0, 0, 0)];
+ function n(e, t, a) {
+ var s = t,
+ n = i.nearestBitrateFullIndex(t);
+ if (e.VBR = xe.vbr_abr, e.VBR_mean_bitrate_kbps = s, e.VBR_mean_bitrate_kbps = Math.min(e.VBR_mean_bitrate_kbps, 320), e.VBR_mean_bitrate_kbps = Math.max(e.VBR_mean_bitrate_kbps, 8), e.brate = e.VBR_mean_bitrate_kbps, 320 < e.VBR_mean_bitrate_kbps && (e.disable_reservoir = !0), 0 < o[n].safejoint && (e.exp_nspsytune = 2 | e.exp_nspsytune), 0 < o[n].sfscale && (e.internal_flags.noise_shaping = 2), 0 < Math.abs(o[n].nsbass)) {
+ var r = int(4 * o[n].nsbass);
r < 0 && (r += 64), e.exp_nspsytune = e.exp_nspsytune | r << 2;
}
- return 0 != a ? e.quant_comp = o[s].quant_comp : 0 < Math.abs(e.quant_comp - -1) || (e.quant_comp = o[s].quant_comp), 0 != a ? e.quant_comp_short = o[s].quant_comp_s : 0 < Math.abs(e.quant_comp_short - -1) || (e.quant_comp_short = o[s].quant_comp_s), 0 != a ? e.msfix = o[s].nsmsfix : 0 < Math.abs(e.msfix - -1) || (e.msfix = o[s].nsmsfix), 0 != a ? e.internal_flags.nsPsy.attackthre = o[s].st_lrm : 0 < Math.abs(e.internal_flags.nsPsy.attackthre - -1) || (e.internal_flags.nsPsy.attackthre = o[s].st_lrm), 0 != a ? e.internal_flags.nsPsy.attackthre_s = o[s].st_s : 0 < Math.abs(e.internal_flags.nsPsy.attackthre_s - -1) || (e.internal_flags.nsPsy.attackthre_s = o[s].st_s), 0 != a ? e.scale = o[s].scale : 0 < Math.abs(e.scale - -1) || (e.scale = o[s].scale), 0 != a ? e.maskingadjust = o[s].masking_adj : 0 < Math.abs(e.maskingadjust - 0) || (e.maskingadjust = o[s].masking_adj), 0 < o[s].masking_adj ? 0 != a ? e.maskingadjust_short = .9 * o[s].masking_adj : 0 < Math.abs(e.maskingadjust_short - 0) || (e.maskingadjust_short = .9 * o[s].masking_adj) : 0 != a ? e.maskingadjust_short = 1.1 * o[s].masking_adj : 0 < Math.abs(e.maskingadjust_short - 0) || (e.maskingadjust_short = 1.1 * o[s].masking_adj), 0 != a ? e.ATHlower = -o[s].ath_lower / 10 : 0 < Math.abs(10 * -e.ATHlower - 0) || (e.ATHlower = -o[s].ath_lower / 10), 0 != a ? e.ATHcurve = o[s].ath_curve : 0 < Math.abs(e.ATHcurve - -1) || (e.ATHcurve = o[s].ath_curve), 0 != a ? e.interChRatio = o[s].interch : 0 < Math.abs(e.interChRatio - -1) || (e.interChRatio = o[s].interch), t;
+ return 0 != a ? e.quant_comp = o[n].quant_comp : 0 < Math.abs(e.quant_comp - -1) || (e.quant_comp = o[n].quant_comp), 0 != a ? e.quant_comp_short = o[n].quant_comp_s : 0 < Math.abs(e.quant_comp_short - -1) || (e.quant_comp_short = o[n].quant_comp_s), 0 != a ? e.msfix = o[n].nsmsfix : 0 < Math.abs(e.msfix - -1) || (e.msfix = o[n].nsmsfix), 0 != a ? e.internal_flags.nsPsy.attackthre = o[n].st_lrm : 0 < Math.abs(e.internal_flags.nsPsy.attackthre - -1) || (e.internal_flags.nsPsy.attackthre = o[n].st_lrm), 0 != a ? e.internal_flags.nsPsy.attackthre_s = o[n].st_s : 0 < Math.abs(e.internal_flags.nsPsy.attackthre_s - -1) || (e.internal_flags.nsPsy.attackthre_s = o[n].st_s), 0 != a ? e.scale = o[n].scale : 0 < Math.abs(e.scale - -1) || (e.scale = o[n].scale), 0 != a ? e.maskingadjust = o[n].masking_adj : 0 < Math.abs(e.maskingadjust - 0) || (e.maskingadjust = o[n].masking_adj), 0 < o[n].masking_adj ? 0 != a ? e.maskingadjust_short = .9 * o[n].masking_adj : 0 < Math.abs(e.maskingadjust_short - 0) || (e.maskingadjust_short = .9 * o[n].masking_adj) : 0 != a ? e.maskingadjust_short = 1.1 * o[n].masking_adj : 0 < Math.abs(e.maskingadjust_short - 0) || (e.maskingadjust_short = 1.1 * o[n].masking_adj), 0 != a ? e.ATHlower = -o[n].ath_lower / 10 : 0 < Math.abs(10 * -e.ATHlower - 0) || (e.ATHlower = -o[n].ath_lower / 10), 0 != a ? e.ATHcurve = o[n].ath_curve : 0 < Math.abs(e.ATHcurve - -1) || (e.ATHcurve = o[n].ath_curve), 0 != a ? e.interChRatio = o[n].interch : 0 < Math.abs(e.interChRatio - -1) || (e.interChRatio = o[n].interch), t;
}
this.apply_preset = function (e, t, a) {
switch (t) {
- case Y.R3MIX:
- t = Y.V3, e.VBR = Me.vbr_mtrh;
+ case U.R3MIX:
+ t = U.V3, e.VBR = xe.vbr_mtrh;
break;
- case Y.MEDIUM:
- t = Y.V4, e.VBR = Me.vbr_rh;
+ case U.MEDIUM:
+ t = U.V4, e.VBR = xe.vbr_rh;
break;
- case Y.MEDIUM_FAST:
- t = Y.V4, e.VBR = Me.vbr_mtrh;
+ case U.MEDIUM_FAST:
+ t = U.V4, e.VBR = xe.vbr_mtrh;
break;
- case Y.STANDARD:
- t = Y.V2, e.VBR = Me.vbr_rh;
+ case U.STANDARD:
+ t = U.V2, e.VBR = xe.vbr_rh;
break;
- case Y.STANDARD_FAST:
- t = Y.V2, e.VBR = Me.vbr_mtrh;
+ case U.STANDARD_FAST:
+ t = U.V2, e.VBR = xe.vbr_mtrh;
break;
- case Y.EXTREME:
- t = Y.V0, e.VBR = Me.vbr_rh;
+ case U.EXTREME:
+ t = U.V0, e.VBR = xe.vbr_rh;
break;
- case Y.EXTREME_FAST:
- t = Y.V0, e.VBR = Me.vbr_mtrh;
+ case U.EXTREME_FAST:
+ t = U.V0, e.VBR = xe.vbr_mtrh;
break;
- case Y.INSANE:
- return t = 320, e.preset = t, s(e, t, a), e.VBR = Me.vbr_off, t;
+ case U.INSANE:
+ return t = 320, e.preset = t, n(e, t, a), e.VBR = xe.vbr_off, t;
}
switch (e.preset = t) {
- case Y.V9:
- return n(), t;
- case Y.V8:
- return n(), t;
- case Y.V7:
- return n(), t;
- case Y.V6:
- return n(), t;
- case Y.V5:
- return n(), t;
- case Y.V4:
- return n(), t;
- case Y.V3:
- return n(), t;
- case Y.V2:
- return n(), t;
- case Y.V1:
- return n(), t;
- case Y.V0:
- return n(), t;
+ case U.V9:
+ return s(e, 9, a), t;
+ case U.V8:
+ return s(e, 8, a), t;
+ case U.V7:
+ return s(e, 7, a), t;
+ case U.V6:
+ return s(e, 6, a), t;
+ case U.V5:
+ return s(e, 5, a), t;
+ case U.V4:
+ return s(e, 4, a), t;
+ case U.V3:
+ return s(e, 3, a), t;
+ case U.V2:
+ return s(e, 2, a), t;
+ case U.V1:
+ return s(e, 1, a), t;
+ case U.V0:
+ return s(e, 0, a), t;
}
- return 8 <= t && t <= 320 ? s(e, t, a) : (e.preset = 0, t);
+ return 8 <= t && t <= 320 ? n(e, t, a) : (e.preset = 0, t);
};
}(),
- _ = new T(),
- l = new C(),
- f = new y(),
+ _ = new x(),
+ l = new w(),
+ f = new M(),
c = new function () {
- this.getLameShortVersion = function () {
+ this.getLameVersion = function () {
return "3.98.4";
+ }, this.getLameShortVersion = function () {
+ return "3.98.4";
+ }, this.getLameVeryShortVersion = function () {
+ return "LAME3.98r";
+ }, this.getPsyVersion = function () {
+ return "0.93";
+ }, this.getLameUrl = function () {
+ return "http://www.mp3dev.org/";
+ }, this.getLameOsBitness = function () {
+ return "32bits";
};
}(),
- u = new function () {
- this.setModules = function (e, t) {};
- }(),
h = new function () {
+ this.setModules = function (e, t) {};
+ }(),
+ u = new function () {
var _;
this.setModules = function (e) {
_ = e;
}, this.ResvFrameBegin = function (e, t) {
var a,
- n = e.internal_flags,
- s = n.l3_side,
+ s = e.internal_flags,
+ n = s.l3_side,
r = _.getframebits(e);
- t.bits = (r - 8 * n.sideinfo_len) / n.mode_gr;
- var i = 2048 * n.mode_gr - 8;
- 320 < e.brate ? me() : (a = 11520, e.strict_ISO && me()), n.ResvMax = a - r, n.ResvMax > i && (n.ResvMax = i), (n.ResvMax < 0 || e.disable_reservoir) && (n.ResvMax = 0);
- var o = t.bits * n.mode_gr + Math.min(n.ResvSize, n.ResvMax);
- return a < o && (o = a), s.resvDrain_pre = 0, null != n.pinfo && me(), o;
- }, this.ResvMaxBits = function (e, t, a, n) {
- var s,
+ t.bits = (r - 8 * s.sideinfo_len) / s.mode_gr;
+ var i = 2048 * s.mode_gr - 8;
+ 320 < e.brate ? a = 8 * int(1e3 * e.brate / (e.out_samplerate / 1152) / 8 + .5) : (a = 11520, e.strict_ISO && (a = 8 * int(32e4 / (e.out_samplerate / 1152) / 8 + .5))), s.ResvMax = a - r, s.ResvMax > i && (s.ResvMax = i), (s.ResvMax < 0 || e.disable_reservoir) && (s.ResvMax = 0);
+ var o = t.bits * s.mode_gr + Math.min(s.ResvSize, s.ResvMax);
+ return a < o && (o = a), n.resvDrain_pre = 0, null != s.pinfo && (s.pinfo.mean_bits = t.bits / 2, s.pinfo.resvsize = s.ResvSize), o;
+ }, this.ResvMaxBits = function (e, t, a, s) {
+ var n,
r = e.internal_flags,
i = r.ResvSize,
o = r.ResvMax;
- 0 != n && (i += t), 0 != (1 & r.substep_shaping) && (o *= .9), a.bits = t, 9 * o < 10 * i ? (s = i - 9 * o / 10, a.bits += s, r.substep_shaping |= 128) : (s = 0, r.substep_shaping &= 127, e.disable_reservoir || 0 != (1 & r.substep_shaping) || (a.bits -= .1 * t));
+ 0 != s && (i += t), 0 != (1 & r.substep_shaping) && (o *= .9), a.bits = t, 9 * o < 10 * i ? (n = i - 9 * o / 10, a.bits += n, r.substep_shaping |= 128) : (n = 0, r.substep_shaping &= 127, e.disable_reservoir || 0 != (1 & r.substep_shaping) || (a.bits -= .1 * t));
var _ = i < 6 * r.ResvMax / 10 ? i : 6 * r.ResvMax / 10;
- return (_ -= s) < 0 && (_ = 0), _;
+ return (_ -= n) < 0 && (_ = 0), _;
}, this.ResvAdjust = function (e, t) {
e.ResvSize -= t.part2_3_length + t.part2_length;
}, this.ResvFrameEnd = function (e, t) {
var a,
- n = e.l3_side;
+ s = e.l3_side;
e.ResvSize += t * e.mode_gr;
- var s = 0;
- n.resvDrain_post = 0, (n.resvDrain_pre = 0) != (a = e.ResvSize % 8) && (s += a), 0 < (a = e.ResvSize - s - e.ResvMax) && (s += a);
- var r = Math.min(8 * n.main_data_begin, s) / 8;
- n.resvDrain_pre += 8 * r, s -= 8 * r, e.ResvSize -= 8 * r, n.main_data_begin -= r, n.resvDrain_post += s, e.ResvSize -= s;
+ var n = 0;
+ s.resvDrain_post = 0, (s.resvDrain_pre = 0) != (a = e.ResvSize % 8) && (n += a), 0 < (a = e.ResvSize - n - e.ResvMax) && (n += a);
+ var r = Math.min(8 * s.main_data_begin, n) / 8;
+ s.resvDrain_pre += 8 * r, n -= 8 * r, e.ResvSize -= 8 * r, s.main_data_begin -= r, s.resvDrain_post += n, e.ResvSize -= n;
};
}(),
- b = new A(),
+ m = new k(),
p = new function () {
this.setModules = function (e, t, a) {};
}(),
- m = new function () {}();
- s.setModules(r, i, o, _, l, f, c, u, m), i.setModules(r, m, c, f), u.setModules(i, c), o.setModules(s), l.setModules(i, h, _, b), _.setModules(b, h, s.enc.psy), h.setModules(i), b.setModules(_), f.setModules(s, i, c), a.setModules(p, m), p.setModules(c, u, o);
- var v = s.lame_init();
- v.num_channels = n, v.in_samplerate = e, v.out_samplerate = e, v.brate = t, v.mode = ye.STEREO, v.quality = 3, v.bWriteVbrTag = !1, v.disable_reservoir = !0, v.write_id3tag_automatic = !1, s.lame_init_params(v);
+ b = new function () {}();
+ n.setModules(r, i, o, _, l, f, c, h, b), i.setModules(r, b, c, f), h.setModules(i, c), o.setModules(n), l.setModules(i, u, _, m), _.setModules(m, u, n.enc.psy), u.setModules(i), m.setModules(_), f.setModules(n, i, c), a.setModules(p, b), p.setModules(c, h, o);
+ var v = n.lame_init();
+ v.num_channels = s, v.in_samplerate = e, v.out_samplerate = e, v.brate = t, v.mode = Ee.STEREO, v.quality = 3, v.bWriteVbrTag = !1, v.disable_reservoir = !0, v.write_id3tag_automatic = !1, n.lame_init_params(v);
var d = 1152,
g = 0 | 1.25 * d + 7200,
- w = S(g);
+ S = A(g);
this.encodeBuffer = function (e, t) {
- 1 == n && (t = e), e.length > d && (d = e.length, w = S(g = 0 | 1.25 * d + 7200));
- var a = s.lame_encode_buffer(v, e, t, e.length, w, 0, g);
- return new Int8Array(w.subarray(0, a));
+ 1 == s && (t = e), e.length > d && (d = e.length, S = A(g = 0 | 1.25 * d + 7200));
+ var a = n.lame_encode_buffer(v, e, t, e.length, S, 0, g);
+ return new Int8Array(S.subarray(0, a));
}, this.flush = function () {
- var e = s.lame_encode_flush(v, w, 0, g);
- return new Int8Array(w.subarray(0, e));
+ var e = n.lame_encode_flush(v, S, 0, g);
+ return new Int8Array(S.subarray(0, e));
};
};
}
- t(), e.lamejs = t;
-}(("object" == typeof window && window.document ? window : Object).Recorder);
+ t(), Recorder.lamejs = t;
+}();
});
/*
录音 Recorder扩展,动态波形显示
https://github.com/xiangyuecn/Recorder
*/
-(function (factory) {
- var browser = typeof window == "object" && !!window.document;
- var win = browser ? window : Object; //非浏览器环境,Recorder挂载在Object下面
- var rec = win.Recorder,
- ni = rec.i18n;
- factory(rec, ni, ni.$T, browser);
-})(function (Recorder, i18n, $T, isBrowser) {
-
+(function () {
var WaveView = function (set) {
return new fn(set);
};
@@ -37249,12 +37574,7 @@ https://github.com/xiangyuecn/Recorder
,width:0 //显示宽度
,height:0 //显示高度
- H5环境以上配置二选一
-
- compatibleCanvas: CanvasObject //提供一个兼容H5的canvas对象,需支持getContext("2d"),支持设置width、height,支持drawImage(canvas,...)
- ,width:0 //canvas显示宽度
- ,height:0 //canvas显示高度
- 非H5环境使用以上配置
+ 以上配置二选一
*/
scale: 2 //缩放系数,应为正整数,使用2(3? no!)倍宽高进行绘制,避免移动端绘制模糊
@@ -37283,44 +37603,38 @@ https://github.com/xiangyuecn/Recorder
o[k] = set[k];
}
This.set = set = o;
- var cCanvas = "compatibleCanvas";
- if (set[cCanvas]) {
- var canvas = This.canvas = set[cCanvas];
- } else {
- if (!isBrowser) throw new Error($T.G("NonBrowser-1", [ViewTxt]));
- var elem = set.elem;
- if (elem) {
- if (typeof elem == "string") {
- elem = document.querySelector(elem);
- } else if (elem.length) {
- elem = elem[0];
- }
- }
- if (elem) {
- set.width = elem.offsetWidth;
- set.height = elem.offsetHeight;
- }
- var thisElem = This.elem = document.createElement("div");
- thisElem.style.fontSize = 0;
- thisElem.innerHTML = '';
- var canvas = This.canvas = thisElem.querySelector("canvas");
- if (elem) {
- elem.innerHTML = "";
- elem.appendChild(thisElem);
+ var elem = set.elem;
+ if (elem) {
+ if (typeof elem == "string") {
+ elem = document.querySelector(elem);
+ } else if (elem.length) {
+ elem = elem[0];
}
}
+ if (elem) {
+ set.width = elem.offsetWidth;
+ set.height = elem.offsetHeight;
+ }
var scale = set.scale;
var width = set.width * scale;
var height = set.height * scale;
if (!width || !height) {
- throw new Error($T.G("IllegalArgs-1", [ViewTxt + " width=0 height=0"]));
+ throw new Error(ViewTxt + "无宽高");
}
+ var thisElem = This.elem = document.createElement("div");
+ var lowerCss = ["", "transform-origin:0 0;", "transform:scale(" + 1 / scale + ");"];
+ thisElem.innerHTML = '';
+ var canvas = This.canvas = thisElem.querySelector("canvas");
+ var ctx = This.ctx = canvas.getContext("2d");
canvas.width = width;
canvas.height = height;
- var ctx = This.ctx = canvas.getContext("2d");
This.linear1 = This.genLinear(ctx, width, set.linear1);
This.linear2 = This.genLinear(ctx, width, set.linear2);
This.linearBg = This.genLinear(ctx, height, set.linearBg, true);
+ if (elem) {
+ elem.innerHTML = "";
+ elem.appendChild(thisElem);
+ }
This._phase = 0;
};
fn.prototype = WaveView.prototype = {
@@ -37339,7 +37653,7 @@ https://github.com/xiangyuecn/Recorder
var scale = set.scale;
var width = set.width * scale;
var maxAmplitude = set.height * scale / 2;
- for (var x = 0; x <= width; x += scale) {
+ for (var x = 0; x < width; x += scale) {
var scaling = (1 + Math.cos(Math.PI + x / width * 2 * Math.PI)) / 2;
var y = scaling * maxAmplitude * amplitude * Math.sin(2 * Math.PI * (x / width) * frequency + phase) + maxAmplitude;
rtv.push(y);
@@ -37411,7 +37725,7 @@ https://github.com/xiangyuecn/Recorder
//绘制包围背景
ctx.beginPath();
- for (var i = 0, x = 0; x <= width; i++, x += scale) {
+ for (var i = 0, x = 0; x < width; i++, x += scale) {
if (x == 0) {
ctx.moveTo(x, path1[i]);
} else {
@@ -37437,7 +37751,7 @@ https://github.com/xiangyuecn/Recorder
var scale = set.scale;
var width = set.width * scale;
ctx.beginPath();
- for (var i = 0, x = 0; x <= width; i++, x += scale) {
+ for (var i = 0, x = 0; x < width; i++, x += scale) {
if (x == 0) {
ctx.moveTo(x, path[i]);
} else {
@@ -37450,11 +37764,11 @@ https://github.com/xiangyuecn/Recorder
}
};
Recorder[ViewTxt] = WaveView;
-});
+})();
/*
录音 Recorder扩展,频率直方图显示
-使用本扩展需要引入src/extensions/lib.fft.js支持,直方图特意优化主要显示0-5khz语音部分(线性),其他高频显示区域较小,不适合用来展示音乐频谱,可通过配置fullFreq来恢复成完整的线性频谱,或自行修改源码修改成倍频程频谱(伯德图、对数频谱);本可视化插件可以移植到其他语言环境,如需定制可联系作者
+使用本扩展需要引入lib.fft.js支持,直方图特意优化主要显示0-5khz语音部分(线性),其他高频显示区域较小,不适合用来展示音乐频谱,可自行修改源码恢复成完整的线性频谱,或修改成倍频程频谱(伯德图、对数频谱);本可视化插件可以移植到其他语言环境,如需定制可联系作者
https://github.com/xiangyuecn/Recorder
@@ -37462,13 +37776,7 @@ https://github.com/xiangyuecn/Recorder
https://www.iteye.com/topic/851459
https://sourceforge.net/projects/jmp123/files/
*/
-(function (factory) {
- var browser = typeof window == "object" && !!window.document;
- var win = browser ? window : Object; //非浏览器环境,Recorder挂载在Object下面
- var rec = win.Recorder,
- ni = rec.i18n;
- factory(rec, ni, ni.$T, browser);
-})(function (Recorder, i18n, $T, isBrowser) {
+(function () {
var FrequencyHistogramView = function (set) {
return new fn(set);
@@ -37483,12 +37791,7 @@ https://sourceforge.net/projects/jmp123/files/
,width:0 //显示宽度
,height:0 //显示高度
- H5环境以上配置二选一
-
- compatibleCanvas: CanvasObject //提供一个兼容H5的canvas对象,需支持getContext("2d"),支持设置width、height,支持drawImage(canvas,...)
- ,width:0 //canvas显示宽度
- ,height:0 //canvas显示高度
- 非H5环境使用以上配置
+ 以上配置二选一
*/
scale: 2 //缩放系数,应为正整数,使用2(3? no!)倍宽高进行绘制,避免移动端绘制模糊
@@ -37534,9 +37837,7 @@ https://sourceforge.net/projects/jmp123/files/
stripeShadowBlur: -1 //峰值小横条阴影基础大小,设为0不显示阴影,-1为柱子的大小,如果柱子数量太多时请勿开启,非常影响性能
,
stripeShadowColor: "" //峰值小横条阴影颜色,留空为柱子的阴影颜色
- ,
- fullFreq: false //是否要绘制所有频率;默认false主要绘制5khz以下的频率,高频部分占比很少,此时不同的采样率对频谱显示几乎没有影响;设为true后不同采样率下显示的频谱是不一样的,因为 最大频率=采样率/2 会有差异
//当发生绘制时会回调此方法,参数为当前绘制的频率数据和采样率,可实现多个直方图同时绘制,只消耗一个input输入和计算时间
,
onDraw: function (frequencyData, sampleRate) {}
@@ -37545,43 +37846,37 @@ https://sourceforge.net/projects/jmp123/files/
o[k] = set[k];
}
This.set = set = o;
- var cCanvas = "compatibleCanvas";
- if (set[cCanvas]) {
- var canvas = This.canvas = set[cCanvas];
- } else {
- if (!isBrowser) throw new Error($T.G("NonBrowser-1", [ViewTxt]));
- var elem = set.elem;
- if (elem) {
- if (typeof elem == "string") {
- elem = document.querySelector(elem);
- } else if (elem.length) {
- elem = elem[0];
- }
- }
- if (elem) {
- set.width = elem.offsetWidth;
- set.height = elem.offsetHeight;
- }
- var thisElem = This.elem = document.createElement("div");
- thisElem.style.fontSize = 0;
- thisElem.innerHTML = '';
- var canvas = This.canvas = thisElem.querySelector("canvas");
- if (elem) {
- elem.innerHTML = "";
- elem.appendChild(thisElem);
+ var elem = set.elem;
+ if (elem) {
+ if (typeof elem == "string") {
+ elem = document.querySelector(elem);
+ } else if (elem.length) {
+ elem = elem[0];
}
}
+ if (elem) {
+ set.width = elem.offsetWidth;
+ set.height = elem.offsetHeight;
+ }
var scale = set.scale;
var width = set.width * scale;
var height = set.height * scale;
if (!width || !height) {
- throw new Error($T.G("IllegalArgs-1", [ViewTxt + " width=0 height=0"]));
+ throw new Error(ViewTxt + "无宽高");
}
+ var thisElem = This.elem = document.createElement("div");
+ var lowerCss = ["", "transform-origin:0 0;", "transform:scale(" + 1 / scale + ");"];
+ thisElem.innerHTML = '';
+ var canvas = This.canvas = thisElem.querySelector("canvas");
+ This.ctx = canvas.getContext("2d");
canvas.width = width;
canvas.height = height;
- This.ctx = canvas.getContext("2d");
+ if (elem) {
+ elem.innerHTML = "";
+ elem.appendChild(thisElem);
+ }
if (!Recorder.LibFFT) {
- throw new Error($T.G("NeedImport-2", [ViewTxt, "src/extensions/lib.fft.js"]));
+ throw new Error("需要lib.fft.js支持");
}
This.fft = Recorder.LibFFT(1024);
@@ -37621,9 +37916,6 @@ https://sourceforge.net/projects/jmp123/files/
//超时没有输入,顶部横条已全部落下,干掉定时器
clearInterval(This.timer);
This.timer = 0;
- This.lastH = []; //重置高度再绘制一次,避免定时不准没到底就停了
- This.stripesH = [];
- This.draw(null, This.sampleRate);
return;
}
if (now - drawTime < interval) {
@@ -37675,19 +37967,15 @@ https://sourceforge.net/projects/jmp123/files/
var Y0 = 1 << (Math.round(Math.log(bufferSize) / Math.log(2) + 3) << 1);
var logY0 = Math.log(Y0) / Math.log(10);
var dBmax = 20 * Math.log(0x7fff) / Math.log(10);
- var fftSize = bufferSize / 2,
- fftSize5k = fftSize;
- if (!set.fullFreq) {
- //非绘制所有频率时,计算5khz所在位置,8000采样率及以下最高只有4khz
- fftSize5k = Math.min(fftSize, Math.floor(fftSize * 5000 / (sampleRate / 2)));
- }
- var isFullFreq = fftSize5k == fftSize;
- var line80 = isFullFreq ? lineCount : Math.round(lineCount * 0.8); //80%的柱子位置
+ var fftSize = bufferSize / 2;
+ var fftSize5k = Math.min(fftSize, Math.floor(fftSize * 5000 / (sampleRate / 2))); //5khz所在位置,8000采样率及以下最高只有4khz
+ var fftSize5kIsAll = fftSize5k == fftSize;
+ var line80 = fftSize5kIsAll ? lineCount : Math.round(lineCount * 0.8); //80%的柱子位置
var fftSizeStep1 = fftSize5k / line80;
- var fftSizeStep2 = isFullFreq ? 0 : (fftSize - fftSize5k) / (lineCount - line80);
+ var fftSizeStep2 = fftSize5kIsAll ? 0 : (fftSize - fftSize5k) / (lineCount - line80);
var fftIdx = 0;
for (var i = 0; i < lineCount; i++) {
- // !fullFreq 时不采用jmp123的非线性划分频段,录音语音并不适用于音乐的频率,应当弱化高频部分
+ //不采用jmp123的非线性划分频段,录音语音并不适用于音乐的频率,应当弱化高频部分
//80%关注0-5khz主要人声部分 20%关注剩下的高频,这样不管什么采样率都能做到大部分频率显示一致。
var start = Math.ceil(fftIdx);
if (i < line80) {
@@ -37697,18 +37985,14 @@ https://sourceforge.net/projects/jmp123/files/
//5khz以上
fftIdx += fftSizeStep2;
}
- var end = Math.ceil(fftIdx);
- if (end == start) end++;
- end = Math.min(end, fftSize);
+ var end = Math.min(Math.ceil(fftIdx), fftSize);
//参考AudioGUI.java .drawHistogram方法
//查找当前频段的最大"幅值"
var maxAmp = 0;
- if (frequencyData) {
- for (var j = start; j < end; j++) {
- maxAmp = Math.max(maxAmp, Math.abs(frequencyData[j]));
- }
+ for (var j = start; j < end; j++) {
+ maxAmp = Math.max(maxAmp, Math.abs(frequencyData[j]));
}
//计算音量
@@ -37746,6 +38030,8 @@ https://sourceforge.net/projects/jmp123/files/
var stripeLinear2 = set.stripeLinear && This.genLinear(ctx, set.stripeLinear, originY, originY + heightY) || linear2; //上半部分的峰值小横条填充
//计算柱子间距
+ ctx.shadowBlur = set.shadowBlur * scale;
+ ctx.shadowColor = set.shadowColor;
var mirrorEnable = set.mirrorEnable;
var mirrorCount = mirrorEnable ? lineCount * 2 - 1 : lineCount; //镜像柱子数量翻一倍-1根
@@ -37754,105 +38040,78 @@ https://sourceforge.net/projects/jmp123/files/
if (spaceWidth != 0) {
widthRatio = (width - spaceWidth * (mirrorCount + 1)) / width;
}
- for (var i = 0; i < 2; i++) {
- var lineFloat = Math.max(1 * scale, width * widthRatio / mirrorCount); //柱子宽度至少1个单位
- var lineWN = Math.floor(lineFloat),
- lineWF = lineFloat - lineWN; //提取出小数部分
- var spaceFloat = (width - mirrorCount * lineFloat) / (mirrorCount + 1); //均匀间隔,首尾都留空,可能为负数,柱子将发生重叠
- if (spaceFloat > 0 && spaceFloat < 1) {
- widthRatio = 1;
- spaceFloat = 0; //不够一个像素,丢弃不绘制间隔,重新计算
- } else break;
+ var lineWidth = Math.max(1 * scale, Math.floor(width * widthRatio / mirrorCount)); //柱子宽度至少1个单位
+ var spaceFloat = (width - mirrorCount * lineWidth) / (mirrorCount + 1); //均匀间隔,首尾都留空,可能为负数,柱子将发生重叠
+
+ //绘制柱子
+ var minHeight = set.minHeight * scale;
+ var mirrorSubX = spaceFloat + lineWidth / 2;
+ var XFloat = mirrorEnable ? width / 2 - mirrorSubX : 0; //镜像时,中间柱子位于正中心
+ for (var i = 0, xFloat = XFloat, x, y, h; i < lineCount; i++) {
+ xFloat += spaceFloat;
+ x = Math.floor(xFloat);
+ h = Math.max(lastH[i], minHeight);
+
+ //绘制上半部分
+ if (originY != 0) {
+ y = originY - h;
+ ctx.fillStyle = linear1;
+ ctx.fillRect(x, y, lineWidth, h);
+ }
+ //绘制下半部分
+ if (originY != height) {
+ ctx.fillStyle = linear2;
+ ctx.fillRect(x, originY, lineWidth, h);
+ }
+ xFloat += lineWidth;
}
- //绘制
- var minHeight = set.minHeight * scale;
- var XFloat = mirrorEnable ? (width - lineWN) / 2 - spaceFloat : 0; //镜像时,中间柱子位于正中心
- for (var iMirror = 0; iMirror < 2; iMirror++) {
- if (iMirror) {
- ctx.save();
- ctx.scale(-1, 1);
- }
- var xMirror = iMirror ? width : 0; //绘制镜像部分,不用drawImage(canvas)进行镜像绘制,提升兼容性(iOS微信小程序bug https://developers.weixin.qq.com/community/develop/doc/000aaca2148dc8a235a0fb8c66b000)
-
- //绘制柱子
- ctx.shadowBlur = set.shadowBlur * scale;
- ctx.shadowColor = set.shadowColor;
- for (var i = 0, xFloat = XFloat, wFloat = 0, x, y, w, h; i < lineCount; i++) {
+ //绘制柱子顶上峰值小横条
+ if (set.stripeEnable) {
+ var stripeShadowBlur = set.stripeShadowBlur;
+ ctx.shadowBlur = (stripeShadowBlur == -1 ? set.shadowBlur : stripeShadowBlur) * scale;
+ ctx.shadowColor = set.stripeShadowColor || set.shadowColor;
+ var stripeHeight = set.stripeHeight * scale;
+ for (var i = 0, xFloat = XFloat, x, y, h; i < lineCount; i++) {
xFloat += spaceFloat;
- x = Math.floor(xFloat) - xMirror;
- w = lineWN;
- wFloat += lineWF;
- if (wFloat >= 1) {
- w++;
- wFloat--;
- } //小数凑够1像素
- h = Math.max(lastH[i], minHeight);
+ x = Math.floor(xFloat);
+ h = stripesH[i];
//绘制上半部分
if (originY != 0) {
- y = originY - h;
- ctx.fillStyle = linear1;
- ctx.fillRect(x, y, w, h);
+ y = originY - h - stripeHeight;
+ if (y < 0) {
+ y = 0;
+ }
+ ctx.fillStyle = stripeLinear1;
+ ctx.fillRect(x, y, lineWidth, stripeHeight);
}
//绘制下半部分
if (originY != height) {
- ctx.fillStyle = linear2;
- ctx.fillRect(x, originY, w, h);
- }
- xFloat += w;
- }
-
- //绘制柱子顶上峰值小横条
- if (set.stripeEnable) {
- var stripeShadowBlur = set.stripeShadowBlur;
- ctx.shadowBlur = (stripeShadowBlur == -1 ? set.shadowBlur : stripeShadowBlur) * scale;
- ctx.shadowColor = set.stripeShadowColor || set.shadowColor;
- var stripeHeight = set.stripeHeight * scale;
- for (var i = 0, xFloat = XFloat, wFloat = 0, x, y, w, h; i < lineCount; i++) {
- xFloat += spaceFloat;
- x = Math.floor(xFloat) - xMirror;
- w = lineWN;
- wFloat += lineWF;
- if (wFloat >= 1) {
- w++;
- wFloat--;
- } //小数凑够1像素
- h = stripesH[i];
-
- //绘制上半部分
- if (originY != 0) {
- y = originY - h - stripeHeight;
- if (y < 0) {
- y = 0;
- }
- ctx.fillStyle = stripeLinear1;
- ctx.fillRect(x, y, w, stripeHeight);
+ y = originY + h;
+ if (y + stripeHeight > height) {
+ y = height - stripeHeight;
}
- //绘制下半部分
- if (originY != height) {
- y = originY + h;
- if (y + stripeHeight > height) {
- y = height - stripeHeight;
- }
- ctx.fillStyle = stripeLinear2;
- ctx.fillRect(x, y, w, stripeHeight);
- }
- xFloat += w;
+ ctx.fillStyle = stripeLinear2;
+ ctx.fillRect(x, y, lineWidth, stripeHeight);
}
+ xFloat += lineWidth;
}
- if (iMirror) {
- ctx.restore();
- }
- if (!mirrorEnable) break;
}
- if (frequencyData) {
- set.onDraw(frequencyData, sampleRate);
+
+ //镜像,从中间直接镜像即可
+ if (mirrorEnable) {
+ var srcW = Math.floor(width / 2);
+ ctx.save();
+ ctx.scale(-1, 1);
+ ctx.drawImage(This.canvas, Math.ceil(width / 2), 0, srcW, height, -srcW, 0, srcW, height);
+ ctx.restore();
}
+ set.onDraw(frequencyData, sampleRate);
}
};
Recorder[ViewTxt] = FrequencyHistogramView;
-});
+})();
/*
时域转频域,快速傅里叶变换(FFT)
@@ -37866,117 +38125,110 @@ fft.transform(inBuffer)
inBuffer:[Int16,...] 数组长度必须是bufferSize
返回[Float64(Long),...],长度为bufferSize/2
*/
-(function (factory) {
- var browser = typeof window == "object" && !!window.document;
- var win = browser ? window : Object; //非浏览器环境,Recorder挂载在Object下面
- var rec = win.Recorder,
- ni = rec.i18n;
- factory(rec, ni, ni.$T, browser);
-})(function (Recorder, i18n, $T, isBrowser) {
+
+/*
+从FFT.java 移植,Java开源库:jmp123 版本0.3
+https://www.iteye.com/topic/851459
+https://sourceforge.net/projects/jmp123/files/
+*/
+Recorder.LibFFT = function (bufferSize) {
+
+ var FFT_N_LOG, FFT_N, MINY;
+ var real, imag, sintable, costable;
+ var bitReverse;
+ var FFT_Fn = function (bufferSize) {
+ //bufferSize只能取值2的n次方
+ FFT_N_LOG = Math.round(Math.log(bufferSize) / Math.log(2));
+ FFT_N = 1 << FFT_N_LOG;
+ MINY = (FFT_N << 2) * Math.sqrt(2);
+ real = [];
+ imag = [];
+ sintable = [0];
+ costable = [0];
+ bitReverse = [];
+ var i, j, k, reve;
+ for (i = 0; i < FFT_N; i++) {
+ k = i;
+ for (j = 0, reve = 0; j != FFT_N_LOG; j++) {
+ reve <<= 1;
+ reve |= k & 1;
+ k >>>= 1;
+ }
+ bitReverse[i] = reve;
+ }
+ var theta,
+ dt = 2 * Math.PI / FFT_N;
+ for (i = (FFT_N >> 1) - 1; i > 0; i--) {
+ theta = i * dt;
+ costable[i] = Math.cos(theta);
+ sintable[i] = Math.sin(theta);
+ }
+ };
/*
- 从FFT.java 移植,Java开源库:jmp123 版本0.3
- https://www.iteye.com/topic/851459
- https://sourceforge.net/projects/jmp123/files/
+ 用于频谱显示的快速傅里叶变换
+ inBuffer 输入FFT_N个实数,返回 FFT_N/2个输出值(复数模的平方)。
*/
- Recorder.LibFFT = function (bufferSize) {
- var FFT_N_LOG, FFT_N, MINY;
- var real, imag, sintable, costable;
- var bitReverse;
- var FFT_Fn = function (bufferSize) {
- //bufferSize只能取值2的n次方
- FFT_N_LOG = Math.round(Math.log(bufferSize) / Math.log(2));
- FFT_N = 1 << FFT_N_LOG;
- MINY = (FFT_N << 2) * Math.sqrt(2);
- real = [];
- imag = [];
- sintable = [0];
- costable = [0];
- bitReverse = [];
- var i, j, k, reve;
- for (i = 0; i < FFT_N; i++) {
- k = i;
- for (j = 0, reve = 0; j != FFT_N_LOG; j++) {
- reve <<= 1;
- reve |= k & 1;
- k >>>= 1;
+ var getModulus = function (inBuffer) {
+ var i,
+ j,
+ k,
+ ir,
+ j0 = 1,
+ idx = FFT_N_LOG - 1;
+ var cosv, sinv, tmpr, tmpi;
+ for (i = 0; i != FFT_N; i++) {
+ real[i] = inBuffer[bitReverse[i]];
+ imag[i] = 0;
+ }
+ for (i = FFT_N_LOG; i != 0; i--) {
+ for (j = 0; j != j0; j++) {
+ cosv = costable[j << idx];
+ sinv = sintable[j << idx];
+ for (k = j; k < FFT_N; k += j0 << 1) {
+ ir = k + j0;
+ tmpr = cosv * real[ir] - sinv * imag[ir];
+ tmpi = cosv * imag[ir] + sinv * real[ir];
+ real[ir] = real[k] - tmpr;
+ imag[ir] = imag[k] - tmpi;
+ real[k] += tmpr;
+ imag[k] += tmpi;
}
- bitReverse[i] = reve;
}
- var theta,
- dt = 2 * Math.PI / FFT_N;
- for (i = (FFT_N >> 1) - 1; i > 0; i--) {
- theta = i * dt;
- costable[i] = Math.cos(theta);
- sintable[i] = Math.sin(theta);
- }
- };
-
+ j0 <<= 1;
+ idx--;
+ }
+ j = FFT_N >> 1;
+ var outBuffer = new Float64Array(j);
/*
- 用于频谱显示的快速傅里叶变换
- inBuffer 输入FFT_N个实数,返回 FFT_N/2个输出值(复数模的平方)。
- */
- var getModulus = function (inBuffer) {
- var i,
- j,
- k,
- ir,
- j0 = 1,
- idx = FFT_N_LOG - 1;
- var cosv, sinv, tmpr, tmpi;
- for (i = 0; i != FFT_N; i++) {
- real[i] = inBuffer[bitReverse[i]];
- imag[i] = 0;
- }
- for (i = FFT_N_LOG; i != 0; i--) {
- for (j = 0; j != j0; j++) {
- cosv = costable[j << idx];
- sinv = sintable[j << idx];
- for (k = j; k < FFT_N; k += j0 << 1) {
- ir = k + j0;
- tmpr = cosv * real[ir] - sinv * imag[ir];
- tmpi = cosv * imag[ir] + sinv * real[ir];
- real[ir] = real[k] - tmpr;
- imag[ir] = imag[k] - tmpi;
- real[k] += tmpr;
- imag[k] += tmpi;
- }
- }
- j0 <<= 1;
- idx--;
- }
- j = FFT_N >> 1;
- var outBuffer = new Float64Array(j);
- /*
- * 输出模的平方:
- * for(i = 1; i <= j; i++)
- * inBuffer[i-1] = real[i] * real[i] + imag[i] * imag[i];
- *
- * 如果FFT只用于频谱显示,可以"淘汰"幅值较小的而减少浮点乘法运算. MINY的值
- * 和Spectrum.Y0,Spectrum.logY0对应.
- */
- sinv = MINY;
- cosv = -MINY;
- for (i = j; i != 0; i--) {
- tmpr = real[i];
- tmpi = imag[i];
- if (tmpr > cosv && tmpr < sinv && tmpi > cosv && tmpi < sinv) outBuffer[i - 1] = 0;else outBuffer[i - 1] = Math.round(tmpr * tmpr + tmpi * tmpi);
- }
- return outBuffer;
- };
- FFT_Fn(bufferSize);
- return {
- transform: getModulus,
- bufferSize: FFT_N
- };
+ * 输出模的平方:
+ * for(i = 1; i <= j; i++)
+ * inBuffer[i-1] = real[i] * real[i] + imag[i] * imag[i];
+ *
+ * 如果FFT只用于频谱显示,可以"淘汰"幅值较小的而减少浮点乘法运算. MINY的值
+ * 和Spectrum.Y0,Spectrum.logY0对应.
+ */
+ sinv = MINY;
+ cosv = -MINY;
+ for (i = j; i != 0; i--) {
+ tmpr = real[i];
+ tmpi = imag[i];
+ if (tmpr > cosv && tmpr < sinv && tmpi > cosv && tmpi < sinv) outBuffer[i - 1] = 0;else outBuffer[i - 1] = Math.round(tmpr * tmpr + tmpi * tmpi);
+ }
+ return outBuffer;
};
-});
+ FFT_Fn(bufferSize);
+ return {
+ transform: getModulus,
+ bufferSize: FFT_N
+ };
+};
-var playIcon$5 = "";
+var playIcon$6 = "";
-var pauseIcon$4 = "";
+var pauseIcon$5 = "";
-var audioIcon$3 = "";
+var audioIcon$4 = "";
var coverLocal$3 = "";
@@ -38004,7 +38256,7 @@ const uuid$2 = prefix => {
const id = s.join('');
return prefix ? prefix + '__' + id : id;
};
-var script$4O = {
+var script$4V = {
name: 'RecordPlayer',
props: {
//模式:preview 预览 (默认),editor 编辑
@@ -38061,9 +38313,9 @@ var script$4O = {
},
data() {
return {
- playIcon: playIcon$5,
- pauseIcon: pauseIcon$4,
- audioIcon: audioIcon$3,
+ playIcon: playIcon$6,
+ pauseIcon: pauseIcon$5,
+ audioIcon: audioIcon$4,
coverLocal: coverLocal$3,
recStartIcon: recStartIcon$1,
recStopIcon: recStopIcon$1,
@@ -38269,7 +38521,9 @@ var script$4O = {
minHeight: 12,
mirrorEnable: true,
stripeEnable: false,
- linear: [0, '#8FC1FD', 1, '#8FC1FD']
+ linear: [0, '#8FC1FD', 1, '#8FC1FD'],
+ width: 300,
+ height: 100
});
this.waveStore.Histogram3 = recorder_mp3_min.FrequencyHistogramView({
elem: elem,
@@ -38279,7 +38533,9 @@ var script$4O = {
fallDuration: 400,
stripeEnable: false,
mirrorEnable: true,
- linear: [0, '#0ac', 1, '#0ac']
+ linear: [0, '#0ac', 1, '#0ac'],
+ width: 300,
+ height: 100
});
},
toggleRec() {
@@ -38316,7 +38572,7 @@ var script$4O = {
rec.open(function () {
_this.dialogCancel();
// _this.reclog("已打开:"+_this.type+" "+_this.sampleRate+"hz "+_this.bitRate+"kbps",2);
-
+ console.log(waveBoxSelector);
// _this.wave=Recorder.WaveView({elem:".ctrlProcessWave"});
_this.initWaveStore(waveBoxSelector);
rec.start();
@@ -38490,10 +38746,10 @@ var script$4O = {
};
/* script */
-const __vue_script__$4O = script$4O;
+const __vue_script__$4V = script$4V;
/* template */
-var __vue_render__$4O = function () {
+var __vue_render__$4V = function () {
var _vm = this;
var _h = _vm.$createElement;
var _c = _vm._self._c || _h;
@@ -38559,7 +38815,7 @@ var __vue_render__$4O = function () {
!_vm.recBolb
? _c("div", {
staticClass: "recwave",
- staticStyle: { height: "75%", width: "100%" },
+ staticStyle: { height: "80px", width: "100%" },
attrs: { id: _vm.waveBoxKey },
})
: _vm._e(),
@@ -38697,17 +38953,17 @@ var __vue_render__$4O = function () {
1
)
};
-var __vue_staticRenderFns__$4O = [];
-__vue_render__$4O._withStripped = true;
+var __vue_staticRenderFns__$4V = [];
+__vue_render__$4V._withStripped = true;
/* style */
- const __vue_inject_styles__$4O = undefined;
+ const __vue_inject_styles__$4V = undefined;
/* scoped */
- const __vue_scope_id__$4O = undefined;
+ const __vue_scope_id__$4V = undefined;
/* module identifier */
- const __vue_module_identifier__$4O = undefined;
+ const __vue_module_identifier__$4V = undefined;
/* functional template */
- const __vue_is_functional_template__$4O = false;
+ const __vue_is_functional_template__$4V = false;
/* style inject */
/* style inject SSR */
@@ -38716,13 +38972,13 @@ __vue_render__$4O._withStripped = true;
- const __vue_component__$4O = /*#__PURE__*/normalizeComponent(
- { render: __vue_render__$4O, staticRenderFns: __vue_staticRenderFns__$4O },
- __vue_inject_styles__$4O,
- __vue_script__$4O,
- __vue_scope_id__$4O,
- __vue_is_functional_template__$4O,
- __vue_module_identifier__$4O,
+ const __vue_component__$4V = /*#__PURE__*/normalizeComponent(
+ { render: __vue_render__$4V, staticRenderFns: __vue_staticRenderFns__$4V },
+ __vue_inject_styles__$4V,
+ __vue_script__$4V,
+ __vue_scope_id__$4V,
+ __vue_is_functional_template__$4V,
+ __vue_module_identifier__$4V,
false,
undefined,
undefined,
@@ -38735,9 +38991,9 @@ const _audio = '.mp3,';
const _video = '.mp4,.MP4';
const _resources = 'application/x-zip-compressed,.zip,';
const _office = '.ppt,.xlsx,.xls,.doc,.docx,.pptx';
-var script$4N = {
+var script$4U = {
components: {
- RecordPlayer: __vue_component__$4O
+ RecordPlayer: __vue_component__$4V
},
name: 'addFile',
props: {
@@ -39196,9 +39452,9 @@ var script$4N = {
};
/* script */
-const __vue_script__$4N = script$4N;
+const __vue_script__$4U = script$4U;
/* template */
-var __vue_render__$4N = function () {
+var __vue_render__$4U = function () {
var _vm = this;
var _h = _vm.$createElement;
var _c = _vm._self._c || _h;
@@ -39795,17 +40051,17 @@ var __vue_render__$4N = function () {
]
)
};
-var __vue_staticRenderFns__$4N = [];
-__vue_render__$4N._withStripped = true;
+var __vue_staticRenderFns__$4U = [];
+__vue_render__$4U._withStripped = true;
/* style */
- const __vue_inject_styles__$4N = undefined;
+ const __vue_inject_styles__$4U = undefined;
/* scoped */
- const __vue_scope_id__$4N = undefined;
+ const __vue_scope_id__$4U = undefined;
/* module identifier */
- const __vue_module_identifier__$4N = undefined;
+ const __vue_module_identifier__$4U = undefined;
/* functional template */
- const __vue_is_functional_template__$4N = false;
+ const __vue_is_functional_template__$4U = false;
/* style inject */
/* style inject SSR */
@@ -39814,13 +40070,13 @@ __vue_render__$4N._withStripped = true;
- const __vue_component__$4N = /*#__PURE__*/normalizeComponent(
- { render: __vue_render__$4N, staticRenderFns: __vue_staticRenderFns__$4N },
- __vue_inject_styles__$4N,
- __vue_script__$4N,
- __vue_scope_id__$4N,
- __vue_is_functional_template__$4N,
- __vue_module_identifier__$4N,
+ const __vue_component__$4U = /*#__PURE__*/normalizeComponent(
+ { render: __vue_render__$4U, staticRenderFns: __vue_staticRenderFns__$4U },
+ __vue_inject_styles__$4U,
+ __vue_script__$4U,
+ __vue_scope_id__$4U,
+ __vue_is_functional_template__$4U,
+ __vue_module_identifier__$4U,
false,
undefined,
undefined,
@@ -52795,11 +53051,11 @@ var n = function () {
*/
let prevOverflow$1 = '';
-var script$4M = {
+var script$4T = {
name: 'XmlTextRender',
components: {
- addFile: __vue_component__$4N,
- XmlTextDialogRender: __vue_component__$4P,
+ addFile: __vue_component__$4U,
+ XmlTextDialogRender: __vue_component__$4W,
[ImagePreview$1.Component.name]: ImagePreview$1.Component
},
props: {
@@ -53969,9 +54225,9 @@ var script$4M = {
};
/* script */
-const __vue_script__$4M = script$4M;
+const __vue_script__$4T = script$4T;
/* template */
-var __vue_render__$4M = function () {
+var __vue_render__$4T = function () {
var _vm = this;
var _h = _vm.$createElement;
var _c = _vm._self._c || _h;
@@ -54481,17 +54737,17 @@ var __vue_render__$4M = function () {
2
)
};
-var __vue_staticRenderFns__$4M = [];
-__vue_render__$4M._withStripped = true;
+var __vue_staticRenderFns__$4T = [];
+__vue_render__$4T._withStripped = true;
/* style */
- const __vue_inject_styles__$4M = undefined;
+ const __vue_inject_styles__$4T = undefined;
/* scoped */
- const __vue_scope_id__$4M = "data-v-5d93942a";
+ const __vue_scope_id__$4T = "data-v-5d93942a";
/* module identifier */
- const __vue_module_identifier__$4M = undefined;
+ const __vue_module_identifier__$4T = undefined;
/* functional template */
- const __vue_is_functional_template__$4M = false;
+ const __vue_is_functional_template__$4T = false;
/* style inject */
/* style inject SSR */
@@ -54500,20 +54756,20 @@ __vue_render__$4M._withStripped = true;
- const __vue_component__$4M = /*#__PURE__*/normalizeComponent(
- { render: __vue_render__$4M, staticRenderFns: __vue_staticRenderFns__$4M },
- __vue_inject_styles__$4M,
- __vue_script__$4M,
- __vue_scope_id__$4M,
- __vue_is_functional_template__$4M,
- __vue_module_identifier__$4M,
+ const __vue_component__$4T = /*#__PURE__*/normalizeComponent(
+ { render: __vue_render__$4T, staticRenderFns: __vue_staticRenderFns__$4T },
+ __vue_inject_styles__$4T,
+ __vue_script__$4T,
+ __vue_scope_id__$4T,
+ __vue_is_functional_template__$4T,
+ __vue_module_identifier__$4T,
false,
undefined,
undefined,
undefined
);
-const TextComponents = [__vue_component__$4M, __vue_component__$4P];
+const TextComponents = [__vue_component__$4T, __vue_component__$4W];
var XmlText = {
...TextComponents
};
@@ -54530,7 +54786,7 @@ var XmlText = {
//
//
-var script$4L = {
+var script$4S = {
name: 'XmlGroupRender',
props: {
//模式:preview 预览 (默认),editor 编辑
@@ -54605,9 +54861,9 @@ var script$4L = {
};
/* script */
-const __vue_script__$4L = script$4L;
+const __vue_script__$4S = script$4S;
/* template */
-var __vue_render__$4L = function () {
+var __vue_render__$4S = function () {
var _vm = this;
var _h = _vm.$createElement;
var _c = _vm._self._c || _h;
@@ -54644,17 +54900,17 @@ var __vue_render__$4L = function () {
2
)
};
-var __vue_staticRenderFns__$4L = [];
-__vue_render__$4L._withStripped = true;
+var __vue_staticRenderFns__$4S = [];
+__vue_render__$4S._withStripped = true;
/* style */
- const __vue_inject_styles__$4L = undefined;
+ const __vue_inject_styles__$4S = undefined;
/* scoped */
- const __vue_scope_id__$4L = "data-v-35e9204b";
+ const __vue_scope_id__$4S = "data-v-35e9204b";
/* module identifier */
- const __vue_module_identifier__$4L = undefined;
+ const __vue_module_identifier__$4S = undefined;
/* functional template */
- const __vue_is_functional_template__$4L = false;
+ const __vue_is_functional_template__$4S = false;
/* style inject */
/* style inject SSR */
@@ -54663,23 +54919,23 @@ __vue_render__$4L._withStripped = true;
- const __vue_component__$4L = /*#__PURE__*/normalizeComponent(
- { render: __vue_render__$4L, staticRenderFns: __vue_staticRenderFns__$4L },
- __vue_inject_styles__$4L,
- __vue_script__$4L,
- __vue_scope_id__$4L,
- __vue_is_functional_template__$4L,
- __vue_module_identifier__$4L,
+ const __vue_component__$4S = /*#__PURE__*/normalizeComponent(
+ { render: __vue_render__$4S, staticRenderFns: __vue_staticRenderFns__$4S },
+ __vue_inject_styles__$4S,
+ __vue_script__$4S,
+ __vue_scope_id__$4S,
+ __vue_is_functional_template__$4S,
+ __vue_module_identifier__$4S,
false,
undefined,
undefined,
undefined
);
-__vue_component__$4L.install = (Vue, options = {}) => {
+__vue_component__$4S.install = (Vue, options = {}) => {
Vue.component(createNamespace$1('group-render', {
prefix: options.prefix
- }), __vue_component__$4L);
+ }), __vue_component__$4S);
};
function getDefaultExportFromCjs(x){return x&&x.__esModule&&Object.prototype.hasOwnProperty.call(x,'default')?x['default']:x;}var urlToolkit={exports:{}};(function(module,exports){// see https://tools.ietf.org/html/rfc1808
@@ -60145,11 +60401,11 @@ var vueAplayer_min = createCommonjsModule(function (module, exports) {
var vueAplayer = unwrapExports(vueAplayer_min);
vueAplayer_min.VueAPlayer;
-var playIcon$4 = "";
+var playIcon$5 = "";
-var pauseIcon$3 = "";
+var pauseIcon$4 = "";
-var audioIcon$2 = "";
+var audioIcon$3 = "";
var coverLocal$2 = "5d9cf0a5d487a818.png";
@@ -60158,7 +60414,7 @@ var playRepeat$2 = "
var playOnce$2 = "";
//
-var script$4K = {
+var script$4R = {
name: 'XmlAudioModalPlayer',
props: {
//模式:preview 预览 (默认),editor 编辑
@@ -60267,9 +60523,9 @@ var script$4K = {
},
data() {
return {
- playIcon: playIcon$4,
- pauseIcon: pauseIcon$3,
- audioIcon: audioIcon$2,
+ playIcon: playIcon$5,
+ pauseIcon: pauseIcon$4,
+ audioIcon: audioIcon$3,
coverLocal: coverLocal$2,
isPlay: false,
playTime: 0,
@@ -60389,10 +60645,10 @@ var script$4K = {
};
/* script */
-const __vue_script__$4K = script$4K;
+const __vue_script__$4R = script$4R;
/* template */
-var __vue_render__$4K = function () {
+var __vue_render__$4R = function () {
var _vm = this;
var _h = _vm.$createElement;
var _c = _vm._self._c || _h;
@@ -60515,17 +60771,17 @@ var __vue_render__$4K = function () {
}),
])
};
-var __vue_staticRenderFns__$4K = [];
-__vue_render__$4K._withStripped = true;
+var __vue_staticRenderFns__$4R = [];
+__vue_render__$4R._withStripped = true;
/* style */
- const __vue_inject_styles__$4K = undefined;
+ const __vue_inject_styles__$4R = undefined;
/* scoped */
- const __vue_scope_id__$4K = undefined;
+ const __vue_scope_id__$4R = undefined;
/* module identifier */
- const __vue_module_identifier__$4K = undefined;
+ const __vue_module_identifier__$4R = undefined;
/* functional template */
- const __vue_is_functional_template__$4K = false;
+ const __vue_is_functional_template__$4R = false;
/* style inject */
/* style inject SSR */
@@ -60534,13 +60790,13 @@ __vue_render__$4K._withStripped = true;
- const __vue_component__$4K = /*#__PURE__*/normalizeComponent(
- { render: __vue_render__$4K, staticRenderFns: __vue_staticRenderFns__$4K },
- __vue_inject_styles__$4K,
- __vue_script__$4K,
- __vue_scope_id__$4K,
- __vue_is_functional_template__$4K,
- __vue_module_identifier__$4K,
+ const __vue_component__$4R = /*#__PURE__*/normalizeComponent(
+ { render: __vue_render__$4R, staticRenderFns: __vue_staticRenderFns__$4R },
+ __vue_inject_styles__$4R,
+ __vue_script__$4R,
+ __vue_scope_id__$4R,
+ __vue_is_functional_template__$4R,
+ __vue_module_identifier__$4R,
false,
undefined,
undefined,
@@ -60548,11 +60804,11 @@ __vue_render__$4K._withStripped = true;
);
//
-var script$4J = {
+var script$4Q = {
name: 'XmlMusicRender',
components: {
vueAplayer,
- XmlAudioModalPlayer: __vue_component__$4K
+ XmlAudioModalPlayer: __vue_component__$4R
},
props: {
//模式:preview 预览 (默认),editor 编辑
@@ -60667,10 +60923,10 @@ var script$4J = {
};
/* script */
-const __vue_script__$4J = script$4J;
+const __vue_script__$4Q = script$4Q;
/* template */
-var __vue_render__$4J = function () {
+var __vue_render__$4Q = function () {
var _vm = this;
var _h = _vm.$createElement;
var _c = _vm._self._c || _h;
@@ -60839,17 +61095,17 @@ var __vue_render__$4J = function () {
2
)
};
-var __vue_staticRenderFns__$4J = [];
-__vue_render__$4J._withStripped = true;
+var __vue_staticRenderFns__$4Q = [];
+__vue_render__$4Q._withStripped = true;
/* style */
- const __vue_inject_styles__$4J = undefined;
+ const __vue_inject_styles__$4Q = undefined;
/* scoped */
- const __vue_scope_id__$4J = undefined;
+ const __vue_scope_id__$4Q = undefined;
/* module identifier */
- const __vue_module_identifier__$4J = undefined;
+ const __vue_module_identifier__$4Q = undefined;
/* functional template */
- const __vue_is_functional_template__$4J = false;
+ const __vue_is_functional_template__$4Q = false;
/* style inject */
/* style inject SSR */
@@ -60858,13 +61114,13 @@ __vue_render__$4J._withStripped = true;
- const __vue_component__$4J = /*#__PURE__*/normalizeComponent(
- { render: __vue_render__$4J, staticRenderFns: __vue_staticRenderFns__$4J },
- __vue_inject_styles__$4J,
- __vue_script__$4J,
- __vue_scope_id__$4J,
- __vue_is_functional_template__$4J,
- __vue_module_identifier__$4J,
+ const __vue_component__$4Q = /*#__PURE__*/normalizeComponent(
+ { render: __vue_render__$4Q, staticRenderFns: __vue_staticRenderFns__$4Q },
+ __vue_inject_styles__$4Q,
+ __vue_script__$4Q,
+ __vue_scope_id__$4Q,
+ __vue_is_functional_template__$4Q,
+ __vue_module_identifier__$4Q,
false,
undefined,
undefined,
@@ -60878,7 +61134,7 @@ var pauseIcon2 = "
var recordIcon = "a6071719aecd4e53.png";
//
-var script$4I = {
+var script$4P = {
name: 'AudioPlay',
props: {
//模式:preview 预览 (默认),editor 编辑
@@ -60996,11 +61252,11 @@ var script$4I = {
},
data() {
return {
- playIcon: playIcon$4,
+ playIcon: playIcon$5,
playIcon2,
- pauseIcon: pauseIcon$3,
+ pauseIcon: pauseIcon$4,
pauseIcon2,
- audioIcon: audioIcon$2,
+ audioIcon: audioIcon$3,
coverLocal: coverLocal$2,
recordIcon,
isPlay: false,
@@ -61122,10 +61378,10 @@ var script$4I = {
};
/* script */
-const __vue_script__$4I = script$4I;
+const __vue_script__$4P = script$4P;
/* template */
-var __vue_render__$4I = function () {
+var __vue_render__$4P = function () {
var _vm = this;
var _h = _vm.$createElement;
var _c = _vm._self._c || _h;
@@ -61395,17 +61651,17 @@ var __vue_render__$4I = function () {
}),
])
};
-var __vue_staticRenderFns__$4I = [];
-__vue_render__$4I._withStripped = true;
+var __vue_staticRenderFns__$4P = [];
+__vue_render__$4P._withStripped = true;
/* style */
- const __vue_inject_styles__$4I = undefined;
+ const __vue_inject_styles__$4P = undefined;
/* scoped */
- const __vue_scope_id__$4I = undefined;
+ const __vue_scope_id__$4P = undefined;
/* module identifier */
- const __vue_module_identifier__$4I = undefined;
+ const __vue_module_identifier__$4P = undefined;
/* functional template */
- const __vue_is_functional_template__$4I = false;
+ const __vue_is_functional_template__$4P = false;
/* style inject */
/* style inject SSR */
@@ -61414,49 +61670,49 @@ __vue_render__$4I._withStripped = true;
- const __vue_component__$4I = /*#__PURE__*/normalizeComponent(
- { render: __vue_render__$4I, staticRenderFns: __vue_staticRenderFns__$4I },
- __vue_inject_styles__$4I,
- __vue_script__$4I,
- __vue_scope_id__$4I,
- __vue_is_functional_template__$4I,
- __vue_module_identifier__$4I,
+ const __vue_component__$4P = /*#__PURE__*/normalizeComponent(
+ { render: __vue_render__$4P, staticRenderFns: __vue_staticRenderFns__$4P },
+ __vue_inject_styles__$4P,
+ __vue_script__$4P,
+ __vue_scope_id__$4P,
+ __vue_is_functional_template__$4P,
+ __vue_module_identifier__$4P,
false,
undefined,
undefined,
undefined
);
-const MusicComponents = [__vue_component__$4J, __vue_component__$4I];
+const MusicComponents = [__vue_component__$4Q, __vue_component__$4P];
var XmlMusic = {
...MusicComponents
};
-const radioType = ['SingleSelect'];
-const checkType = ['MultipleSelect'];
-const showOptionsType = ['1', '2', '4', '5'];
-const showJudgeAnswerType = ['Judgement'];
-const showSortType = ['7'];
-const showRichTextAnswerType = ['Filling', 'AskAnswer'];
-const isclozeType = ['Filling'];
-const isRadio = type => {
- return radioType.includes(type);
+const radioType$1 = ['1', '4'];
+const checkType$1 = ['2', '5'];
+const showOptionsType$1 = ['1', '2', '4', '5'];
+const showJudgeAnswerType$1 = ['3'];
+const showSortType$1 = ['7'];
+const showRichTextAnswerType$1 = ['10', '13'];
+const isclozeType$1 = ['10', '11', '12'];
+const isRadio$1 = type => {
+ return radioType$1.includes(type);
};
-const isCheck = type => checkType.includes(type);
-const showOptions = type => showOptionsType.includes(type);
-const showJudgeAnswer = type => showJudgeAnswerType.includes(type);
-const showSort = type => showSortType.includes(type);
-const showRichTextAnswer = type => showRichTextAnswerType.includes(type);
-const isCloze = type => isclozeType.includes(type);
+const isCheck$1 = type => checkType$1.includes(type);
+const showOptions$1 = type => showOptionsType$1.includes(type);
+const showJudgeAnswer$1 = type => showJudgeAnswerType$1.includes(type);
+const showSort$1 = type => showSortType$1.includes(type);
+const showRichTextAnswer$1 = type => showRichTextAnswerType$1.includes(type);
+const isCloze$1 = type => isclozeType$1.includes(type);
-var playIcon$3 = "";
+var playIcon$4 = "";
-var pauseIcon$2 = "";
+var pauseIcon$3 = "";
-var audioIcon$1 = "";
+var audioIcon$2 = "";
//
-var script$4H = {
+var script$4O = {
name: 'audio-play',
props: {
url: {
@@ -61479,9 +61735,9 @@ var script$4H = {
},
data() {
return {
- playIcon: playIcon$3,
- pauseIcon: pauseIcon$2,
- audioIcon: audioIcon$1,
+ playIcon: playIcon$4,
+ pauseIcon: pauseIcon$3,
+ audioIcon: audioIcon$2,
isPlay: false,
playTime: 0,
playDuration: '00:00',
@@ -61538,9 +61794,9 @@ var script$4H = {
};
/* script */
-const __vue_script__$4H = script$4H;
+const __vue_script__$4O = script$4O;
/* template */
-var __vue_render__$4H = function () {
+var __vue_render__$4O = function () {
var _vm = this;
var _h = _vm.$createElement;
var _c = _vm._self._c || _h;
@@ -61734,17 +61990,17 @@ var __vue_render__$4H = function () {
}),
])
};
-var __vue_staticRenderFns__$4H = [];
-__vue_render__$4H._withStripped = true;
+var __vue_staticRenderFns__$4O = [];
+__vue_render__$4O._withStripped = true;
/* style */
- const __vue_inject_styles__$4H = undefined;
+ const __vue_inject_styles__$4O = undefined;
/* scoped */
- const __vue_scope_id__$4H = "data-v-25355b9e";
+ const __vue_scope_id__$4O = "data-v-160e520c";
/* module identifier */
- const __vue_module_identifier__$4H = undefined;
+ const __vue_module_identifier__$4O = undefined;
/* functional template */
- const __vue_is_functional_template__$4H = false;
+ const __vue_is_functional_template__$4O = false;
/* style inject */
/* style inject SSR */
@@ -61753,20 +62009,20 @@ __vue_render__$4H._withStripped = true;
- const __vue_component__$4H = /*#__PURE__*/normalizeComponent(
- { render: __vue_render__$4H, staticRenderFns: __vue_staticRenderFns__$4H },
- __vue_inject_styles__$4H,
- __vue_script__$4H,
- __vue_scope_id__$4H,
- __vue_is_functional_template__$4H,
- __vue_module_identifier__$4H,
+ const __vue_component__$4O = /*#__PURE__*/normalizeComponent(
+ { render: __vue_render__$4O, staticRenderFns: __vue_staticRenderFns__$4O },
+ __vue_inject_styles__$4O,
+ __vue_script__$4O,
+ __vue_scope_id__$4O,
+ __vue_is_functional_template__$4O,
+ __vue_module_identifier__$4O,
false,
undefined,
undefined,
undefined
);
-var videoIcon = "";
+var videoIcon$1 = "";
var win;
if (typeof window !== "undefined") {
@@ -74732,7 +74988,7 @@ var VueVideoPlayer = unwrapExports(vueVideoPlayer);
vueVideoPlayer.VueVideoPlayer;
//
-var script$4G = {
+var script$4N = {
name: 'video-play',
components: {
videoPlayer: VueVideoPlayer.videoPlayer
@@ -74757,7 +75013,7 @@ var script$4G = {
return {
pageType: 'pc',
isShowPlay: false,
- videoIcon,
+ videoIcon: videoIcon$1,
isPlay: false,
playTime: 0,
playDuration: '00:00',
@@ -74834,9 +75090,9 @@ var script$4G = {
};
/* script */
-const __vue_script__$4G = script$4G;
+const __vue_script__$4N = script$4N;
/* template */
-var __vue_render__$4G = function () {
+var __vue_render__$4N = function () {
var _vm = this;
var _h = _vm.$createElement;
var _c = _vm._self._c || _h;
@@ -74914,17 +75170,17 @@ var __vue_render__$4G = function () {
1
)
};
-var __vue_staticRenderFns__$4G = [];
-__vue_render__$4G._withStripped = true;
+var __vue_staticRenderFns__$4N = [];
+__vue_render__$4N._withStripped = true;
/* style */
- const __vue_inject_styles__$4G = undefined;
+ const __vue_inject_styles__$4N = undefined;
/* scoped */
- const __vue_scope_id__$4G = "data-v-7628e470";
+ const __vue_scope_id__$4N = "data-v-7cccb5ec";
/* module identifier */
- const __vue_module_identifier__$4G = undefined;
+ const __vue_module_identifier__$4N = undefined;
/* functional template */
- const __vue_is_functional_template__$4G = false;
+ const __vue_is_functional_template__$4N = false;
/* style inject */
/* style inject SSR */
@@ -74933,13 +75189,13 @@ __vue_render__$4G._withStripped = true;
- const __vue_component__$4G = /*#__PURE__*/normalizeComponent(
- { render: __vue_render__$4G, staticRenderFns: __vue_staticRenderFns__$4G },
- __vue_inject_styles__$4G,
- __vue_script__$4G,
- __vue_scope_id__$4G,
- __vue_is_functional_template__$4G,
- __vue_module_identifier__$4G,
+ const __vue_component__$4N = /*#__PURE__*/normalizeComponent(
+ { render: __vue_render__$4N, staticRenderFns: __vue_staticRenderFns__$4N },
+ __vue_inject_styles__$4N,
+ __vue_script__$4N,
+ __vue_scope_id__$4N,
+ __vue_is_functional_template__$4N,
+ __vue_module_identifier__$4N,
false,
undefined,
undefined,
@@ -74947,11 +75203,11 @@ __vue_render__$4G._withStripped = true;
);
//
-var script$4F = {
+var script$4M = {
name: 'bc-file-render',
components: {
- audioPlay: __vue_component__$4H,
- videoPlay: __vue_component__$4G
+ audioPlay: __vue_component__$4O,
+ videoPlay: __vue_component__$4N
},
props: {
fileInfo: {
@@ -75001,9 +75257,9 @@ var script$4F = {
};
/* script */
-const __vue_script__$4F = script$4F;
+const __vue_script__$4M = script$4M;
/* template */
-var __vue_render__$4F = function () {
+var __vue_render__$4M = function () {
var _vm = this;
var _h = _vm.$createElement;
var _c = _vm._self._c || _h;
@@ -75127,17 +75383,17 @@ var __vue_render__$4F = function () {
1
)
};
-var __vue_staticRenderFns__$4F = [];
-__vue_render__$4F._withStripped = true;
+var __vue_staticRenderFns__$4M = [];
+__vue_render__$4M._withStripped = true;
/* style */
- const __vue_inject_styles__$4F = undefined;
+ const __vue_inject_styles__$4M = undefined;
/* scoped */
- const __vue_scope_id__$4F = "data-v-506f1aca";
+ const __vue_scope_id__$4M = "data-v-643cc5f7";
/* module identifier */
- const __vue_module_identifier__$4F = undefined;
+ const __vue_module_identifier__$4M = undefined;
/* functional template */
- const __vue_is_functional_template__$4F = false;
+ const __vue_is_functional_template__$4M = false;
/* style inject */
/* style inject SSR */
@@ -75146,13 +75402,13 @@ __vue_render__$4F._withStripped = true;
- const __vue_component__$4F = /*#__PURE__*/normalizeComponent(
- { render: __vue_render__$4F, staticRenderFns: __vue_staticRenderFns__$4F },
- __vue_inject_styles__$4F,
- __vue_script__$4F,
- __vue_scope_id__$4F,
- __vue_is_functional_template__$4F,
- __vue_module_identifier__$4F,
+ const __vue_component__$4M = /*#__PURE__*/normalizeComponent(
+ { render: __vue_render__$4M, staticRenderFns: __vue_staticRenderFns__$4M },
+ __vue_inject_styles__$4M,
+ __vue_script__$4M,
+ __vue_scope_id__$4M,
+ __vue_is_functional_template__$4M,
+ __vue_module_identifier__$4M,
false,
undefined,
undefined,
@@ -75160,10 +75416,10 @@ __vue_render__$4F._withStripped = true;
);
//
-var script$4E = {
+var script$4L = {
name: 'BcViewCommon',
components: {
- bcFileRenderNew: __vue_component__$4F
+ bcFileRenderNew: __vue_component__$4M
},
props: {
content: {
@@ -75249,9 +75505,9 @@ var script$4E = {
};
/* script */
-const __vue_script__$4E = script$4E;
+const __vue_script__$4L = script$4L;
/* template */
-var __vue_render__$4E = function () {
+var __vue_render__$4L = function () {
var _vm = this;
var _h = _vm.$createElement;
var _c = _vm._self._c || _h;
@@ -75319,17 +75575,17 @@ var __vue_render__$4E = function () {
),
])
};
-var __vue_staticRenderFns__$4E = [];
-__vue_render__$4E._withStripped = true;
+var __vue_staticRenderFns__$4L = [];
+__vue_render__$4L._withStripped = true;
/* style */
- const __vue_inject_styles__$4E = undefined;
+ const __vue_inject_styles__$4L = undefined;
/* scoped */
- const __vue_scope_id__$4E = "data-v-3d2dcb5b";
+ const __vue_scope_id__$4L = "data-v-55ea6f92";
/* module identifier */
- const __vue_module_identifier__$4E = undefined;
+ const __vue_module_identifier__$4L = undefined;
/* functional template */
- const __vue_is_functional_template__$4E = false;
+ const __vue_is_functional_template__$4L = false;
/* style inject */
/* style inject SSR */
@@ -75338,13 +75594,13 @@ __vue_render__$4E._withStripped = true;
- const __vue_component__$4E = /*#__PURE__*/normalizeComponent(
- { render: __vue_render__$4E, staticRenderFns: __vue_staticRenderFns__$4E },
- __vue_inject_styles__$4E,
- __vue_script__$4E,
- __vue_scope_id__$4E,
- __vue_is_functional_template__$4E,
- __vue_module_identifier__$4E,
+ const __vue_component__$4L = /*#__PURE__*/normalizeComponent(
+ { render: __vue_render__$4L, staticRenderFns: __vue_staticRenderFns__$4L },
+ __vue_inject_styles__$4L,
+ __vue_script__$4L,
+ __vue_scope_id__$4L,
+ __vue_is_functional_template__$4L,
+ __vue_module_identifier__$4L,
false,
undefined,
undefined,
@@ -75352,10 +75608,10 @@ __vue_render__$4E._withStripped = true;
);
//
-var script$4D = {
+var script$4K = {
name: 'bc-view-option-radio',
components: {
- BcViewCommon: __vue_component__$4E
+ BcViewCommon: __vue_component__$4L
},
props: {
option: {
@@ -75387,8 +75643,7 @@ var script$4D = {
default: 'radio'
},
standardAnswer: {
- type: [String, Number],
- default: ''
+ type: Array
},
resourceBasisPath: {
type: String,
@@ -75404,7 +75659,6 @@ var script$4D = {
optionsList: [],
selectData: '',
isAnswer: false,
- answerIsTrue: false,
radioJudeMap: {
A: '正确',
B: '错误'
@@ -75437,11 +75691,56 @@ var script$4D = {
},
methods: {
isActive(item) {
- return item.number === this.selectData;
+ return item.title === this.selectData && !this.readonly;
},
isTrue(item) {
+ // if (this.type === 'radio') {
+ // if (this.selectData) {
+ // //当前等于选中
+ // if (item.title === this.selectData) {
+ // //等于正确答案
+ // if (item.title === this.standardAnswer[0].title) {
+ // return true
+ // } else {
+ // return false
+ // }
+ // } else {
+ // //等于正确答案
+ // if (item.title === this.standardAnswer[0].title) {
+ // return true
+ // } else {
+ // return false
+ // }
+ // }
+ // } else {
+ // return false
+ // }
+ // } else {
+ // if (this.selectData) {
+ // //当前等于选中
+ // if (item.title === this.selectData) {
+ // //等于正确答案
+ // if (item.content === this.standardAnswer[0]) {
+ // return true
+ // } else {
+ // return false
+ // }
+ // } else {
+ // //等于正确答案
+ // if (item.content === this.standardAnswer[0]) {
+ // return true
+ // } else {
+ // return false
+ // }
+ // }
+ // } else {
+ // return false
+ // }
+ // }
if (this.type === 'radio') {
- return this.isAnswer && item.number === this.selectData && item.isRightAnswer;
+ return this.isAnswer && this.selectData && this.selectData === item.title && this.standardAnswer.some(i => i.title === item.title);
+ } else {
+ return this.isAnswer && this.selectData && this.selectData === item.title && this.standardAnswer.some(i => i === item.content);
}
},
isFalse(item) {
@@ -75451,7 +75750,30 @@ var script$4D = {
if (this.type === 'radio') {
if (this.selectData) {
//当前为选中的
- return item.number === this.selectData && !item.isRightAnswer;
+ if (item.title === this.selectData) {
+ if (this.standardAnswer[0].title === item.title) {
+ return false;
+ } else {
+ return true;
+ }
+ } else {
+ return false;
+ }
+ } else {
+ return false;
+ }
+ } else {
+ if (this.selectData) {
+ //当前为选中的
+ if (item.title === this.selectData) {
+ if (this.standardAnswer[0] === item.content) {
+ return false;
+ } else {
+ return true;
+ }
+ } else {
+ return false;
+ }
} else {
return false;
}
@@ -75463,17 +75785,14 @@ var script$4D = {
this.$message.error('请选择答案');
return;
}
- // let answerIsTrue = false
- // if (this.type === 'radio') {
- // console.log(this.selectData, this.standardAnswer)
- // answerIsTrue = this.optionsList[this.standardAnswer - 1].number === this.selectData ? true : false
- // // answerIsTrue = this.standardAnswer.some((i) => i.title === this.selectData)
- // } else {
- // answerIsTrue = this.standardAnswer.some((i) => i === this.radioJudeMap[this.selectData])
- // }
-
+ let answerIsTrue = false;
+ if (this.type === 'radio') {
+ answerIsTrue = this.standardAnswer.some(i => i.title === this.selectData);
+ } else {
+ answerIsTrue = this.standardAnswer.some(i => i === this.radioJudeMap[this.selectData]);
+ }
this.isAnswer = true;
- this.$emit('showAnalysis', this.answerIsTrue);
+ this.$emit('showAnalysis', answerIsTrue);
},
afresh() {
this.selectData = '';
@@ -75481,8 +75800,7 @@ var script$4D = {
this.$emit('afresh');
},
select(item) {
- this.selectData = item.number;
- this.answerIsTrue = item.isRightAnswer;
+ this.selectData = item;
// this.$emit('showAnalysis')
}
}
@@ -75493,8 +75811,8 @@ var __$_require_static_images_leaflet_icons_correct_png__ = "data:image/png;base
var __$_require_static_images_leaflet_icons_error_png__ = "";
/* script */
-const __vue_script__$4D = script$4D;
-var __vue_render__$4D = function () {
+const __vue_script__$4K = script$4K;
+var __vue_render__$4K = function () {
var _vm = this;
var _h = _vm.$createElement;
var _c = _vm._self._c || _h;
@@ -75517,7 +75835,7 @@ var __vue_render__$4D = function () {
on: {
click: function ($event) {
$event.stopPropagation();
- return _vm.select(item)
+ return _vm.select(item.title)
},
},
},
@@ -75549,7 +75867,7 @@ var __vue_render__$4D = function () {
!_vm.readonly && !_vm.isTrue(item) && !_vm.isFalse(item)
? _c(
"el-radio",
- { attrs: { value: _vm.selectData, label: item.number } },
+ { attrs: { value: _vm.selectData, label: item.title } },
[_vm._v(_vm._s(""))]
)
: _vm._e(),
@@ -75578,7 +75896,7 @@ var __vue_render__$4D = function () {
attrs: {
"flex-box": "1",
border: false,
- content: item.description,
+ content: item.content,
fileInfo: item.fileInfo,
resourceBasisPath: _vm.resourceBasisPath,
pageType: _vm.pageType,
@@ -75630,17 +75948,17 @@ var __vue_render__$4D = function () {
: _vm._e(),
])
};
-var __vue_staticRenderFns__$4D = [];
-__vue_render__$4D._withStripped = true;
+var __vue_staticRenderFns__$4K = [];
+__vue_render__$4K._withStripped = true;
/* style */
- const __vue_inject_styles__$4D = undefined;
+ const __vue_inject_styles__$4K = undefined;
/* scoped */
- const __vue_scope_id__$4D = "data-v-7fac7a23";
+ const __vue_scope_id__$4K = "data-v-6b27b5ec";
/* module identifier */
- const __vue_module_identifier__$4D = undefined;
+ const __vue_module_identifier__$4K = undefined;
/* functional template */
- const __vue_is_functional_template__$4D = false;
+ const __vue_is_functional_template__$4K = false;
/* style inject */
/* style inject SSR */
@@ -75649,13 +75967,13 @@ __vue_render__$4D._withStripped = true;
- const __vue_component__$4D = /*#__PURE__*/normalizeComponent(
- { render: __vue_render__$4D, staticRenderFns: __vue_staticRenderFns__$4D },
- __vue_inject_styles__$4D,
- __vue_script__$4D,
- __vue_scope_id__$4D,
- __vue_is_functional_template__$4D,
- __vue_module_identifier__$4D,
+ const __vue_component__$4K = /*#__PURE__*/normalizeComponent(
+ { render: __vue_render__$4K, staticRenderFns: __vue_staticRenderFns__$4K },
+ __vue_inject_styles__$4K,
+ __vue_script__$4K,
+ __vue_scope_id__$4K,
+ __vue_is_functional_template__$4K,
+ __vue_module_identifier__$4K,
false,
undefined,
undefined,
@@ -75663,10 +75981,10 @@ __vue_render__$4D._withStripped = true;
);
//
-var script$4C = {
+var script$4J = {
name: 'bc-view-option-checkbox',
components: {
- BcViewCommon: __vue_component__$4E
+ BcViewCommon: __vue_component__$4L
},
props: {
option: {
@@ -75694,8 +76012,8 @@ var script$4C = {
default: () => {}
},
standardAnswer: {
- type: [String, Number],
- default: ''
+ type: Array,
+ default: () => []
},
resourceBasisPath: {
type: String,
@@ -75750,6 +76068,7 @@ var script$4C = {
} else {
this.selectData.push(item);
}
+ this.selectData.sort((a, b) => a.charCodeAt() - b.charCodeAt());
this.$emit('change', this.selectData.join(''));
},
submitAnswer() {
@@ -75757,9 +76076,7 @@ var script$4C = {
this.$message.error('请选择答案');
return;
}
-
- // let answerIsTrue = this.standardAnswer.map((i) => i.title).join('、') === this.selectData.join('、')
- let answerIsTrue = false;
+ let answerIsTrue = this.standardAnswer.map(i => i.title).join('、') === this.selectData.join('、');
this.isAnswer = true;
this.$emit('showAnalysis', answerIsTrue);
},
@@ -75777,8 +76094,8 @@ var script$4C = {
};
/* script */
-const __vue_script__$4C = script$4C;
-var __vue_render__$4C = function () {
+const __vue_script__$4J = script$4J;
+var __vue_render__$4J = function () {
var _vm = this;
var _h = _vm.$createElement;
var _c = _vm._self._c || _h;
@@ -75793,21 +76110,27 @@ var __vue_render__$4C = function () {
key: index,
staticClass: "option-item",
class: {
- isActive: _vm.selectData.includes(item.number) && !_vm.readonly,
+ isActive: _vm.selectData.includes(item.title) && !_vm.readonly,
isTrue:
_vm.isAnswer &&
- _vm.selectData.includes(item.number) &&
- item.isRightAnswer,
+ _vm.selectData.length &&
+ _vm.selectData.includes(item.title) &&
+ _vm.standardAnswer.some(function (i) {
+ return i.title === item.title
+ }),
isFalse:
_vm.isAnswer &&
- _vm.selectData.includes(item.number) &&
- !item.isRightAnswer,
+ _vm.selectData.length &&
+ _vm.selectData.includes(item.title) &&
+ _vm.standardAnswer.every(function (i) {
+ return i.title !== item.title
+ }),
},
attrs: { flex: "" },
on: {
click: function ($event) {
$event.stopPropagation();
- return _vm.select(item.number, $event)
+ return _vm.select(item.title, $event)
},
},
},
@@ -75817,8 +76140,11 @@ var __vue_render__$4C = function () {
{ staticClass: "questionSeq" },
[
_vm.isAnswer &&
- _vm.selectData.includes(item.number) &&
- item.isRightAnswer
+ _vm.selectData.length &&
+ _vm.selectData.includes(item.title) &&
+ _vm.standardAnswer.some(function (i) {
+ return i.title === item.title
+ })
? _c("img", {
staticStyle: { "margin-right": "10px" },
attrs: {
@@ -75829,8 +76155,11 @@ var __vue_render__$4C = function () {
: _vm._e(),
_vm._v(" "),
_vm.isAnswer &&
- _vm.selectData.includes(item.number) &&
- !item.isRightAnswer
+ _vm.selectData.length &&
+ _vm.selectData.includes(item.title) &&
+ _vm.standardAnswer.every(function (i) {
+ return i.title !== item.title
+ })
? _c("img", {
staticStyle: { "margin-right": "10px" },
attrs: {
@@ -75844,13 +76173,13 @@ var __vue_render__$4C = function () {
? _c(
"el-checkbox",
{
- attrs: { value: _vm.selectData.includes(item.number) },
+ attrs: { value: _vm.selectData.includes(item.title) },
nativeOn: {
click: function ($event) {
_vm.SkipProgress(
$event,
- item.number,
- _vm.selectData.includes(item.number)
+ item.title,
+ _vm.selectData.includes(item.title)
);
},
},
@@ -75883,7 +76212,7 @@ var __vue_render__$4C = function () {
attrs: {
"flex-box": "1",
border: false,
- content: item.description,
+ content: item.content,
fileInfo: item.fileInfo,
resourceBasisPath: _vm.resourceBasisPath,
pageType: _vm.pageType,
@@ -75935,17 +76264,17 @@ var __vue_render__$4C = function () {
: _vm._e(),
])
};
-var __vue_staticRenderFns__$4C = [];
-__vue_render__$4C._withStripped = true;
+var __vue_staticRenderFns__$4J = [];
+__vue_render__$4J._withStripped = true;
/* style */
- const __vue_inject_styles__$4C = undefined;
+ const __vue_inject_styles__$4J = undefined;
/* scoped */
- const __vue_scope_id__$4C = "data-v-fa728c70";
+ const __vue_scope_id__$4J = "data-v-307b4eb2";
/* module identifier */
- const __vue_module_identifier__$4C = undefined;
+ const __vue_module_identifier__$4J = undefined;
/* functional template */
- const __vue_is_functional_template__$4C = false;
+ const __vue_is_functional_template__$4J = false;
/* style inject */
/* style inject SSR */
@@ -75954,13 +76283,13 @@ __vue_render__$4C._withStripped = true;
- const __vue_component__$4C = /*#__PURE__*/normalizeComponent(
- { render: __vue_render__$4C, staticRenderFns: __vue_staticRenderFns__$4C },
- __vue_inject_styles__$4C,
- __vue_script__$4C,
- __vue_scope_id__$4C,
- __vue_is_functional_template__$4C,
- __vue_module_identifier__$4C,
+ const __vue_component__$4J = /*#__PURE__*/normalizeComponent(
+ { render: __vue_render__$4J, staticRenderFns: __vue_staticRenderFns__$4J },
+ __vue_inject_styles__$4J,
+ __vue_script__$4J,
+ __vue_scope_id__$4J,
+ __vue_is_functional_template__$4J,
+ __vue_module_identifier__$4J,
false,
undefined,
undefined,
@@ -75968,12 +76297,12 @@ __vue_render__$4C._withStripped = true;
);
//
-var script$4B = {
+var script$4I = {
name: 'QuestionItem',
components: {
- BcViewOptionCheckbox: __vue_component__$4C,
- BcViewOptionRadio: __vue_component__$4D,
- BcViewCommon: __vue_component__$4E
+ BcViewOptionCheckbox: __vue_component__$4J,
+ BcViewOptionRadio: __vue_component__$4K,
+ BcViewCommon: __vue_component__$4L
},
// dicts: ['question_type'],
data() {
@@ -76013,7 +76342,7 @@ var script$4B = {
},
questionNumber: {
type: Number,
- default: -1
+ default: 0
},
isShowAi: {
type: String,
@@ -76047,25 +76376,25 @@ var script$4B = {
return this.isAnswer && this.canShowKnowledge === 'true';
},
isRadio() {
- return isRadio(this.question.type);
+ return isRadio$1(this.question.questionType);
},
isCheck() {
- return isCheck(this.question.type);
+ return isCheck$1(this.question.questionType);
},
showJudgeAnswer() {
- return showJudgeAnswer(this.question.type);
+ return showJudgeAnswer$1(this.question.questionType);
},
showRichTextAnswer() {
- return showRichTextAnswer(this.question.type);
+ return showRichTextAnswer$1(this.question.questionType);
},
showOptions() {
- return showOptions(this.question.type);
+ return showOptions$1(this.question.questionType);
},
showSort() {
- return showSort(this.question.type);
+ return showSort$1(this.question.questionType);
},
isCloze() {
- return isCloze(this.question.type);
+ return isCloze$1(this.question.questionType);
},
clozeLength() {
let fillInTheBlanksSpan = this.question.stem.content.match(/fillInTheBlanksSpan/g);
@@ -76147,7 +76476,7 @@ var script$4B = {
}
}
},
- //
+ //
changeAnswer() {
if (this.isRadio || this.showJudgeAnswer) {
this.$refs.bcViewOptionRadio?.submitAnswer();
@@ -76206,14 +76535,33 @@ var script$4B = {
e = e.replace(/ /gi, ''); //去除空格
return e;
}
+ },
+ getPaperList(list) {
+ if (list.length > 0) {
+ let answerList = [];
+ list.map(item => {
+ if (typeof item == 'string') {
+ let data = {
+ selected: false,
+ ...JSON.parse(item)
+ };
+ answerList.push(data);
+ } else {
+ this.$set(item, 'selected', false);
+ answerList = list;
+ }
+ });
+ return answerList;
+ }
}
}
};
+var __$_require_static_images_leaflet_icons_ai_png__ = "";
+
/* script */
-const __vue_script__$4B = script$4B;
-/* template */
-var __vue_render__$4B = function () {
+const __vue_script__$4I = script$4I;
+var __vue_render__$4I = function () {
var _vm = this;
var _h = _vm.$createElement;
var _c = _vm._self._c || _h;
@@ -76231,31 +76579,11 @@ var __vue_render__$4B = function () {
"div",
{ staticClass: "stem-box", staticStyle: { display: "flex" } },
[
- _vm.questionNumber !== -1
- ? _c(
- "div",
- {
- staticClass: "question-number",
- staticStyle: {
- "line-height": "28px",
- "padding-right": "4px",
- },
- },
- [
- _vm._v(
- "\n " +
- _vm._s(_vm.questionNumber + 1) +
- " .\n "
- ),
- ]
- )
- : _vm._e(),
- _vm._v(" "),
_c("bc-view-common", {
staticClass: "xml-question-title",
staticStyle: { flex: "1", "min-width": "0" },
attrs: {
- content: _vm.question.description,
+ content: _vm.question.stem.content,
border: false,
fileInfo: _vm.question.stem.fileInfo,
resourceBasisPath: _vm.resourceBasisPath,
@@ -76277,8 +76605,8 @@ var __vue_render__$4B = function () {
_c("bc-view-option-radio", {
ref: "bcViewOptionRadio",
attrs: {
- standardAnswer: _vm.question.answer,
- option: _vm.question.candidates,
+ standardAnswer: _vm.question.standardAnswer,
+ option: _vm.question.questionOption,
resourceBasisPath: _vm.resourceBasisPath,
isSubmit: _vm.isSubmit,
pageType: _vm.pageType,
@@ -76298,8 +76626,8 @@ var __vue_render__$4B = function () {
_c("bc-view-option-checkbox", {
ref: "bcViewOptionCheckbox",
attrs: {
- option: _vm.question.candidates,
- standardAnswer: _vm.question.answer,
+ option: _vm.question.questionOption,
+ standardAnswer: _vm.question.standardAnswer,
resourceBasisPath: _vm.resourceBasisPath,
isSubmit: _vm.isSubmit,
pageType: _vm.pageType,
@@ -76365,7 +76693,7 @@ var __vue_render__$4B = function () {
},
},
},
- [_vm._v("\n 重新作答\n ")]
+ [_vm._v("重新作答")]
)
: _vm._e(),
],
@@ -76380,11 +76708,15 @@ var __vue_render__$4B = function () {
_c("bc-view-option-radio", {
ref: "bcViewOptionRadio",
attrs: {
- standardAnswer: _vm.question.answer,
+ standardAnswer: _vm.question.standardAnswer,
resourceBasisPath: _vm.resourceBasisPath,
pageType: _vm.pageType,
isSubmit: _vm.isSubmit,
- option: _vm.question.candidates,
+ type: "judge",
+ option: [
+ { title: "A", content: "正确" },
+ { title: "B", content: "错误" },
+ ],
},
on: { showAnalysis: _vm.showAnalysis, afresh: _vm.afresh },
}),
@@ -76439,7 +76771,7 @@ var __vue_render__$4B = function () {
questionId: _vm.question.id,
questionName: JSON.stringify(_vm.question.stem),
userAnswer: _vm.clozeLength,
- questionType: "Filling",
+ questionType: "fillInTheBlanks",
});
},
},
@@ -76454,11 +76786,11 @@ var __vue_render__$4B = function () {
"xml-submit-answer xml-submit-answer-right",
on: {
click: function ($event) {
- return _vm.afresh("Filling")
+ return _vm.afresh("fillInTheBlanks")
},
},
},
- [_vm._v("\n 重新作答\n ")]
+ [_vm._v("重新作答")]
)
: _vm._e(),
],
@@ -76481,20 +76813,67 @@ var __vue_render__$4B = function () {
[
_c("div", { staticClass: "question-label" }, [
_vm._v(
- "正确答案:" +
- _vm._s(_vm.serialNumber[_vm.question.answer - 1])
+ _vm._s(
+ _vm.question.questionType == 13
+ ? "参考答案:"
+ : "正确答案:"
+ )
),
]),
_vm._v(" "),
- _c("div", {
- staticStyle: {
- color: "#0070c1",
- "min-width": "0",
- flex: "1",
- "line-height": "28px",
- display: "inline-block",
+ _c(
+ "div",
+ {
+ staticStyle: {
+ color: "#0070c1",
+ "min-width": "0",
+ flex: "1",
+ "line-height": "28px",
+ },
},
- }),
+ [
+ _vm.question.questionType == 3
+ ? [
+ _c("span", [
+ _vm._v(
+ "\n " +
+ _vm._s(_vm.standardAnswer) +
+ "\n "
+ ),
+ ]),
+ ]
+ : _vm._l(
+ _vm.getPaperList(_vm.question.questionOption),
+ function (item, index) {
+ return _c(
+ "span",
+ {
+ directives: [
+ {
+ name: "show",
+ rawName: "v-show",
+ value: _vm.standardAnswer.includes(
+ item.title
+ ),
+ expression:
+ "standardAnswer.includes(item.title)",
+ },
+ ],
+ key: index,
+ },
+ [
+ _vm._v(
+ "\n " +
+ _vm._s(_vm.serialNumber[index]) +
+ "\n "
+ ),
+ ]
+ )
+ }
+ ),
+ ],
+ 2
+ ),
]
),
])
@@ -76509,7 +76888,13 @@ var __vue_render__$4B = function () {
},
[
_c("div", { staticClass: "question-label" }, [
- _vm._v("正确答案:"),
+ _vm._v(
+ _vm._s(
+ _vm.question.questionType == 13
+ ? "参考答案:"
+ : "正确答案:"
+ )
+ ),
]),
_vm._v(" "),
_c(
@@ -76587,21 +76972,71 @@ var __vue_render__$4B = function () {
]
)
: _vm._e(),
+ _vm._v(" "),
+ _vm.isShowKnowledge && _vm.question.knowledgePointVoList.length
+ ? _c("div", { staticClass: "info-item", attrs: { flex: "" } }, [
+ _c("div", { staticClass: "info-item--label" }, [
+ _vm._v("知识点:"),
+ ]),
+ _vm._v(" "),
+ _c(
+ "div",
+ {
+ staticClass: "info-item--content",
+ staticStyle: { flex: "1" },
+ },
+ [
+ _vm.question.knowledgePointVoList &&
+ _vm.question.knowledgePointVoList.length
+ ? _vm._l(
+ _vm.question.knowledgePointVoList,
+ function (item) {
+ return _c(
+ "el-tag",
+ {
+ key: item.id,
+ staticStyle: {
+ "margin-right": "8px",
+ "margin-bottom": "8px",
+ },
+ attrs: { effect: "plain" },
+ },
+ [_vm._v(_vm._s(item.kpName))]
+ )
+ }
+ )
+ : [_c("span", [_vm._v("无")])],
+ ],
+ 2
+ ),
+ ])
+ : _vm._e(),
+ _vm._v(" "),
+ _vm.isShowAi == "0"
+ ? _c("div", { staticClass: "AIbtn", on: { click: _vm.AIanalysis } }, [
+ _c("img", {
+ attrs: {
+ src: __$_require_static_images_leaflet_icons_ai_png__,
+ alt: "",
+ },
+ }),
+ ])
+ : _vm._e(),
]
),
])
};
-var __vue_staticRenderFns__$4B = [];
-__vue_render__$4B._withStripped = true;
+var __vue_staticRenderFns__$4I = [];
+__vue_render__$4I._withStripped = true;
/* style */
- const __vue_inject_styles__$4B = undefined;
+ const __vue_inject_styles__$4I = undefined;
/* scoped */
- const __vue_scope_id__$4B = "data-v-6bf2ab28";
+ const __vue_scope_id__$4I = "data-v-0ef5bb3c";
/* module identifier */
- const __vue_module_identifier__$4B = undefined;
+ const __vue_module_identifier__$4I = undefined;
/* functional template */
- const __vue_is_functional_template__$4B = false;
+ const __vue_is_functional_template__$4I = false;
/* style inject */
/* style inject SSR */
@@ -76610,13 +77045,13 @@ __vue_render__$4B._withStripped = true;
- const __vue_component__$4B = /*#__PURE__*/normalizeComponent(
- { render: __vue_render__$4B, staticRenderFns: __vue_staticRenderFns__$4B },
- __vue_inject_styles__$4B,
- __vue_script__$4B,
- __vue_scope_id__$4B,
- __vue_is_functional_template__$4B,
- __vue_module_identifier__$4B,
+ const __vue_component__$4I = /*#__PURE__*/normalizeComponent(
+ { render: __vue_render__$4I, staticRenderFns: __vue_staticRenderFns__$4I },
+ __vue_inject_styles__$4I,
+ __vue_script__$4I,
+ __vue_scope_id__$4I,
+ __vue_is_functional_template__$4I,
+ __vue_module_identifier__$4I,
false,
undefined,
undefined,
@@ -76624,10 +77059,10 @@ __vue_render__$4B._withStripped = true;
);
//
-var script$4A = {
+var script$4H = {
name: 'XmlQuestionRender',
components: {
- QuestionItem: __vue_component__$4B
+ QuestionItem: __vue_component__$4I
},
// dicts: [
// "question_type",
@@ -76751,9 +77186,9 @@ var script$4A = {
};
/* script */
-const __vue_script__$4A = script$4A;
+const __vue_script__$4H = script$4H;
/* template */
-var __vue_render__$4A = function () {
+var __vue_render__$4H = function () {
var _vm = this;
var _h = _vm.$createElement;
var _c = _vm._self._c || _h;
@@ -76783,7 +77218,7 @@ var __vue_render__$4A = function () {
"can-show-answer": _vm.pBlockData.showAnswer,
"can-show-knowledge": _vm.pBlockData.showRecommend,
border: index < _vm.questionSetList.length - 1 ? true : false,
- "question-number": _vm.questionSetList.length > 1 ? index : -1,
+ "question-number": index,
"is-show-ai": _vm.isShowAi,
resourceBasisPath: _vm.resourceBasisPath,
pageType: _vm.pageType,
@@ -76801,17 +77236,17 @@ var __vue_render__$4A = function () {
]
)
};
-var __vue_staticRenderFns__$4A = [];
-__vue_render__$4A._withStripped = true;
+var __vue_staticRenderFns__$4H = [];
+__vue_render__$4H._withStripped = true;
/* style */
- const __vue_inject_styles__$4A = undefined;
+ const __vue_inject_styles__$4H = undefined;
/* scoped */
- const __vue_scope_id__$4A = "data-v-0f531fa4";
+ const __vue_scope_id__$4H = "data-v-2e04d85c";
/* module identifier */
- const __vue_module_identifier__$4A = undefined;
+ const __vue_module_identifier__$4H = undefined;
/* functional template */
- const __vue_is_functional_template__$4A = false;
+ const __vue_is_functional_template__$4H = false;
/* style inject */
/* style inject SSR */
@@ -76820,23 +77255,23 @@ __vue_render__$4A._withStripped = true;
- const __vue_component__$4A = /*#__PURE__*/normalizeComponent(
- { render: __vue_render__$4A, staticRenderFns: __vue_staticRenderFns__$4A },
- __vue_inject_styles__$4A,
- __vue_script__$4A,
- __vue_scope_id__$4A,
- __vue_is_functional_template__$4A,
- __vue_module_identifier__$4A,
+ const __vue_component__$4H = /*#__PURE__*/normalizeComponent(
+ { render: __vue_render__$4H, staticRenderFns: __vue_staticRenderFns__$4H },
+ __vue_inject_styles__$4H,
+ __vue_script__$4H,
+ __vue_scope_id__$4H,
+ __vue_is_functional_template__$4H,
+ __vue_module_identifier__$4H,
false,
undefined,
undefined,
undefined
);
-__vue_component__$4A.install = (Vue, options = {}) => {
+__vue_component__$4H.install = (Vue, options = {}) => {
Vue.component(createNamespace$1('question-render', {
prefix: options.prefix
- }), __vue_component__$4A);
+ }), __vue_component__$4H);
};
var epub = "";
@@ -76854,7 +77289,7 @@ var image = {
// import { OuchnOss } from '@/api/business/file/OuchnOss'
// import { defaultCover } from '@/assets/remote'
-var script$4z = {
+var script$4G = {
name: 'XmlResourceRender',
props: {
//模式:preview 预览 (默认),editor 编辑
@@ -77049,8 +77484,8 @@ var __$_require_static_images_leaflet_icons_resource_elliptic_png__ = "data:imag
var __$_require_static_images_leaflet_icons_download_white_png__ = "";
/* script */
-const __vue_script__$4z = script$4z;
-var __vue_render__$4z = function () {
+const __vue_script__$4G = script$4G;
+var __vue_render__$4G = function () {
var _vm = this;
var _h = _vm.$createElement;
var _c = _vm._self._c || _h;
@@ -77658,7 +78093,7 @@ var __vue_render__$4z = function () {
]
)
};
-var __vue_staticRenderFns__$4z = [
+var __vue_staticRenderFns__$4G = [
function () {
var _vm = this;
var _h = _vm.$createElement;
@@ -77676,16 +78111,16 @@ var __vue_staticRenderFns__$4z = [
])
},
];
-__vue_render__$4z._withStripped = true;
+__vue_render__$4G._withStripped = true;
/* style */
- const __vue_inject_styles__$4z = undefined;
+ const __vue_inject_styles__$4G = undefined;
/* scoped */
- const __vue_scope_id__$4z = "data-v-2be4d8c2";
+ const __vue_scope_id__$4G = "data-v-2be4d8c2";
/* module identifier */
- const __vue_module_identifier__$4z = undefined;
+ const __vue_module_identifier__$4G = undefined;
/* functional template */
- const __vue_is_functional_template__$4z = false;
+ const __vue_is_functional_template__$4G = false;
/* style inject */
/* style inject SSR */
@@ -77694,23 +78129,23 @@ __vue_render__$4z._withStripped = true;
- const __vue_component__$4z = /*#__PURE__*/normalizeComponent(
- { render: __vue_render__$4z, staticRenderFns: __vue_staticRenderFns__$4z },
- __vue_inject_styles__$4z,
- __vue_script__$4z,
- __vue_scope_id__$4z,
- __vue_is_functional_template__$4z,
- __vue_module_identifier__$4z,
+ const __vue_component__$4G = /*#__PURE__*/normalizeComponent(
+ { render: __vue_render__$4G, staticRenderFns: __vue_staticRenderFns__$4G },
+ __vue_inject_styles__$4G,
+ __vue_script__$4G,
+ __vue_scope_id__$4G,
+ __vue_is_functional_template__$4G,
+ __vue_module_identifier__$4G,
false,
undefined,
undefined,
undefined
);
-__vue_component__$4z.install = (Vue, options = {}) => {
+__vue_component__$4G.install = (Vue, options = {}) => {
Vue.component(createNamespace$1('resource-render', {
prefix: options.prefix
- }), __vue_component__$4z);
+ }), __vue_component__$4G);
};
//
@@ -77744,7 +78179,7 @@ __vue_component__$4z.install = (Vue, options = {}) => {
//
//
-var script$4y = {
+var script$4F = {
name: 'PdfView',
props: {
show: {
@@ -77778,8 +78213,8 @@ var script$4y = {
var __$_require_static_images_leaflet_icons_back_png__ = "";
/* script */
-const __vue_script__$4y = script$4y;
-var __vue_render__$4y = function () {
+const __vue_script__$4F = script$4F;
+var __vue_render__$4F = function () {
var _vm = this;
var _h = _vm.$createElement;
var _c = _vm._self._c || _h;
@@ -77840,17 +78275,17 @@ var __vue_render__$4y = function () {
]
)
};
-var __vue_staticRenderFns__$4y = [];
-__vue_render__$4y._withStripped = true;
+var __vue_staticRenderFns__$4F = [];
+__vue_render__$4F._withStripped = true;
/* style */
- const __vue_inject_styles__$4y = undefined;
+ const __vue_inject_styles__$4F = undefined;
/* scoped */
- const __vue_scope_id__$4y = undefined;
+ const __vue_scope_id__$4F = undefined;
/* module identifier */
- const __vue_module_identifier__$4y = undefined;
+ const __vue_module_identifier__$4F = undefined;
/* functional template */
- const __vue_is_functional_template__$4y = false;
+ const __vue_is_functional_template__$4F = false;
/* style inject */
/* style inject SSR */
@@ -77859,13 +78294,13 @@ __vue_render__$4y._withStripped = true;
- const __vue_component__$4y = /*#__PURE__*/normalizeComponent(
- { render: __vue_render__$4y, staticRenderFns: __vue_staticRenderFns__$4y },
- __vue_inject_styles__$4y,
- __vue_script__$4y,
- __vue_scope_id__$4y,
- __vue_is_functional_template__$4y,
- __vue_module_identifier__$4y,
+ const __vue_component__$4F = /*#__PURE__*/normalizeComponent(
+ { render: __vue_render__$4F, staticRenderFns: __vue_staticRenderFns__$4F },
+ __vue_inject_styles__$4F,
+ __vue_script__$4F,
+ __vue_scope_id__$4F,
+ __vue_is_functional_template__$4F,
+ __vue_module_identifier__$4F,
false,
undefined,
undefined,
@@ -77873,10 +78308,10 @@ __vue_render__$4y._withStripped = true;
);
//
-var script$4x = {
+var script$4E = {
name: 'XmlEbookRender',
components: {
- PdfView: __vue_component__$4y
+ PdfView: __vue_component__$4F
},
props: {
//模式:preview 预览 (默认),editor 编辑
@@ -77996,8 +78431,8 @@ var script$4x = {
var __$_require_static_images_default_over_ebook_png__ = "2539d578aeabf7c9.png";
/* script */
-const __vue_script__$4x = script$4x;
-var __vue_render__$4x = function () {
+const __vue_script__$4E = script$4E;
+var __vue_render__$4E = function () {
var _vm = this;
var _h = _vm.$createElement;
var _c = _vm._self._c || _h;
@@ -78280,17 +78715,17 @@ var __vue_render__$4x = function () {
1
)
};
-var __vue_staticRenderFns__$4x = [];
-__vue_render__$4x._withStripped = true;
+var __vue_staticRenderFns__$4E = [];
+__vue_render__$4E._withStripped = true;
/* style */
- const __vue_inject_styles__$4x = undefined;
+ const __vue_inject_styles__$4E = undefined;
/* scoped */
- const __vue_scope_id__$4x = "data-v-7ea50222";
+ const __vue_scope_id__$4E = "data-v-7ea50222";
/* module identifier */
- const __vue_module_identifier__$4x = undefined;
+ const __vue_module_identifier__$4E = undefined;
/* functional template */
- const __vue_is_functional_template__$4x = false;
+ const __vue_is_functional_template__$4E = false;
/* style inject */
/* style inject SSR */
@@ -78299,23 +78734,23 @@ __vue_render__$4x._withStripped = true;
- const __vue_component__$4x = /*#__PURE__*/normalizeComponent(
- { render: __vue_render__$4x, staticRenderFns: __vue_staticRenderFns__$4x },
- __vue_inject_styles__$4x,
- __vue_script__$4x,
- __vue_scope_id__$4x,
- __vue_is_functional_template__$4x,
- __vue_module_identifier__$4x,
+ const __vue_component__$4E = /*#__PURE__*/normalizeComponent(
+ { render: __vue_render__$4E, staticRenderFns: __vue_staticRenderFns__$4E },
+ __vue_inject_styles__$4E,
+ __vue_script__$4E,
+ __vue_scope_id__$4E,
+ __vue_is_functional_template__$4E,
+ __vue_module_identifier__$4E,
false,
undefined,
undefined,
undefined
);
-__vue_component__$4x.install = (Vue, options = {}) => {
+__vue_component__$4E.install = (Vue, options = {}) => {
Vue.component(createNamespace$1('ebook-render', {
prefix: options.prefix
- }), __vue_component__$4x);
+ }), __vue_component__$4E);
};
//
@@ -78345,7 +78780,7 @@ __vue_component__$4x.install = (Vue, options = {}) => {
//
// import { Player, Video, Ui, ClickToPlay, Skeleton, Controls, ScrubberControl } from '@vime/vue'
-var script$4w = {
+var script$4D = {
name: 'VmPlayer',
// components: { Player, Video, Ui, ClickToPlay, Skeleton, Controls, ScrubberControl },
props: {
@@ -78387,10 +78822,10 @@ var script$4w = {
};
/* script */
-const __vue_script__$4w = script$4w;
+const __vue_script__$4D = script$4D;
/* template */
-var __vue_render__$4w = function () {
+var __vue_render__$4D = function () {
var _vm = this;
var _h = _vm.$createElement;
var _c = _vm._self._c || _h;
@@ -78436,17 +78871,17 @@ var __vue_render__$4w = function () {
1
)
};
-var __vue_staticRenderFns__$4w = [];
-__vue_render__$4w._withStripped = true;
+var __vue_staticRenderFns__$4D = [];
+__vue_render__$4D._withStripped = true;
/* style */
- const __vue_inject_styles__$4w = undefined;
+ const __vue_inject_styles__$4D = undefined;
/* scoped */
- const __vue_scope_id__$4w = undefined;
+ const __vue_scope_id__$4D = undefined;
/* module identifier */
- const __vue_module_identifier__$4w = undefined;
+ const __vue_module_identifier__$4D = undefined;
/* functional template */
- const __vue_is_functional_template__$4w = false;
+ const __vue_is_functional_template__$4D = false;
/* style inject */
/* style inject SSR */
@@ -78455,13 +78890,13 @@ __vue_render__$4w._withStripped = true;
- const __vue_component__$4w = /*#__PURE__*/normalizeComponent(
- { render: __vue_render__$4w, staticRenderFns: __vue_staticRenderFns__$4w },
- __vue_inject_styles__$4w,
- __vue_script__$4w,
- __vue_scope_id__$4w,
- __vue_is_functional_template__$4w,
- __vue_module_identifier__$4w,
+ const __vue_component__$4D = /*#__PURE__*/normalizeComponent(
+ { render: __vue_render__$4D, staticRenderFns: __vue_staticRenderFns__$4D },
+ __vue_inject_styles__$4D,
+ __vue_script__$4D,
+ __vue_scope_id__$4D,
+ __vue_is_functional_template__$4D,
+ __vue_module_identifier__$4D,
false,
undefined,
undefined,
@@ -78469,10 +78904,10 @@ __vue_render__$4w._withStripped = true;
);
//
-var script$4v = {
+var script$4C = {
name: 'VideoPlayer',
components: {
- VmPlayer: __vue_component__$4w,
+ VmPlayer: __vue_component__$4D,
videoPlayer: VueVideoPlayer.videoPlayer
},
props: {
@@ -78967,10 +79402,10 @@ var script$4v = {
};
/* script */
-const __vue_script__$4v = script$4v;
+const __vue_script__$4C = script$4C;
/* template */
-var __vue_render__$4v = function () {
+var __vue_render__$4C = function () {
var _vm = this;
var _h = _vm.$createElement;
var _c = _vm._self._c || _h;
@@ -79077,7 +79512,7 @@ var __vue_render__$4v = function () {
2
)
};
-var __vue_staticRenderFns__$4v = [
+var __vue_staticRenderFns__$4C = [
function () {
var _vm = this;
var _h = _vm.$createElement;
@@ -79089,16 +79524,16 @@ var __vue_staticRenderFns__$4v = [
])
},
];
-__vue_render__$4v._withStripped = true;
+__vue_render__$4C._withStripped = true;
/* style */
- const __vue_inject_styles__$4v = undefined;
+ const __vue_inject_styles__$4C = undefined;
/* scoped */
- const __vue_scope_id__$4v = undefined;
+ const __vue_scope_id__$4C = undefined;
/* module identifier */
- const __vue_module_identifier__$4v = undefined;
+ const __vue_module_identifier__$4C = undefined;
/* functional template */
- const __vue_is_functional_template__$4v = false;
+ const __vue_is_functional_template__$4C = false;
/* style inject */
/* style inject SSR */
@@ -79107,27 +79542,27 @@ __vue_render__$4v._withStripped = true;
- const __vue_component__$4v = /*#__PURE__*/normalizeComponent(
- { render: __vue_render__$4v, staticRenderFns: __vue_staticRenderFns__$4v },
- __vue_inject_styles__$4v,
- __vue_script__$4v,
- __vue_scope_id__$4v,
- __vue_is_functional_template__$4v,
- __vue_module_identifier__$4v,
+ const __vue_component__$4C = /*#__PURE__*/normalizeComponent(
+ { render: __vue_render__$4C, staticRenderFns: __vue_staticRenderFns__$4C },
+ __vue_inject_styles__$4C,
+ __vue_script__$4C,
+ __vue_scope_id__$4C,
+ __vue_is_functional_template__$4C,
+ __vue_module_identifier__$4C,
false,
undefined,
undefined,
undefined
);
-var playIcon$2 = "";
+var playIcon$3 = "";
var titleLeftIcon = "";
var titleRightIcon = "";
//
-var script$4u = {
+var script$4B = {
name: 'VideoModalPlayer',
components: {
videoPlayer: VueVideoPlayer.videoPlayer
@@ -79184,7 +79619,7 @@ var script$4u = {
},
data() {
return {
- playIcon: playIcon$2,
+ playIcon: playIcon$3,
titleLeftIcon,
titleRightIcon,
// 用于存放