diff --git a/.gitignore b/.gitignore
index 8d516a52b8..4ca1138b25 100644
--- a/.gitignore
+++ b/.gitignore
@@ -2,5 +2,4 @@
.ruff_cache
.vscode
*.a
-.DS_Store
-*.raw
\ No newline at end of file
+.DS_Store
\ No newline at end of file
diff --git a/.typos.toml b/.typos.toml
index 113110966a..24be17b111 100644
--- a/.typos.toml
+++ b/.typos.toml
@@ -12,5 +12,6 @@ extend-ignore-identifiers-re = [
[files]
extend-exclude = [
"mistralrs-pyo3/pdoc/*",
- "examples/server/phi3_duckduckgo_mistral.rs.ipynb"
+ "examples/server/phi3_duckduckgo_mistral.rs.ipynb",
+ "calibration_data/*"
]
\ No newline at end of file
diff --git a/Cargo.lock b/Cargo.lock
index be6010d9e8..368281fbae 100644
--- a/Cargo.lock
+++ b/Cargo.lock
@@ -27,12 +27,6 @@ dependencies = [
"gimli",
]
-[[package]]
-name = "adler"
-version = "1.0.2"
-source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "f26201604c87b1e01bd3d98f8d5d9a8fcbb815e8cedb41ffccbeb4bf593a35fe"
-
[[package]]
name = "adler2"
version = "2.0.0"
@@ -46,7 +40,9 @@ source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "e89da841a80418a9b391ebaea17f5c112ffaaa96f621d2c285b5174da76b9011"
dependencies = [
"cfg-if",
+ "getrandom",
"once_cell",
+ "serde",
"version_check",
"zerocopy",
]
@@ -68,9 +64,9 @@ checksum = "1763692fc1416554cf051efc56a3de5595eca47299d731cc5c2b583adf8b4d2f"
[[package]]
name = "allocator-api2"
-version = "0.2.18"
+version = "0.2.21"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "5c6cb57a04249c6480766f7f7cef5467412af1490f8d1e243141daddada3264f"
+checksum = "683d7910e743518b0e34f1186f92494becacb047c7b6bf616c96772180fef923"
[[package]]
name = "android-tzdata"
@@ -89,9 +85,9 @@ dependencies = [
[[package]]
name = "anstream"
-version = "0.6.17"
+version = "0.6.18"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "23a1e53f0f5d86382dafe1cf314783b2044280f406e7e1506368220ad11b1338"
+checksum = "8acc5369981196006228e28809f761875c0327210a891e941f4c683b3a99529b"
dependencies = [
"anstyle",
"anstyle-parse",
@@ -104,9 +100,9 @@ dependencies = [
[[package]]
name = "anstyle"
-version = "1.0.9"
+version = "1.0.10"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "8365de52b16c035ff4fcafe0092ba9390540e3e352870ac09933bebcaa2c8c56"
+checksum = "55cc3b69f167a1ef2e161439aa98aed94e6028e5f9a59be9a6ffb47aef1651f9"
[[package]]
name = "anstyle-parse"
@@ -138,18 +134,18 @@ dependencies = [
[[package]]
name = "anyhow"
-version = "1.0.91"
+version = "1.0.94"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "c042108f3ed77fd83760a5fd79b53be043192bb3b9dba91d8c574c0ada7850c8"
+checksum = "c1fd03a028ef38ba2276dce7e33fcd6369c158a1bca17946c4b1b701891c1ff7"
dependencies = [
"backtrace",
]
[[package]]
name = "arbitrary"
-version = "1.3.2"
+version = "1.4.1"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "7d5a26814d8dcb93b0e5a0ff3c6d80a8843bafb21b39e8e18a6f05471870e110"
+checksum = "dde20b3d026af13f561bdd0f15edf01fc734f0dafcedbaf42bba506a9517f223"
dependencies = [
"derive_arbitrary",
]
@@ -174,7 +170,7 @@ checksum = "721cae7de5c34fbb2acd27e21e6d2cf7b886dce0c27388d46c4e6c47ea4318dd"
dependencies = [
"proc-macro2",
"quote",
- "syn 2.0.85",
+ "syn 2.0.90",
]
[[package]]
@@ -191,9 +187,9 @@ checksum = "ace50bade8e6234aa140d9a2f552bbee1db4d353f69b8217bc503490fc1a9f26"
[[package]]
name = "axum"
-version = "0.7.7"
+version = "0.7.9"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "504e3947307ac8326a5437504c517c4b56716c9d98fac0028c2acc7ca47d70ae"
+checksum = "edca88bc138befd0323b20752846e6587272d3b03b0343c8ea28a6f819e6e71f"
dependencies = [
"async-trait",
"axum-core",
@@ -215,7 +211,7 @@ dependencies = [
"serde_json",
"serde_path_to_error",
"serde_urlencoded",
- "sync_wrapper 1.0.1",
+ "sync_wrapper 1.0.2",
"tokio",
"tower",
"tower-layer",
@@ -238,7 +234,7 @@ dependencies = [
"mime",
"pin-project-lite",
"rustversion",
- "sync_wrapper 1.0.1",
+ "sync_wrapper 1.0.2",
"tower-layer",
"tower-service",
"tracing",
@@ -253,7 +249,7 @@ dependencies = [
"addr2line",
"cfg-if",
"libc",
- "miniz_oxide 0.8.0",
+ "miniz_oxide",
"object",
"rustc-demangle",
"windows-targets 0.52.6",
@@ -331,6 +327,12 @@ dependencies = [
"generic-array",
]
+[[package]]
+name = "borrow-or-share"
+version = "0.2.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "3eeab4423108c5d7c744f4d234de88d18d636100093ae04caf4825134b9c3a32"
+
[[package]]
name = "buildstructor"
version = "0.5.4"
@@ -341,8 +343,8 @@ dependencies = [
"proc-macro2",
"quote",
"str_inflector",
- "syn 2.0.85",
- "thiserror",
+ "syn 2.0.90",
+ "thiserror 1.0.69",
"try_match",
]
@@ -354,9 +356,9 @@ checksum = "79296716171880943b8470b5f8d03aa55eb2e645a4874bdbb28adb49162e012c"
[[package]]
name = "bytemuck"
-version = "1.19.0"
+version = "1.20.0"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "8334215b81e418a0a7bdb8ef0849474f40bb10c8b71f1c4ed315cff49f32494d"
+checksum = "8b37c88a63ffd85d15b406896cc343916d7cf57838a847b3a6f2ca5d39a5695a"
dependencies = [
"bytemuck_derive",
]
@@ -369,7 +371,7 @@ checksum = "bcfcc3cd946cb52f0bbfdbbcfa2f4e24f75ebb6c0e1002f7c25904fada18b9ec"
dependencies = [
"proc-macro2",
"quote",
- "syn 2.0.85",
+ "syn 2.0.90",
]
[[package]]
@@ -386,14 +388,14 @@ checksum = "8f1fe948ff07f4bd06c30984e69f5b4899c516a3ef74f34df92a2df2ab535495"
[[package]]
name = "bytes"
-version = "1.8.0"
+version = "1.9.0"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "9ac0150caa2ae65ca5bd83f25c7de183dea78d4d366469f148435e2acfbad0da"
+checksum = "325918d6fe32f23b19878fe4b34794ae41fc19ddbe53b10571a4874d44ffd39b"
[[package]]
name = "candle-core"
version = "0.8.0"
-source = "git+https://github.com/EricLBuehler/candle.git?rev=8742354#87423548e70b471d7c4a760bc16e3aa9e814f56d"
+source = "git+https://github.com/EricLBuehler/candle.git?rev=6800496#6800496261a240aa969fdc47cc9814d7914f0862"
dependencies = [
"accelerate-src",
"byteorder",
@@ -413,7 +415,7 @@ dependencies = [
"rand_distr",
"rayon",
"safetensors",
- "thiserror",
+ "thiserror 1.0.69",
"ug",
"ug-cuda",
"ug-metal",
@@ -424,7 +426,7 @@ dependencies = [
[[package]]
name = "candle-flash-attn"
version = "0.8.0"
-source = "git+https://github.com/EricLBuehler/candle.git?rev=8742354#87423548e70b471d7c4a760bc16e3aa9e814f56d"
+source = "git+https://github.com/EricLBuehler/candle.git?rev=6800496#6800496261a240aa969fdc47cc9814d7914f0862"
dependencies = [
"anyhow",
"bindgen_cuda 0.1.5",
@@ -448,7 +450,7 @@ dependencies = [
"reqwest",
"serde",
"serde_json",
- "thiserror",
+ "thiserror 1.0.69",
"tokio",
"ureq",
]
@@ -456,7 +458,7 @@ dependencies = [
[[package]]
name = "candle-kernels"
version = "0.8.0"
-source = "git+https://github.com/EricLBuehler/candle.git?rev=8742354#87423548e70b471d7c4a760bc16e3aa9e814f56d"
+source = "git+https://github.com/EricLBuehler/candle.git?rev=6800496#6800496261a240aa969fdc47cc9814d7914f0862"
dependencies = [
"bindgen_cuda 0.1.5",
]
@@ -464,18 +466,18 @@ dependencies = [
[[package]]
name = "candle-metal-kernels"
version = "0.8.0"
-source = "git+https://github.com/EricLBuehler/candle.git?rev=8742354#87423548e70b471d7c4a760bc16e3aa9e814f56d"
+source = "git+https://github.com/EricLBuehler/candle.git?rev=6800496#6800496261a240aa969fdc47cc9814d7914f0862"
dependencies = [
"metal 0.27.0",
"once_cell",
- "thiserror",
+ "thiserror 1.0.69",
"tracing",
]
[[package]]
name = "candle-nn"
version = "0.8.0"
-source = "git+https://github.com/EricLBuehler/candle.git?rev=8742354#87423548e70b471d7c4a760bc16e3aa9e814f56d"
+source = "git+https://github.com/EricLBuehler/candle.git?rev=6800496#6800496261a240aa969fdc47cc9814d7914f0862"
dependencies = [
"accelerate-src",
"candle-core",
@@ -487,14 +489,33 @@ dependencies = [
"rayon",
"safetensors",
"serde",
- "thiserror",
+ "thiserror 1.0.69",
+]
+
+[[package]]
+name = "cbindgen"
+version = "0.27.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "3fce8dd7fcfcbf3a0a87d8f515194b49d6135acab73e18bd380d1d93bb1a15eb"
+dependencies = [
+ "clap",
+ "heck 0.4.1",
+ "indexmap",
+ "log",
+ "proc-macro2",
+ "quote",
+ "serde",
+ "serde_json",
+ "syn 2.0.90",
+ "tempfile",
+ "toml",
]
[[package]]
name = "cc"
-version = "1.1.31"
+version = "1.2.2"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "c2e7962b54006dcfcc61cb72735f4d89bb97061dd6a7ed882ec6b8ee53714c6f"
+checksum = "f34d93e62b03caf570cccc334cbc6c2fceca82f39211051345108adcba3eebdc"
dependencies = [
"shlex",
]
@@ -513,9 +534,9 @@ checksum = "613afe47fcd5fac7ccf1db93babcb082c5994d996f20b8b159f2ad1658eb5724"
[[package]]
name = "cfgrammar"
-version = "0.13.7"
+version = "0.13.8"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "6026d8cd82ada8bbcfe337805dd1eb6afdc9e80fa4d57e977b3a36315e0c5525"
+checksum = "6d621f687a04efa1f269f1cd13d8cfea9660852bdb3d1cd2c3c9fb6fdd34daf2"
dependencies = [
"indexmap",
"lazy_static",
@@ -563,9 +584,9 @@ dependencies = [
[[package]]
name = "clap"
-version = "4.5.20"
+version = "4.5.23"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "b97f376d85a664d5837dbae44bf546e6477a679ff6610010f17276f686d867e8"
+checksum = "3135e7ec2ef7b10c6ed8950f0f792ed96ee093fa088608f1c76e569722700c84"
dependencies = [
"clap_builder",
"clap_derive",
@@ -573,9 +594,9 @@ dependencies = [
[[package]]
name = "clap_builder"
-version = "4.5.20"
+version = "4.5.23"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "19bc80abd44e4bed93ca373a0704ccbd1b710dc5749406201bb018272808dc54"
+checksum = "30582fc632330df2bd26877bde0c1f4470d57c582bbc070376afcd04d8cb4838"
dependencies = [
"anstream",
"anstyle",
@@ -590,17 +611,17 @@ version = "4.5.18"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "4ac6a0c7b1a9e9a5186361f67dfa1b88213572f427fb9ab038efb2bd8c582dab"
dependencies = [
- "heck",
+ "heck 0.5.0",
"proc-macro2",
"quote",
- "syn 2.0.85",
+ "syn 2.0.90",
]
[[package]]
name = "clap_lex"
-version = "0.7.2"
+version = "0.7.4"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "1462739cb27611015575c0c11df5df7601141071f07518d56fcc1be504cbec97"
+checksum = "f46ad14479a25103f283c0f10005961cf086d8dc42205bb44c46ac563475dca6"
[[package]]
name = "cli-table"
@@ -611,7 +632,7 @@ dependencies = [
"cli-table-derive",
"csv",
"termcolor",
- "unicode-width",
+ "unicode-width 0.1.14",
]
[[package]]
@@ -646,7 +667,7 @@ dependencies = [
"encode_unicode",
"lazy_static",
"libc",
- "unicode-width",
+ "unicode-width 0.1.14",
"windows-sys 0.52.0",
]
@@ -679,9 +700,9 @@ dependencies = [
[[package]]
name = "cpufeatures"
-version = "0.2.14"
+version = "0.2.16"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "608697df725056feaccfa42cffdaeeec3fccc4ffc38358ecd19b243e716a78e0"
+checksum = "16b80225097f2e5ae4e7179dd2266824648f3e2f49d9134d584b76389d31c4c3"
dependencies = [
"libc",
]
@@ -763,9 +784,9 @@ dependencies = [
[[package]]
name = "csv"
-version = "1.3.0"
+version = "1.3.1"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "ac574ff4d437a7b5ad237ef331c17ccca63c46479e5b5453eb8e10bb99a759fe"
+checksum = "acdc4883a9c96732e4733212c01447ebd805833b7275a73ca3ee080fd77afdaf"
dependencies = [
"csv-core",
"itoa",
@@ -847,7 +868,7 @@ dependencies = [
"proc-macro2",
"quote",
"strsim 0.11.1",
- "syn 2.0.85",
+ "syn 2.0.90",
]
[[package]]
@@ -869,7 +890,7 @@ checksum = "d336a2a514f6ccccaa3e09b02d41d35330c07ddf03a62165fcec10bb561c7806"
dependencies = [
"darling_core 0.20.10",
"quote",
- "syn 2.0.85",
+ "syn 2.0.90",
]
[[package]]
@@ -892,18 +913,18 @@ checksum = "2cdc8d50f426189eef89dac62fabfa0abb27d5cc008f25bf4156a0203325becc"
dependencies = [
"proc-macro2",
"quote",
- "syn 2.0.85",
+ "syn 2.0.90",
]
[[package]]
name = "derive_arbitrary"
-version = "1.3.2"
+version = "1.4.1"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "67e77553c4162a157adbf834ebae5b415acbecbeafc7a74b0e886657506a7611"
+checksum = "30542c1ad912e0e3d22a1935c290e12e8a29d704a420177a31faad4a601a0800"
dependencies = [
"proc-macro2",
"quote",
- "syn 2.0.85",
+ "syn 2.0.90",
]
[[package]]
@@ -924,7 +945,7 @@ dependencies = [
"darling 0.20.10",
"proc-macro2",
"quote",
- "syn 2.0.85",
+ "syn 2.0.90",
]
[[package]]
@@ -934,7 +955,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "ab63b0e2bf4d5928aff72e83a7dace85d7bba5fe12dcc3c5a572d78caffd3f3c"
dependencies = [
"derive_builder_core",
- "syn 2.0.85",
+ "syn 2.0.90",
]
[[package]]
@@ -945,7 +966,20 @@ checksum = "5f33878137e4dafd7fa914ad4e259e18a4e8e532b9617a2d0150262bf53abfce"
dependencies = [
"proc-macro2",
"quote",
- "syn 2.0.85",
+ "syn 2.0.90",
+]
+
+[[package]]
+name = "derivre"
+version = "0.1.0"
+source = "git+https://github.com/microsoft/derivre?rev=02ee497e6e404a0b402b4f68a9abf599d22ed2ed#02ee497e6e404a0b402b4f68a9abf599d22ed2ed"
+dependencies = [
+ "ahash",
+ "anyhow",
+ "bytemuck",
+ "bytemuck_derive",
+ "hashbrown 0.14.5",
+ "regex-syntax 0.8.5",
]
[[package]]
@@ -996,7 +1030,7 @@ checksum = "97369cbbc041bc366949bc74d34658d6cda5621039731c6310521892a3a20ae0"
dependencies = [
"proc-macro2",
"quote",
- "syn 2.0.85",
+ "syn 2.0.90",
]
[[package]]
@@ -1051,10 +1085,10 @@ version = "0.6.1"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "a1e6a265c649f3f5979b601d26f1d05ada116434c87741c9493cb56218f76cbc"
dependencies = [
- "heck",
+ "heck 0.5.0",
"proc-macro2",
"quote",
- "syn 2.0.85",
+ "syn 2.0.90",
]
[[package]]
@@ -1065,12 +1099,12 @@ checksum = "5443807d6dff69373d433ab9ef5378ad8df50ca6298caf15de6e52e24aaf54d5"
[[package]]
name = "errno"
-version = "0.3.9"
+version = "0.3.10"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "534c5cf6194dfab3db3242765c03bbe257cf92f22b38f6bc0c58d59108a820ba"
+checksum = "33d852cb9b869c2a9b3df2f71a3074817f01e1844f839a144f5fcef059a4eb5d"
dependencies = [
"libc",
- "windows-sys 0.52.0",
+ "windows-sys 0.59.0",
]
[[package]]
@@ -1084,15 +1118,14 @@ dependencies = [
[[package]]
name = "exr"
-version = "1.72.0"
+version = "1.73.0"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "887d93f60543e9a9362ef8a21beedd0a833c5d9610e18c67abe15a5963dcb1a4"
+checksum = "f83197f59927b46c04a183a619b7c29df34e63e63c7869320862268c0ef687e0"
dependencies = [
"bit_field",
- "flume",
"half",
"lebe",
- "miniz_oxide 0.7.4",
+ "miniz_oxide",
"rayon-core",
"smallvec",
"zune-inflate",
@@ -1110,15 +1143,15 @@ dependencies = [
[[package]]
name = "fastrand"
-version = "2.1.1"
+version = "2.2.0"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "e8c02a5121d4ea3eb16a80748c74f5549a5665e4c21333c6098f283870fbdea6"
+checksum = "486f806e73c5707928240ddc295403b1b93c96a02038563881c4a2fd84b81ac4"
[[package]]
name = "fdeflate"
-version = "0.3.5"
+version = "0.3.7"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "d8090f921a24b04994d9929e204f50b498a33ea6ba559ffaa05e04f7ee7fb5ab"
+checksum = "1e6853b52649d4ac5c0bd02320cddc5ba956bdb407c4b75a2c6b75bf51500f8c"
dependencies = [
"simd-adler32",
]
@@ -1137,12 +1170,12 @@ dependencies = [
[[package]]
name = "flate2"
-version = "1.0.34"
+version = "1.0.35"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "a1b589b4dc103969ad3cf85c950899926ec64300a1a46d76c03a6072957036f0"
+checksum = "c936bfdafb507ebbf50b8074c54fa31c5be9a1e7e5f467dd659697041407d07c"
dependencies = [
"crc32fast",
- "miniz_oxide 0.8.0",
+ "miniz_oxide",
]
[[package]]
@@ -1159,12 +1192,14 @@ dependencies = [
]
[[package]]
-name = "flume"
-version = "0.11.1"
+name = "fluent-uri"
+version = "0.3.2"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "da0e4dd2a88388a1f4ccc7c9ce104604dab68d9f408dc34cd45823d5a9069095"
+checksum = "1918b65d96df47d3591bed19c5cca17e3fa5d0707318e4b5ef2eae01764df7e5"
dependencies = [
- "spin",
+ "borrow-or-share",
+ "ref-cast",
+ "serde",
]
[[package]]
@@ -1200,7 +1235,7 @@ checksum = "1a5c6c585bc94aaf2c7b51dd4c2ba22680844aba4c687be581871a6f518c5742"
dependencies = [
"proc-macro2",
"quote",
- "syn 2.0.85",
+ "syn 2.0.90",
]
[[package]]
@@ -1280,7 +1315,7 @@ checksum = "162ee34ebcb7c64a8abebc059ce0fee27c2262618d7b60ed8faf72fef13c3650"
dependencies = [
"proc-macro2",
"quote",
- "syn 2.0.85",
+ "syn 2.0.90",
]
[[package]]
@@ -1458,8 +1493,10 @@ source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "c4567c8db10ae91089c99af84c68c38da3ec2f087c3f82960bcdbf3656b6f4d7"
dependencies = [
"cfg-if",
+ "js-sys",
"libc",
"wasi",
+ "wasm-bindgen",
]
[[package]]
@@ -1471,7 +1508,7 @@ dependencies = [
"proc-macro-error2",
"proc-macro2",
"quote",
- "syn 2.0.85",
+ "syn 2.0.90",
]
[[package]]
@@ -1498,9 +1535,9 @@ checksum = "d2fabcfbdc87f4758337ca535fb41a6d701b65693ce38287d856d1674551ec9b"
[[package]]
name = "h2"
-version = "0.4.6"
+version = "0.4.7"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "524e8ac6999421f49a846c2d4411f337e53497d8ec55d67753beffa43c5d9205"
+checksum = "ccae279728d634d083c00f6099cb58f01cc99c145b84b8be2f6c74618d79922e"
dependencies = [
"atomic-waker",
"bytes",
@@ -1541,9 +1578,15 @@ dependencies = [
[[package]]
name = "hashbrown"
-version = "0.15.0"
+version = "0.15.2"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "1e087f84d4f86bf4b218b927129862374b72199ae7d8657835f1e89000eea4fb"
+checksum = "bf151400ff0baff5465007dd2f3e717f3fe502074ca563069ce3a6629d07b289"
+
+[[package]]
+name = "heck"
+version = "0.4.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "95505c38b4572b2d910cecb0281560f54b440a19336cbbcb27bf6ce6adc6f5a8"
[[package]]
name = "heck"
@@ -1557,11 +1600,28 @@ version = "0.3.9"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "d231dfb89cfffdbc30e7fc41579ed6066ad03abda9e567ccafae602b97ec5024"
+[[package]]
+name = "hf-hub"
+version = "0.3.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "2b780635574b3d92f036890d8373433d6f9fc7abb320ee42a5c25897fc8ed732"
+dependencies = [
+ "dirs",
+ "indicatif",
+ "log",
+ "native-tls",
+ "rand",
+ "serde",
+ "serde_json",
+ "thiserror 1.0.69",
+ "ureq",
+]
+
[[package]]
name = "http"
-version = "1.1.0"
+version = "1.2.0"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "21b9ddb458710bc376481b842f5da65cdf31522de232c1ca8146abce2a358258"
+checksum = "f16ca2af56261c99fba8bac40a10251ce8188205a4c448fbb745a2e4daa76fea"
dependencies = [
"bytes",
"fnv",
@@ -1605,9 +1665,9 @@ checksum = "df3b46402a9d5adb4c86a0cf463f42e19994e3ee891101b1841f30a545cb49a9"
[[package]]
name = "hyper"
-version = "1.5.0"
+version = "1.5.1"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "bbbff0a806a4728c99295b254c8838933b5b082d75e3cb70c8dab21fdfbcfa9a"
+checksum = "97818827ef4f364230e16705d4706e2897df2bb60617d6ca15d598025a3c481f"
dependencies = [
"bytes",
"futures-channel",
@@ -1660,9 +1720,9 @@ dependencies = [
[[package]]
name = "hyper-util"
-version = "0.1.9"
+version = "0.1.10"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "41296eb09f183ac68eec06e03cdbea2e759633d4067b2f6552fc2e009bcad08b"
+checksum = "df2dcfbe0677734ab2f3ffa7fa7bfd4706bfdc1ef393f2ee30184aed67e631b4"
dependencies = [
"bytes",
"futures-channel",
@@ -1700,6 +1760,124 @@ dependencies = [
"cc",
]
+[[package]]
+name = "icu_collections"
+version = "1.5.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "db2fa452206ebee18c4b5c2274dbf1de17008e874b4dc4f0aea9d01ca79e4526"
+dependencies = [
+ "displaydoc",
+ "yoke",
+ "zerofrom",
+ "zerovec",
+]
+
+[[package]]
+name = "icu_locid"
+version = "1.5.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "13acbb8371917fc971be86fc8057c41a64b521c184808a698c02acc242dbf637"
+dependencies = [
+ "displaydoc",
+ "litemap",
+ "tinystr",
+ "writeable",
+ "zerovec",
+]
+
+[[package]]
+name = "icu_locid_transform"
+version = "1.5.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "01d11ac35de8e40fdeda00d9e1e9d92525f3f9d887cdd7aa81d727596788b54e"
+dependencies = [
+ "displaydoc",
+ "icu_locid",
+ "icu_locid_transform_data",
+ "icu_provider",
+ "tinystr",
+ "zerovec",
+]
+
+[[package]]
+name = "icu_locid_transform_data"
+version = "1.5.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "fdc8ff3388f852bede6b579ad4e978ab004f139284d7b28715f773507b946f6e"
+
+[[package]]
+name = "icu_normalizer"
+version = "1.5.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "19ce3e0da2ec68599d193c93d088142efd7f9c5d6fc9b803774855747dc6a84f"
+dependencies = [
+ "displaydoc",
+ "icu_collections",
+ "icu_normalizer_data",
+ "icu_properties",
+ "icu_provider",
+ "smallvec",
+ "utf16_iter",
+ "utf8_iter",
+ "write16",
+ "zerovec",
+]
+
+[[package]]
+name = "icu_normalizer_data"
+version = "1.5.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "f8cafbf7aa791e9b22bec55a167906f9e1215fd475cd22adfcf660e03e989516"
+
+[[package]]
+name = "icu_properties"
+version = "1.5.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "93d6020766cfc6302c15dbbc9c8778c37e62c14427cb7f6e601d849e092aeef5"
+dependencies = [
+ "displaydoc",
+ "icu_collections",
+ "icu_locid_transform",
+ "icu_properties_data",
+ "icu_provider",
+ "tinystr",
+ "zerovec",
+]
+
+[[package]]
+name = "icu_properties_data"
+version = "1.5.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "67a8effbc3dd3e4ba1afa8ad918d5684b8868b3b26500753effea8d2eed19569"
+
+[[package]]
+name = "icu_provider"
+version = "1.5.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "6ed421c8a8ef78d3e2dbc98a973be2f3770cb42b606e3ab18d6237c4dfde68d9"
+dependencies = [
+ "displaydoc",
+ "icu_locid",
+ "icu_provider_macros",
+ "stable_deref_trait",
+ "tinystr",
+ "writeable",
+ "yoke",
+ "zerofrom",
+ "zerovec",
+]
+
+[[package]]
+name = "icu_provider_macros"
+version = "1.5.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "1ec89e9337638ecdc08744df490b221a7399bf8d164eb52a665454e60e075ad6"
+dependencies = [
+ "proc-macro2",
+ "quote",
+ "syn 2.0.90",
+]
+
[[package]]
name = "ident_case"
version = "1.0.1"
@@ -1708,19 +1886,30 @@ checksum = "b9e0384b61958566e926dc50660321d12159025e767c18e043daf26b70104c39"
[[package]]
name = "idna"
-version = "0.5.0"
+version = "1.0.3"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "686f825264d630750a544639377bae737628043f20d38bbc029e8f29ea968a7e"
+dependencies = [
+ "idna_adapter",
+ "smallvec",
+ "utf8_iter",
+]
+
+[[package]]
+name = "idna_adapter"
+version = "1.2.0"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "634d9b1461af396cad843f47fdba5597a4f9e6ddd4bfb6ff5d85028c25cb12f6"
+checksum = "daca1df1c957320b2cf139ac61e7bd64fed304c5040df000a745aa1de3b4ef71"
dependencies = [
- "unicode-bidi",
- "unicode-normalization",
+ "icu_normalizer",
+ "icu_properties",
]
[[package]]
name = "image"
-version = "0.25.4"
+version = "0.25.5"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "bc144d44a31d753b02ce64093d532f55ff8dc4ebf2ffb8a63c0dda691385acae"
+checksum = "cd6f44aed642f18953a158afeb30206f4d50da59fbc66ecb53c66488de73563b"
dependencies = [
"bytemuck",
"byteorder-lite",
@@ -1754,27 +1943,27 @@ checksum = "ce23b50ad8242c51a442f3ff322d56b02f08852c77e4c0b4d3fd684abc89c683"
[[package]]
name = "indexmap"
-version = "2.6.0"
+version = "2.7.0"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "707907fe3c25f5424cce2cb7e1cbcafee6bdbe735ca90ef77c29e84591e5b9da"
+checksum = "62f822373a4fe84d4bb149bf54e584a7f4abec90e072ed49cda0edea5b95471f"
dependencies = [
"equivalent",
- "hashbrown 0.15.0",
+ "hashbrown 0.15.2",
"serde",
]
[[package]]
name = "indicatif"
-version = "0.17.8"
+version = "0.17.9"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "763a5a8f45087d6bcea4222e7b72c291a054edf80e4ef6efd2a4979878c7bea3"
+checksum = "cbf675b85ed934d3c67b5c5469701eec7db22689d0a2139d856e0925fa28b281"
dependencies = [
"console",
- "instant",
"number_prefix",
"portable-atomic",
"rayon",
- "unicode-width",
+ "unicode-width 0.2.0",
+ "web-time",
]
[[package]]
@@ -1855,9 +2044,9 @@ dependencies = [
[[package]]
name = "itoa"
-version = "1.0.11"
+version = "1.0.14"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "49f1f14873335454500d59611f1cf4a4b0f786f9ac11f4312a78e4cf2566695b"
+checksum = "d75a2a4b1b190afb6f5425f10f6a8f959d2ea0b9c2b1d79553551850539e4674"
[[package]]
name = "jpeg-decoder"
@@ -1867,10 +2056,11 @@ checksum = "f5d4a7da358eff58addd2877a45865158f0d78c911d43a5784ceb7bbf52833b0"
[[package]]
name = "js-sys"
-version = "0.3.72"
+version = "0.3.74"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "6a88f1bda2bd75b0452a14784937d796722fdebfe50df998aeb3f0b7603019a9"
+checksum = "a865e038f7f6ed956f788f0d7d60c541fff74c7bd74272c5d4cf15c63743e705"
dependencies = [
+ "once_cell",
"wasm-bindgen",
]
@@ -1888,15 +2078,15 @@ checksum = "03087c2bad5e1034e8cace5926dec053fb3790248370865f5117a7d0213354c8"
[[package]]
name = "libc"
-version = "0.2.161"
+version = "0.2.167"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "8e9489c2807c139ffd9c1794f4af0ebe86a828db53ecdc7fea2111d0fed085d1"
+checksum = "09d6582e104315a817dff97f75133544b2e094ee22447d2acf4a74e189ba06fc"
[[package]]
name = "libloading"
-version = "0.8.5"
+version = "0.8.6"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "4979f22fdb869068da03c9f7528f8297c6fd2606bc3a4affe42e6a823fdb8da4"
+checksum = "fc2f4eb4bc735547cfed7c0a4922cbd04a4655978c09b54f1f7b228750664c34"
dependencies = [
"cfg-if",
"windows-targets 0.52.6",
@@ -1904,9 +2094,9 @@ dependencies = [
[[package]]
name = "libm"
-version = "0.2.8"
+version = "0.2.11"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "4ec2a862134d2a7d32d7983ddcdd1c4923530833c9f2ea1a44fc5fa473989058"
+checksum = "8355be11b20d696c8f18f6cc018c4e372165b1fa8126cef092399c9951984ffa"
[[package]]
name = "libredox"
@@ -1925,6 +2115,31 @@ version = "0.4.14"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "78b3ae25bc7c8c38cec158d1f2757ee79e9b3740fbc7ccf0e59e4b08d793fa89"
+[[package]]
+name = "litemap"
+version = "0.7.4"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "4ee93343901ab17bd981295f2cf0026d4ad018c7c31ba84549a4ddbb47a45104"
+
+[[package]]
+name = "llguidance"
+version = "0.4.1"
+source = "git+https://github.com/microsoft/llguidance?rev=cfef3df97372a7b84d74976ff41cc9cb78bca6cc#cfef3df97372a7b84d74976ff41cc9cb78bca6cc"
+dependencies = [
+ "anyhow",
+ "cbindgen",
+ "derivre",
+ "indexmap",
+ "instant",
+ "referencing",
+ "regex-syntax 0.8.5",
+ "rustc-hash",
+ "serde",
+ "serde_json",
+ "toktrie",
+ "url",
+]
+
[[package]]
name = "lock_api"
version = "0.4.12"
@@ -1943,9 +2158,9 @@ checksum = "a7a70ba024b9dc04c27ea2f0c0548feb474ec5c54bba33a7f72f873a39d07b24"
[[package]]
name = "lrtable"
-version = "0.13.7"
+version = "0.13.8"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "d42d2752cb50a171efadda0cb6fa97432e8bf05accfff3eed320b87e80a2f69e"
+checksum = "49e35162de3a5d91b380f8ebb31fc6c5e9a4618276465df4725ff1f88613312b"
dependencies = [
"cfgrammar",
"fnv",
@@ -2067,9 +2282,9 @@ dependencies = [
[[package]]
name = "minijinja"
-version = "2.4.0"
+version = "2.5.0"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "c9ca8daf4b0b4029777f1bc6e1aedd1aec7b74c276a43bc6f620a8e1a1c0a90e"
+checksum = "2c37e1b517d1dcd0e51dc36c4567b9d5a29262b3ec8da6cb5d35e27a8fb529b5"
dependencies = [
"serde",
"serde_json",
@@ -2077,9 +2292,9 @@ dependencies = [
[[package]]
name = "minijinja-contrib"
-version = "2.3.1"
+version = "2.5.0"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "39ffd46ee854be23604a20efd6c9655374fefbe4d44b949dc0f907305d92873a"
+checksum = "7fe51f1a6a8285f03fcd1544d834234fe8db285f29e1c2253600c93b3ae19242"
dependencies = [
"minijinja",
"serde",
@@ -2091,15 +2306,6 @@ version = "0.2.1"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "68354c5c6bd36d73ff3feceb05efa59b6acb7626617f4962be322a825e61f79a"
-[[package]]
-name = "miniz_oxide"
-version = "0.7.4"
-source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "b8a240ddb74feaf34a79a7add65a741f3167852fba007066dcac1ca548d89c08"
-dependencies = [
- "adler",
-]
-
[[package]]
name = "miniz_oxide"
version = "0.8.0"
@@ -2124,11 +2330,10 @@ dependencies = [
[[package]]
name = "mio"
-version = "1.0.2"
+version = "1.0.3"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "80e04d1dcff3aae0704555fe5fee3bcfaf3d1fdf8a7e521d5b9d2b42acb52cec"
+checksum = "2886843bf800fba2e3377cff24abf6379b4c4d5c6681eaf9ea5b0d15090450bd"
dependencies = [
- "hermit-abi",
"libc",
"wasi",
"windows-sys 0.52.0",
@@ -2204,6 +2409,7 @@ dependencies = [
"indicatif",
"intel-mkl-src",
"itertools 0.13.0",
+ "llguidance",
"lrtable",
"minijinja",
"minijinja-contrib",
@@ -2217,7 +2423,7 @@ dependencies = [
"rand_isaac",
"rayon",
"regex",
- "regex-automata 0.4.8",
+ "regex-automata 0.4.9",
"reqwest",
"rustc-hash",
"safetensors",
@@ -2228,10 +2434,11 @@ dependencies = [
"serde_yaml",
"strum",
"sysinfo",
- "thiserror",
+ "thiserror 1.0.69",
"tokenizers",
"tokio",
"tokio-rayon",
+ "toktrie_hf_tokenizers",
"toml",
"tqdm",
"tracing",
@@ -2292,7 +2499,8 @@ dependencies = [
"paste",
"rayon",
"serde",
- "thiserror",
+ "serde_json",
+ "thiserror 1.0.69",
"tracing",
]
@@ -2352,7 +2560,7 @@ checksum = "a7ce64b975ed4f123575d11afd9491f2e37bbd5813fbfbc0f09ae1fbddea74e0"
dependencies = [
"proc-macro2",
"quote",
- "syn 2.0.85",
+ "syn 2.0.90",
]
[[package]]
@@ -2525,7 +2733,7 @@ dependencies = [
"proc-macro-crate",
"proc-macro2",
"quote",
- "syn 2.0.85",
+ "syn 2.0.90",
]
[[package]]
@@ -2574,7 +2782,7 @@ dependencies = [
"serde_json",
"strum",
"strum_macros",
- "thiserror",
+ "thiserror 1.0.69",
]
[[package]]
@@ -2596,7 +2804,7 @@ dependencies = [
"serde_json",
"sha2",
"tar",
- "thiserror",
+ "thiserror 1.0.69",
"toml",
"ureq",
"url",
@@ -2655,7 +2863,7 @@ checksum = "a948666b637a0f465e8564c73e89d4dde00d72d4d473cc972f390fc3dcee7d9c"
dependencies = [
"proc-macro2",
"quote",
- "syn 2.0.85",
+ "syn 2.0.90",
]
[[package]]
@@ -2808,14 +3016,14 @@ dependencies = [
"crc32fast",
"fdeflate",
"flate2",
- "miniz_oxide 0.8.0",
+ "miniz_oxide",
]
[[package]]
name = "portable-atomic"
-version = "1.9.0"
+version = "1.10.0"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "cc9c68a3f6da06753e9335d63e27f6b9754dd1920d941135b7ea8224f141adb2"
+checksum = "280dc24453071f1b63954171985a0b0d30058d287960968b9b2aca264c8d4ee6"
[[package]]
name = "ppv-lite86"
@@ -2878,14 +3086,14 @@ dependencies = [
"proc-macro-error-attr2",
"proc-macro2",
"quote",
- "syn 2.0.85",
+ "syn 2.0.90",
]
[[package]]
name = "proc-macro2"
-version = "1.0.89"
+version = "1.0.92"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "f139b0662de085916d1fb67d2b4169d1addddda1919e696f3252b740b629986e"
+checksum = "37d3544b3f2748c54e147655edb5025752e2303145b5aefb3c3ea2c78b973bb0"
dependencies = [
"unicode-ident",
]
@@ -2904,9 +3112,9 @@ dependencies = [
[[package]]
name = "pyo3"
-version = "0.22.5"
+version = "0.22.6"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "3d922163ba1f79c04bc49073ba7b32fd5a8d3b76a87c955921234b8e77333c51"
+checksum = "f402062616ab18202ae8319da13fa4279883a2b8a9d9f83f20dbade813ce1884"
dependencies = [
"anyhow",
"cfg-if",
@@ -2935,9 +3143,9 @@ dependencies = [
[[package]]
name = "pyo3-build-config"
-version = "0.22.5"
+version = "0.22.6"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "bc38c5feeb496c8321091edf3d63e9a6829eab4b863b4a6a65f26f3e9cc6b179"
+checksum = "b14b5775b5ff446dd1056212d778012cbe8a0fbffd368029fd9e25b514479c38"
dependencies = [
"once_cell",
"target-lexicon",
@@ -2945,9 +3153,9 @@ dependencies = [
[[package]]
name = "pyo3-ffi"
-version = "0.22.5"
+version = "0.22.6"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "94845622d88ae274d2729fcefc850e63d7a3ddff5e3ce11bd88486db9f1d357d"
+checksum = "9ab5bcf04a2cdcbb50c7d6105de943f543f9ed92af55818fd17b660390fc8636"
dependencies = [
"libc",
"pyo3-build-config",
@@ -2955,27 +3163,27 @@ dependencies = [
[[package]]
name = "pyo3-macros"
-version = "0.22.5"
+version = "0.22.6"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "e655aad15e09b94ffdb3ce3d217acf652e26bbc37697ef012f5e5e348c716e5e"
+checksum = "0fd24d897903a9e6d80b968368a34e1525aeb719d568dba8b3d4bfa5dc67d453"
dependencies = [
"proc-macro2",
"pyo3-macros-backend",
"quote",
- "syn 2.0.85",
+ "syn 2.0.90",
]
[[package]]
name = "pyo3-macros-backend"
-version = "0.22.5"
+version = "0.22.6"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "ae1e3f09eecd94618f60a455a23def79f79eba4dc561a97324bf9ac8c6df30ce"
+checksum = "36c011a03ba1e50152b4b394b479826cad97e7a21eb52df179cd91ac411cbfbe"
dependencies = [
- "heck",
+ "heck 0.5.0",
"proc-macro2",
"pyo3-build-config",
"quote",
- "syn 2.0.85",
+ "syn 2.0.90",
]
[[package]]
@@ -2995,9 +3203,9 @@ checksum = "a993555f31e5a609f617c12db6250dedcac1b0a85076912c436e6fc9b2c8e6a3"
[[package]]
name = "quinn"
-version = "0.11.5"
+version = "0.11.6"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "8c7c5fdde3cdae7203427dc4f0a68fe0ed09833edc525a03456b153b79828684"
+checksum = "62e96808277ec6f97351a2380e6c25114bc9e67037775464979f3037c92d05ef"
dependencies = [
"bytes",
"pin-project-lite",
@@ -3006,34 +3214,38 @@ dependencies = [
"rustc-hash",
"rustls",
"socket2",
- "thiserror",
+ "thiserror 2.0.4",
"tokio",
"tracing",
]
[[package]]
name = "quinn-proto"
-version = "0.11.8"
+version = "0.11.9"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "fadfaed2cd7f389d0161bb73eeb07b7b78f8691047a6f3e73caaeae55310a4a6"
+checksum = "a2fe5ef3495d7d2e377ff17b1a8ce2ee2ec2a18cde8b6ad6619d65d0701c135d"
dependencies = [
"bytes",
+ "getrandom",
"rand",
"ring",
"rustc-hash",
"rustls",
+ "rustls-pki-types",
"slab",
- "thiserror",
+ "thiserror 2.0.4",
"tinyvec",
"tracing",
+ "web-time",
]
[[package]]
name = "quinn-udp"
-version = "0.5.5"
+version = "0.5.7"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "4fe68c2e9e1a1234e218683dbdf9f9dfcb094113c5ac2b938dfcb9bab4c4140b"
+checksum = "7d5a626c6807713b15cac82a6acaccd6043c9a5408c24baae07611fec3f243da"
dependencies = [
+ "cfg_aliases",
"libc",
"once_cell",
"socket2",
@@ -3172,7 +3384,40 @@ checksum = "ba009ff324d1fc1b900bd1fdb31564febe58a8ccc8a6fdbb93b543d33b13ca43"
dependencies = [
"getrandom",
"libredox",
- "thiserror",
+ "thiserror 1.0.69",
+]
+
+[[package]]
+name = "ref-cast"
+version = "1.0.23"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "ccf0a6f84d5f1d581da8b41b47ec8600871962f2a528115b542b362d4b744931"
+dependencies = [
+ "ref-cast-impl",
+]
+
+[[package]]
+name = "ref-cast-impl"
+version = "1.0.23"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "bcc303e793d3734489387d205e9b186fac9c6cfacedd98cbb2e8a5943595f3e6"
+dependencies = [
+ "proc-macro2",
+ "quote",
+ "syn 2.0.90",
+]
+
+[[package]]
+name = "referencing"
+version = "0.26.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "eb853437e467c693ac1dc8c1520105a31b8c2588544ff2f3cfa5a7c706c6c069"
+dependencies = [
+ "ahash",
+ "fluent-uri",
+ "once_cell",
+ "percent-encoding",
+ "serde_json",
]
[[package]]
@@ -3183,7 +3428,7 @@ checksum = "b544ef1b4eac5dc2db33ea63606ae9ffcfac26c1416a2806ae0bf5f56b201191"
dependencies = [
"aho-corasick",
"memchr",
- "regex-automata 0.4.8",
+ "regex-automata 0.4.9",
"regex-syntax 0.8.5",
]
@@ -3198,9 +3443,9 @@ dependencies = [
[[package]]
name = "regex-automata"
-version = "0.4.8"
+version = "0.4.9"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "368758f23274712b504848e9d5a6f010445cc8b87a7cdb4d7cbee666c1288da3"
+checksum = "809e8dc61f6de73b46c85f4c96486310fe304c434cfa43669d7b40f711150908"
dependencies = [
"aho-corasick",
"memchr",
@@ -3221,9 +3466,9 @@ checksum = "2b15c43186be67a4fd63bee50d0303afffcef381492ebe2c5d87f324e1b8815c"
[[package]]
name = "reqwest"
-version = "0.12.8"
+version = "0.12.9"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "f713147fbe92361e52392c73b8c9e48c04c6625bce969ef54dc901e58e042a7b"
+checksum = "a77c62af46e79de0a562e1a9849205ffcb7fc1238876e9bd743357570e04046f"
dependencies = [
"base64 0.22.1",
"bytes",
@@ -3254,7 +3499,7 @@ dependencies = [
"serde",
"serde_json",
"serde_urlencoded",
- "sync_wrapper 1.0.1",
+ "sync_wrapper 1.0.2",
"system-configuration",
"tokio",
"tokio-native-tls",
@@ -3303,7 +3548,7 @@ dependencies = [
"proc-macro2",
"quote",
"rust-embed-utils",
- "syn 2.0.85",
+ "syn 2.0.90",
"walkdir",
]
@@ -3335,9 +3580,9 @@ checksum = "719b953e2095829ee67db738b3bfa9fa368c94900df327b3f07fe6e794d2fe1f"
[[package]]
name = "rustc-hash"
-version = "2.0.0"
+version = "2.1.0"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "583034fd73374156e66797ed8e5b0d5690409c9226b22d87cb7f19821c05d152"
+checksum = "c7fb8039b3032c191086b10f11f319a6e99e1e82889c5cc6046f515c9db1d497"
[[package]]
name = "rustc_version"
@@ -3350,9 +3595,9 @@ dependencies = [
[[package]]
name = "rustix"
-version = "0.38.37"
+version = "0.38.41"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "8acb788b847c24f28525660c4d7758620a7210875711f79e7f663cc152726811"
+checksum = "d7f649912bc1495e167a6edee79151c84b1bad49748cb4f1f1167f459f6224f6"
dependencies = [
"bitflags 2.6.0",
"errno",
@@ -3363,9 +3608,9 @@ dependencies = [
[[package]]
name = "rustls"
-version = "0.23.18"
+version = "0.23.19"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "9c9cc1d47e243d655ace55ed38201c19ae02c148ae56412ab8750e8f0166ab7f"
+checksum = "934b404430bb06b3fae2cba809eb45a1ab1aecd64491213d7c3301b88393f8d1"
dependencies = [
"log",
"once_cell",
@@ -3390,6 +3635,9 @@ name = "rustls-pki-types"
version = "1.10.0"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "16f1201b3c9a7ee8039bcadc17b7e605e2945b27eee7631788c1bd2b0643674b"
+dependencies = [
+ "web-time",
+]
[[package]]
name = "rustls-webpki"
@@ -3435,9 +3683,9 @@ dependencies = [
[[package]]
name = "schannel"
-version = "0.1.26"
+version = "0.1.27"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "01227be5826fa0690321a2ba6c5cd57a19cf3f6a09e76973b58e61de6ab9d1c1"
+checksum = "1f29ebaa345f945cec9fbbc532eb307f0fdad8161f281b6369539c8d84876b3d"
dependencies = [
"windows-sys 0.59.0",
]
@@ -3463,7 +3711,7 @@ dependencies = [
"proc-macro2",
"quote",
"serde_derive_internals",
- "syn 2.0.85",
+ "syn 2.0.90",
]
[[package]]
@@ -3487,9 +3735,9 @@ dependencies = [
[[package]]
name = "security-framework-sys"
-version = "2.12.0"
+version = "2.12.1"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "ea4a292869320c0272d7bc55a5a6aafaff59b4f63404a003887b679a2e05b4b6"
+checksum = "fa39c7303dc58b5543c94d22c1766b0d31f2ee58306363ea622b10bbc075eaa2"
dependencies = [
"core-foundation-sys",
"libc",
@@ -3509,22 +3757,22 @@ checksum = "a3f0bf26fd526d2a95683cd0f87bf103b8539e2ca1ef48ce002d67aad59aa0b4"
[[package]]
name = "serde"
-version = "1.0.213"
+version = "1.0.215"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "3ea7893ff5e2466df8d720bb615088341b295f849602c6956047f8f80f0e9bc1"
+checksum = "6513c1ad0b11a9376da888e3e0baa0077f1aed55c17f50e7b2397136129fb88f"
dependencies = [
"serde_derive",
]
[[package]]
name = "serde_derive"
-version = "1.0.213"
+version = "1.0.215"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "7e85ad2009c50b58e87caa8cd6dac16bdf511bbfb7af6c33df902396aa480fa5"
+checksum = "ad1e866f866923f252f05c889987993144fb74e722403468a4ebd70c3cd756c0"
dependencies = [
"proc-macro2",
"quote",
- "syn 2.0.85",
+ "syn 2.0.90",
]
[[package]]
@@ -3535,15 +3783,16 @@ checksum = "18d26a20a969b9e3fdf2fc2d9f21eda6c40e2de84c9408bb5d3b05d499aae711"
dependencies = [
"proc-macro2",
"quote",
- "syn 2.0.85",
+ "syn 2.0.90",
]
[[package]]
name = "serde_json"
-version = "1.0.132"
+version = "1.0.133"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "d726bfaff4b320266d395898905d0eba0345aae23b54aee3a737e260fd46db03"
+checksum = "c7fceb2473b9166b2294ef05efcb65a3db80803f0b03ef86a5fc88a2b85ee377"
dependencies = [
+ "indexmap",
"itoa",
"memchr",
"ryu",
@@ -3688,9 +3937,9 @@ checksum = "3c5e1a9a646d36c3599cd173a41282daf47c44583ad367b8e6837255952e5c67"
[[package]]
name = "socket2"
-version = "0.5.7"
+version = "0.5.8"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "ce305eb0b4296696835b71df73eb912e0f1ffd2556a501fcede6e0c50349191c"
+checksum = "c970269d99b64e60ec3bd6ad27270092a5394c4e309314b18ae3fe575695fbe8"
dependencies = [
"libc",
"windows-sys 0.52.0",
@@ -3709,9 +3958,9 @@ dependencies = [
[[package]]
name = "sparsevec"
-version = "0.2.0"
+version = "0.2.1"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "35df5d2e580b29f3f7ec5b4ed49b0ab3acf7f3624122b3e823cafb9630f293b8"
+checksum = "91ef4657ebc254f6e84a863cb495c2feb60e5b48eba5141bf2bbbe202adb65b4"
dependencies = [
"num-traits",
"packedvec",
@@ -3724,9 +3973,6 @@ name = "spin"
version = "0.9.8"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "6980e8d7511241f8acf4aebddbb1ff938df5eebe98691418c4468d0b72a96a67"
-dependencies = [
- "lock_api",
-]
[[package]]
name = "spm_precompiled"
@@ -3783,11 +4029,11 @@ version = "0.26.4"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "4c6bee85a5a24955dc440386795aa378cd9cf82acd5f764469152d2270e581be"
dependencies = [
- "heck",
+ "heck 0.5.0",
"proc-macro2",
"quote",
"rustversion",
- "syn 2.0.85",
+ "syn 2.0.90",
]
[[package]]
@@ -3809,9 +4055,9 @@ dependencies = [
[[package]]
name = "syn"
-version = "2.0.85"
+version = "2.0.90"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "5023162dfcd14ef8f32034d8bcd4cc5ddc61ef7a247c024a33e24e1f24d21b56"
+checksum = "919d3b74a5dd0ccd15aeb8f93e7006bd9e14c295087c9896a110f490752bcf31"
dependencies = [
"proc-macro2",
"quote",
@@ -3826,9 +4072,9 @@ checksum = "2047c6ded9c721764247e62cd3b03c09ffc529b2ba5b10ec482ae507a4a70160"
[[package]]
name = "sync_wrapper"
-version = "1.0.1"
+version = "1.0.2"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "a7065abeca94b6a8a577f9bd45aa0867a2238b74e8eb67cf10d492bc39351394"
+checksum = "0bf256ce5efdfa370213c1dabab5935a12e49f2c58d15e9eac2870d3b4f27263"
dependencies = [
"futures-core",
]
@@ -3841,7 +4087,7 @@ checksum = "c8af7666ab7b6390ab78131fb5b0fce11d6b7a6951602017c35fa82800708971"
dependencies = [
"proc-macro2",
"quote",
- "syn 2.0.85",
+ "syn 2.0.90",
]
[[package]]
@@ -3854,7 +4100,7 @@ dependencies = [
"byteorder",
"enum-as-inner",
"libc",
- "thiserror",
+ "thiserror 1.0.69",
"walkdir",
]
@@ -3896,9 +4142,9 @@ dependencies = [
[[package]]
name = "tar"
-version = "0.4.42"
+version = "0.4.43"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "4ff6c40d3aedb5e06b57c6f669ad17ab063dd1e63d977c6a88e7f4dfa4f04020"
+checksum = "c65998313f8e17d0d553d28f91a0df93e4dbbbf770279c7bc21ca0f09ea1a1f6"
dependencies = [
"filetime",
"libc",
@@ -3913,9 +4159,9 @@ checksum = "61c41af27dd6d1e27b1b16b489db798443478cef1f06a660c96db617ba5de3b1"
[[package]]
name = "tempfile"
-version = "3.13.0"
+version = "3.14.0"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "f0f2c9fc62d0beef6951ccffd757e241266a2c833136efbe35af6cd2567dca5b"
+checksum = "28cce251fcbc87fac86a866eeb0d6c2d536fc16d06f184bb61aeae11aa4cee0c"
dependencies = [
"cfg-if",
"fastrand",
@@ -3935,9 +4181,9 @@ dependencies = [
[[package]]
name = "terminal_size"
-version = "0.4.0"
+version = "0.4.1"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "4f599bd7ca042cfdf8f4512b277c02ba102247820f9d9d4a9f521f496751a6ef"
+checksum = "5352447f921fda68cf61b4101566c0bdb5104eff6804d0678e5227580ab6a4e9"
dependencies = [
"rustix",
"windows-sys 0.59.0",
@@ -3945,22 +4191,42 @@ dependencies = [
[[package]]
name = "thiserror"
-version = "1.0.65"
+version = "1.0.69"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "b6aaf5339b578ea85b50e080feb250a3e8ae8cfcdff9a461c9ec2904bc923f52"
+dependencies = [
+ "thiserror-impl 1.0.69",
+]
+
+[[package]]
+name = "thiserror"
+version = "2.0.4"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "2f49a1853cf82743e3b7950f77e0f4d622ca36cf4317cba00c767838bac8d490"
+dependencies = [
+ "thiserror-impl 2.0.4",
+]
+
+[[package]]
+name = "thiserror-impl"
+version = "1.0.69"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "5d11abd9594d9b38965ef50805c5e469ca9cc6f197f883f717e0269a3057b3d5"
+checksum = "4fee6c4efc90059e10f81e6d42c60a18f76588c3d74cb83a0b242a2b6c7504c1"
dependencies = [
- "thiserror-impl",
+ "proc-macro2",
+ "quote",
+ "syn 2.0.90",
]
[[package]]
name = "thiserror-impl"
-version = "1.0.65"
+version = "2.0.4"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "ae71770322cbd277e69d762a16c444af02aa0575ac0d174f0b9562d3b37f8602"
+checksum = "8381894bb3efe0c4acac3ded651301ceee58a15d47c2e34885ed1908ad667061"
dependencies = [
"proc-macro2",
"quote",
- "syn 2.0.85",
+ "syn 2.0.90",
]
[[package]]
@@ -3984,6 +4250,16 @@ dependencies = [
"weezl",
]
+[[package]]
+name = "tinystr"
+version = "0.7.6"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "9117f5d4db391c1cf6927e7bea3db74b9a1c1add8f7eda9ffd5364f40f57b82f"
+dependencies = [
+ "displaydoc",
+ "zerovec",
+]
+
[[package]]
name = "tinyvec"
version = "1.8.0"
@@ -4001,14 +4277,15 @@ checksum = "1f3ccbac311fea05f86f61904b462b55fb3df8837a366dfc601a0161d0532f20"
[[package]]
name = "tokenizers"
-version = "0.20.3"
+version = "0.21.0"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "67b67c92f6d705e2a1d106fb0b28c696f9074901a9c656ee5d9f5de204c39bf7"
+checksum = "9ecededfed68a69bc657e486510089e255e53c3d38cc7d4d59c8742668ca2cae"
dependencies = [
"aho-corasick",
"derive_builder",
"esaxx-rs",
"getrandom",
+ "hf-hub",
"indicatif",
"itertools 0.12.1",
"lazy_static",
@@ -4025,7 +4302,7 @@ dependencies = [
"serde",
"serde_json",
"spm_precompiled",
- "thiserror",
+ "thiserror 1.0.69",
"unicode-normalization-alignments",
"unicode-segmentation",
"unicode_categories",
@@ -4033,14 +4310,14 @@ dependencies = [
[[package]]
name = "tokio"
-version = "1.41.0"
+version = "1.42.0"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "145f3413504347a2be84393cc8a7d2fb4d863b375909ea59f2158261aa258bbb"
+checksum = "5cec9b21b0450273377fc97bd4c33a8acffc8c996c987a7c5b319a0083707551"
dependencies = [
"backtrace",
"bytes",
"libc",
- "mio 1.0.2",
+ "mio 1.0.3",
"parking_lot",
"pin-project-lite",
"signal-hook-registry",
@@ -4057,7 +4334,7 @@ checksum = "693d596312e88961bc67d7f1f97af8a70227d9f90c31bba5806eec004978d752"
dependencies = [
"proc-macro2",
"quote",
- "syn 2.0.85",
+ "syn 2.0.90",
]
[[package]]
@@ -4082,20 +4359,19 @@ dependencies = [
[[package]]
name = "tokio-rustls"
-version = "0.26.0"
+version = "0.26.1"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "0c7bc40d0e5a97695bb96e27995cd3a08538541b0a846f65bba7a359f36700d4"
+checksum = "5f6d0975eaace0cf0fcadee4e4aaa5da15b5c079146f2cffb67c113be122bf37"
dependencies = [
"rustls",
- "rustls-pki-types",
"tokio",
]
[[package]]
name = "tokio-util"
-version = "0.7.12"
+version = "0.7.13"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "61e7c3654c13bcd040d4a03abee2c75b1d14a37b423cf5a813ceae1cc903ec6a"
+checksum = "d7fcaa8d55a2bdd6b83ace262b016eca0d79ee02818c5c1bcdf0305114081078"
dependencies = [
"bytes",
"futures-core",
@@ -4104,6 +4380,33 @@ dependencies = [
"tokio",
]
+[[package]]
+name = "toktrie"
+version = "0.1.0"
+source = "git+https://github.com/microsoft/llguidance?rev=cfef3df97372a7b84d74976ff41cc9cb78bca6cc#cfef3df97372a7b84d74976ff41cc9cb78bca6cc"
+dependencies = [
+ "anyhow",
+ "bytemuck",
+ "bytemuck_derive",
+ "rustc-hash",
+ "serde",
+ "serde_json",
+]
+
+[[package]]
+name = "toktrie_hf_tokenizers"
+version = "0.1.0"
+source = "git+https://github.com/microsoft/llguidance?rev=cfef3df97372a7b84d74976ff41cc9cb78bca6cc#cfef3df97372a7b84d74976ff41cc9cb78bca6cc"
+dependencies = [
+ "anyhow",
+ "log",
+ "rustc-hash",
+ "serde",
+ "serde_json",
+ "tokenizers",
+ "toktrie",
+]
+
[[package]]
name = "toml"
version = "0.8.19"
@@ -4195,9 +4498,9 @@ dependencies = [
[[package]]
name = "tracing"
-version = "0.1.40"
+version = "0.1.41"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "c3523ab5a71916ccf420eebdf5521fcef02141234bbc0b8a49f2fdc4544364ef"
+checksum = "784e0ac535deb450455cbfa28a6f0df145ea1bb7ae51b821cf5e7927fdcfbdd0"
dependencies = [
"log",
"pin-project-lite",
@@ -4207,20 +4510,20 @@ dependencies = [
[[package]]
name = "tracing-attributes"
-version = "0.1.27"
+version = "0.1.28"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "34704c8d6ebcbc939824180af020566b01a7c01f80641264eba0999f6c2b6be7"
+checksum = "395ae124c09f9e6918a2310af6038fba074bcf474ac352496d5910dd59a2226d"
dependencies = [
"proc-macro2",
"quote",
- "syn 2.0.85",
+ "syn 2.0.90",
]
[[package]]
name = "tracing-core"
-version = "0.1.32"
+version = "0.1.33"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "c06d3da6113f116aaee68e4d601191614c9053067f9ab7f6edbcb161237daa54"
+checksum = "e672c95779cf947c5311f83787af4fa8fffd12fb27e4993211a84bdfd9610f9c"
dependencies = [
"once_cell",
"valuable",
@@ -4239,9 +4542,9 @@ dependencies = [
[[package]]
name = "tracing-subscriber"
-version = "0.3.18"
+version = "0.3.19"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "ad0f048c97dbd9faa9b7df56362b8ebcaa52adb06b498c050d2f4e32f90a7a8b"
+checksum = "e8189decb5ac0fa7bc8b96b7cb9b2701d60d48805aca84a238004d665fcc4008"
dependencies = [
"matchers",
"nu-ansi-term",
@@ -4278,7 +4581,7 @@ checksum = "b9c81686f7ab4065ccac3df7a910c4249f8c0f3fb70421d6ddec19b9311f63f9"
dependencies = [
"proc-macro2",
"quote",
- "syn 2.0.85",
+ "syn 2.0.90",
]
[[package]]
@@ -4297,7 +4600,7 @@ dependencies = [
"num",
"serde",
"serde_json",
- "thiserror",
+ "thiserror 1.0.69",
]
[[package]]
@@ -4310,7 +4613,7 @@ dependencies = [
"half",
"serde",
"serde_json",
- "thiserror",
+ "thiserror 1.0.69",
"ug",
]
@@ -4325,7 +4628,7 @@ dependencies = [
"objc",
"serde",
"serde_json",
- "thiserror",
+ "thiserror 1.0.69",
"ug",
]
@@ -4341,26 +4644,11 @@ version = "2.8.0"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "7e51b68083f157f853b6379db119d1c1be0e6e4dec98101079dec41f6f5cf6df"
-[[package]]
-name = "unicode-bidi"
-version = "0.3.17"
-source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "5ab17db44d7388991a428b2ee655ce0c212e862eff1768a455c58f9aad6e7893"
-
[[package]]
name = "unicode-ident"
-version = "1.0.13"
+version = "1.0.14"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "e91b56cd4cadaeb79bbf1a5645f6b4f8dc5bde8834ad5894a8db35fda9efa1fe"
-
-[[package]]
-name = "unicode-normalization"
-version = "0.1.24"
-source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "5033c97c4262335cded6d6fc3e5c18ab755e1a3dc96376350f3d8e9f009ad956"
-dependencies = [
- "tinyvec",
-]
+checksum = "adb9e6ca4f869e1180728b7950e35922a7fc6397f7b641499e8f3ef06e50dc83"
[[package]]
name = "unicode-normalization-alignments"
@@ -4383,6 +4671,12 @@ version = "0.1.14"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "7dd6e30e90baa6f72411720665d41d89b9a3d039dc45b8faea1ddd07f617f6af"
+[[package]]
+name = "unicode-width"
+version = "0.2.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "1fc81956842c57dac11422a97c3b8195a1ff727f06e85c84ed2e8aa277c9a0fd"
+
[[package]]
name = "unicode_categories"
version = "0.1.1"
@@ -4409,13 +4703,14 @@ checksum = "8ecb6da28b8a351d773b68d5825ac39017e680750f980f3a1a85cd8dd28a47c1"
[[package]]
name = "ureq"
-version = "2.10.1"
+version = "2.12.1"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "b74fc6b57825be3373f7054754755f03ac3a8f5d70015ccad699ba2029956f4a"
+checksum = "02d1a66277ed75f640d608235660df48c8e3c19f3b4edb6a263315626cc3c01d"
dependencies = [
"base64 0.22.1",
"flate2",
"log",
+ "native-tls",
"once_cell",
"rustls",
"rustls-pki-types",
@@ -4428,15 +4723,27 @@ dependencies = [
[[package]]
name = "url"
-version = "2.5.2"
+version = "2.5.4"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "22784dbdf76fdde8af1aeda5622b546b422b6fc585325248a2bf9f5e41e94d6c"
+checksum = "32f8b686cadd1473f4bd0117a5d28d36b1ade384ea9b5069a1c40aefed7fda60"
dependencies = [
"form_urlencoded",
"idna",
"percent-encoding",
]
+[[package]]
+name = "utf16_iter"
+version = "1.0.5"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "c8232dd3cdaed5356e0f716d285e4b40b932ac434100fe9b7e0e8e935b9e6246"
+
+[[package]]
+name = "utf8_iter"
+version = "1.0.4"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "b6c140620e7ffbb22c2dee59cafe6084a59b5ffc27a8859a5f0d494b5d52b6be"
+
[[package]]
name = "utf8parse"
version = "0.2.2"
@@ -4465,7 +4772,7 @@ dependencies = [
"proc-macro2",
"quote",
"regex",
- "syn 2.0.85",
+ "syn 2.0.90",
]
[[package]]
@@ -4574,9 +4881,9 @@ checksum = "9c8d87e72b64a3b4db28d11ce29237c246188f4f51057d65a7eab63b7987e423"
[[package]]
name = "wasm-bindgen"
-version = "0.2.95"
+version = "0.2.97"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "128d1e363af62632b8eb57219c8fd7877144af57558fb2ef0368d0087bddeb2e"
+checksum = "d15e63b4482863c109d70a7b8706c1e364eb6ea449b201a76c5b89cedcec2d5c"
dependencies = [
"cfg-if",
"once_cell",
@@ -4585,36 +4892,37 @@ dependencies = [
[[package]]
name = "wasm-bindgen-backend"
-version = "0.2.95"
+version = "0.2.97"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "cb6dd4d3ca0ddffd1dd1c9c04f94b868c37ff5fac97c30b97cff2d74fce3a358"
+checksum = "8d36ef12e3aaca16ddd3f67922bc63e48e953f126de60bd33ccc0101ef9998cd"
dependencies = [
"bumpalo",
"log",
"once_cell",
"proc-macro2",
"quote",
- "syn 2.0.85",
+ "syn 2.0.90",
"wasm-bindgen-shared",
]
[[package]]
name = "wasm-bindgen-futures"
-version = "0.4.45"
+version = "0.4.47"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "cc7ec4f8827a71586374db3e87abdb5a2bb3a15afed140221307c3ec06b1f63b"
+checksum = "9dfaf8f50e5f293737ee323940c7d8b08a66a95a419223d9f41610ca08b0833d"
dependencies = [
"cfg-if",
"js-sys",
+ "once_cell",
"wasm-bindgen",
"web-sys",
]
[[package]]
name = "wasm-bindgen-macro"
-version = "0.2.95"
+version = "0.2.97"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "e79384be7f8f5a9dd5d7167216f022090cf1f9ec128e6e6a482a2cb5c5422c56"
+checksum = "705440e08b42d3e4b36de7d66c944be628d579796b8090bfa3471478a2260051"
dependencies = [
"quote",
"wasm-bindgen-macro-support",
@@ -4622,28 +4930,38 @@ dependencies = [
[[package]]
name = "wasm-bindgen-macro-support"
-version = "0.2.95"
+version = "0.2.97"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "26c6ab57572f7a24a4985830b120de1594465e5d500f24afe89e16b4e833ef68"
+checksum = "98c9ae5a76e46f4deecd0f0255cc223cfa18dc9b261213b8aa0c7b36f61b3f1d"
dependencies = [
"proc-macro2",
"quote",
- "syn 2.0.85",
+ "syn 2.0.90",
"wasm-bindgen-backend",
"wasm-bindgen-shared",
]
[[package]]
name = "wasm-bindgen-shared"
-version = "0.2.95"
+version = "0.2.97"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "65fc09f10666a9f147042251e0dda9c18f166ff7de300607007e96bdebc1068d"
+checksum = "6ee99da9c5ba11bd675621338ef6fa52296b76b83305e9b6e5c77d4c286d6d49"
[[package]]
name = "web-sys"
-version = "0.3.72"
+version = "0.3.74"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "a98bc3c33f0fe7e59ad7cd041b89034fa82a7c2d4365ca538dda6cdaf513863c"
+dependencies = [
+ "js-sys",
+ "wasm-bindgen",
+]
+
+[[package]]
+name = "web-time"
+version = "1.1.0"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "f6488b90108c040df0fe62fa815cbdee25124641df01814dd7282749234c6112"
+checksum = "5a6580f308b1fad9207618087a65c04e7a10bc77e02c8e84e9b00dd4b12fa0bb"
dependencies = [
"js-sys",
"wasm-bindgen",
@@ -4651,9 +4969,9 @@ dependencies = [
[[package]]
name = "webpki-roots"
-version = "0.26.6"
+version = "0.26.7"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "841c67bff177718f1d4dfefde8d8f0e78f9b6589319ba88312f567fc5841a958"
+checksum = "5d642ff16b7e79272ae451b7322067cdc17cadf68c23264be9d94a32319efe7e"
dependencies = [
"rustls-pki-types",
]
@@ -4901,6 +5219,18 @@ dependencies = [
"memchr",
]
+[[package]]
+name = "write16"
+version = "1.0.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "d1890f4022759daae28ed4fe62859b1236caebfc61ede2f63ed4e695f3f6d936"
+
+[[package]]
+name = "writeable"
+version = "0.5.5"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "1e9df38ee2d2c3c5948ea468a8406ff0db0b29ae1ffde1bcf20ef305bcc95c51"
+
[[package]]
name = "xattr"
version = "1.3.1"
@@ -4914,9 +5244,9 @@ dependencies = [
[[package]]
name = "yoke"
-version = "0.7.4"
+version = "0.7.5"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "6c5b1314b079b0930c31e3af543d8ee1757b1951ae1e1565ec704403a7240ca5"
+checksum = "120e6aef9aa629e3d4f52dc8cc43a015c7724194c97dfaf45180d2daf2b77f40"
dependencies = [
"serde",
"stable_deref_trait",
@@ -4926,13 +5256,13 @@ dependencies = [
[[package]]
name = "yoke-derive"
-version = "0.7.4"
+version = "0.7.5"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "28cc31741b18cb6f1d5ff12f5b7523e3d6eb0852bbbad19d73905511d9849b95"
+checksum = "2380878cad4ac9aac1e2435f3eb4020e8374b5f13c296cb75b4620ff8e229154"
dependencies = [
"proc-macro2",
"quote",
- "syn 2.0.85",
+ "syn 2.0.90",
"synstructure",
]
@@ -4954,27 +5284,27 @@ checksum = "fa4f8080344d4671fb4e831a13ad1e68092748387dfc4f55e356242fae12ce3e"
dependencies = [
"proc-macro2",
"quote",
- "syn 2.0.85",
+ "syn 2.0.90",
]
[[package]]
name = "zerofrom"
-version = "0.1.4"
+version = "0.1.5"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "91ec111ce797d0e0784a1116d0ddcdbea84322cd79e5d5ad173daeba4f93ab55"
+checksum = "cff3ee08c995dee1859d998dea82f7374f2826091dd9cd47def953cae446cd2e"
dependencies = [
"zerofrom-derive",
]
[[package]]
name = "zerofrom-derive"
-version = "0.1.4"
+version = "0.1.5"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "0ea7b4a3637ea8669cedf0f1fd5c286a17f3de97b8dd5a70a6c167a1730e63a5"
+checksum = "595eed982f7d355beb85837f651fa22e90b3c044842dc7f2c2842c086f295808"
dependencies = [
"proc-macro2",
"quote",
- "syn 2.0.85",
+ "syn 2.0.90",
"synstructure",
]
@@ -4984,6 +5314,28 @@ version = "1.8.1"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "ced3678a2879b30306d323f4542626697a464a97c0a07c9aebf7ebca65cd4dde"
+[[package]]
+name = "zerovec"
+version = "0.10.4"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "aa2b893d79df23bfb12d5461018d408ea19dfafe76c2c7ef6d4eba614f8ff079"
+dependencies = [
+ "yoke",
+ "zerofrom",
+ "zerovec-derive",
+]
+
+[[package]]
+name = "zerovec-derive"
+version = "0.10.3"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "6eafa6dfb17584ea3e2bd6e76e0cc15ad7af12b09abdd1ca55961bed9b1063c6"
+dependencies = [
+ "proc-macro2",
+ "quote",
+ "syn 2.0.90",
+]
+
[[package]]
name = "zip"
version = "1.1.4"
@@ -4997,7 +5349,7 @@ dependencies = [
"flate2",
"indexmap",
"num_enum",
- "thiserror",
+ "thiserror 1.0.69",
]
[[package]]
diff --git a/Cargo.toml b/Cargo.toml
index 6564903333..f0f356191b 100644
--- a/Cargo.toml
+++ b/Cargo.toml
@@ -22,11 +22,12 @@ repository = "https://github.com/EricLBuehler/mistral.rs"
keywords = ["machine-learning"]
categories = ["science"]
license = "MIT"
+rust-version = "1.82"
[workspace.dependencies]
anyhow = "1.0.80"
-candle-core = { git = "https://github.com/EricLBuehler/candle.git", version = "0.8.0", rev = "8742354" }
-candle-nn = { git = "https://github.com/EricLBuehler/candle.git", version = "0.8.0", rev = "8742354" }
+candle-core = { git = "https://github.com/EricLBuehler/candle.git", version = "0.8.0", rev = "6800496" }
+candle-nn = { git = "https://github.com/EricLBuehler/candle.git", version = "0.8.0", rev = "6800496" }
serde = "1.0.197"
serde_json = "1.0.114"
indexmap = { version = "2.2.5", features = ["serde"] }
diff --git a/README.md b/README.md
index 36881b9f33..229adfa194 100644
--- a/README.md
+++ b/README.md
@@ -52,21 +52,16 @@ Please submit requests for new models [here](https://github.com/EricLBuehler/mis
./mistralrs-server -i vision-plain -m HuggingFaceTB/SmolVLM-Instruct -a idefics3
```
-- 🔥🧠 AnyMoE: Build a memory-efficient MoE model from anything, in seconds
-
- ```
- ./mistralrs-server -i toml -f toml-selectors/anymoe_lora.toml
- ```
- φ³ Run the new Phi 3.5/3.1/3 model with 128K context window
```
./mistralrs-server -i plain -m microsoft/Phi-3.5-mini-instruct -a phi3
```
-- 🌀 Run the Phi 3.5 MoE model with 128K context window: [documentation and guide here](docs/PHI3.5MOE.md)
+- 🧮 Enhance ISQ by collecting an imatrix from calibration data: [documentation](docs/IMATRIX.md)
```
- ./mistralrs-server -i plain -m microsoft/Phi-3.5-MoE-instruct -a phi3.5moe
+ ./mistralrs-server -i --isq Q4K plain -m meta-llama/Llama-3.2-3B-Instruct --calibration-file calibration_data/calibration_datav3_small.txt
```
- φ³ 📷 Run the Phi 3 vision model: [documentation and guide here](docs/PHI3V.md)
@@ -94,8 +89,9 @@ Mistral.rs supports several model categories:
**Easy**:
- Lightweight OpenAI API compatible HTTP server
- Python API
-- Grammar support with Regex and Yacc
+- Grammar support with JSON Schema, Regex, Lark, and Guidance via [LLGuidance library](https://github.com/microsoft/llguidance)
- [ISQ](docs/ISQ.md) (In situ quantization): run `.safetensors` models directly from 🤗 Hugging Face by quantizing in-place
+ - Enhance performance with an [imatrix](docs/IMATRIX.md)!
**Fast**:
- Apple silicon support: ARM NEON, Accelerate, Metal
@@ -105,9 +101,11 @@ Mistral.rs supports several model categories:
**Quantization**:
- [Details](docs/QUANTS.md)
-- GGML: 2-bit, 3-bit, 4-bit, 5-bit, 6-bit and 8-bit, with ISQ support.
+- GGML: 2-bit, 3-bit, 4-bit, 5-bit, 6-bit and 8-bit, with imatrix support
- GPTQ: 2-bit, 3-bit, 4-bit and 8-bit, with [Marlin](https://github.com/IST-DASLab/marlin) kernel support in 4-bit and 8-bit.
- HQQ: 4-bit and 8 bit, with ISQ support
+- FP8
+- BNB: bitsandbytes int8, fp4, nf4 support
**Powerful**:
- LoRA support with weight merging
@@ -215,8 +213,6 @@ Enabling features is done by passing `--features ...` to the build system. When
> Note: You can use our [Docker containers here](https://github.com/EricLBuehler/mistral.rs/pkgs/container/mistral.rs).
> Learn more about running Docker containers: https://docs.docker.com/engine/reference/run/
-> Note: You can use pre-built `mistralrs-server` binaries [here](https://github.com/EricLBuehler/mistral.rs/releases/tag/v0.3.1)
-
- Install the [Python package here](mistralrs-pyo3/_README.md).
- The Python package has [wheels on PyPi](mistralrs-pyo3/_README.md#installation-from-pypi)!
@@ -608,6 +604,8 @@ If you want to add a new model, please contact us via an issue and we can coordi
- Set the `CUDA_NVCC_FLAGS` environment variable to `-fPIE` during build: `CUDA_NVCC_FLAGS=-fPIE`
- Error `CUDA_ERROR_NOT_FOUND` or symbol not found when using a normal or vison model:
- For non-quantized models, you can specify the data type to load and run in. This must be one of `f32`, `f16`, `bf16` or `auto` to choose based on the device.
+- What is the minimum supported CUDA compute cap?
+ - The minimum CUDA compute cap is **5.3**.
## Credits
This project would not be possible without the excellent work at [`candle`](https://github.com/huggingface/candle). Additionally, thank you to all contributors! Contributing can range from raising an issue or suggesting a feature to adding some new functionality.
diff --git a/calibration_data/README.md b/calibration_data/README.md
new file mode 100644
index 0000000000..2693eea3fe
--- /dev/null
+++ b/calibration_data/README.md
@@ -0,0 +1,8 @@
+# Calibration data
+
+Sourced from: https://gist.github.com/bartowski1182/eb213dccb3571f863da82e99418f81e8
+
+- `calibration_datav3.txt` is the original data (64181 tokens)
+- `calibration_datav3_small.txt` is up to line 1241 of the original data (30173 tokens)
+
+Using the full dataset will take the longest but also provide the most accurate calibration.
diff --git a/calibration_data/calibration_datav3.txt b/calibration_data/calibration_datav3.txt
new file mode 100644
index 0000000000..41ae165614
--- /dev/null
+++ b/calibration_data/calibration_datav3.txt
@@ -0,0 +1,2482 @@
+In addition to a significant decrease in hepatic lipid accumulation in the IOE group, which inhibited energy intake by propionate enrichment, hepatic lipids were also significantly reduced in the mice in the IOP group, which was largely enriched with butyrate. Compared with the IOE group, IOP had a stronger regulatory effect on hepatic metabolism and triglyceride metabolism and higher levels of TCA cycle in the host. In addition, butyrate has the ability to promote browning of white adipose tissue (WAT) to brown adipose tissue (BAT).^[@ref39],[@ref40]^ WAT stores energy, whereas BAT uses energy for heating and consequently host energy expenditure increases.^[@ref41],[@ref42]^ However, adipose tissue weight does not change after WAT browning.^[@ref43]^ Therefore, the weight of adipose tissue of mice in the IOP group dominated by butyrate was greater than that of the mice in the IOE group dominated by propionate.
+
+In conclusion ([Figure [7](#fig7){ref-type="fig"}](#fig7){ref-type="fig"}C), the improvement of obesity condition in mice by both *I. obliquus* extracts was attributed to their effects on gut microbiota and SCFA profiles. IOE increased the levels of propionate-producing bacteria *Bacteroides* and *Akkermansia* in the cecum of HFD-fed mice, resulting in the enrichment of propionate. Propionate reduced weight gain in mice by inhibiting energy intake. IOP increased the levels of butyrate-production-associated bacteria *Lactobacillus* and the *Bacteroidales* S24-7 group in the cecum of HFD-fed mice, resulting in the enrichment of butyrate. Butyrate increased energy consumption, TCA cycle levels, and degradation of carbohydrates and lipids in mice by promoting mitochondrial decoupling.
+
+Conclusions {#sec4}
+===========
+
+IOE and IOP ameliorated HFD-induced obesity condition in mice through differential modulatory effects on gut microbial metabolism. Moreover, we found the connections between cecal butyrate (not propionate) and chemicals of mice, including four metabolites of the TCA cycle and other metabolism-related chemicals.
+
+Materials and Methods {#sec5}
+=====================
+
+Preparation of IOE/IOP {#sec5.1}
+----------------------
+
+The dried and powdered *I. obliquus* (1.0 kg) was extracted with ultrapure water (30 L) at 90 °C for 3 h and concentrated. The supernatant was evaporated in vacuo at 45 °C, followed by extracting with 4 vol of ethanol to get crude extract. The extract was deproteinized by the Sevage method five times. The supernatant was dried in vacuo and lyophilized to get IOP (62.5 g). After *I. obliquus* was extracted with water, the residue was extracted with 80% ethanol at 80 °C in a water bath for 2 h. The supernatant was dried in vacuo and lyophilized to get IOE (30.9 g).
+
+Animal Experimental Design {#sec5.2}
+--------------------------
+
+The experimental protocol was approved by the Animal Ethics Committee of Jilin University and complied with national laws. Five-week-old C57BL/6J male mice (15--17 g) were divided into four groups, 12 mice per group. The mice in the NCD group were fed with normal chow diet, and the mice in the HFD group, IOE group, and IOP group were fed with high-fat diet. The compositions of mice diets are presented in [Tables S4 and S5](http://pubs.acs.org/doi/suppl/10.1021/acsomega.0c01566/suppl_file/ao0c01566_si_001.pdf). The mice in the IOP group were gavaged with IOP at a dose of 1000 mg/kg per day according to previous studies,^[@ref44]^ and the mice in the IOE group were gavaged with IOE at a dose of 500 mg/kg per day according to the extraction rate of IOE/IOP and the dose of IOP. After 14 weeks of treatment, the mice were sacrificed for specimens.
+
+Oral Glucose Tolerance Test (OGTT) {#sec5.3}
+----------------------------------
+
+OGTT was performed using a previously described method.^[@ref45]^
+
+Serum Biochemical Analysis {#sec5.4}
+--------------------------
+
+Serum and liver lipid were measured using the method of kits obtained from Nanjing Jiancheng Bioengineering Institute (Nanjing, China).
+
+RNA Preparation and Quantitative PCR Analysis {#sec5.5}
+---------------------------------------------
+
+The total RNA extraction and the reverse transcription (RT)-qPCR analysis of the gene expression were performed using a previously described method.^[@ref46]^ Primer sequences for the targeted mouse genes are shown in [Table S6](http://pubs.acs.org/doi/suppl/10.1021/acsomega.0c01566/suppl_file/ao0c01566_si_001.pdf).
+
+Sample Collection {#sec5.6}
+-----------------
+
+Urine was collected using metabolic cages at 14th week, and 50 μL of sodium azide solution (0.1% w/w) was added into each urine sample. Cecum contents were washed from cecum in a 2 mL Eppendorf tube containing 1.0 mL of cold phosphate-buffered saline (PBS) (pH 7.4). All samples were then stored in a −80 °C freezer for later analysis.
+
+All samples were thawed at room temperature. Serum was prepared by mixing 100 μL of each sample with a solution of 500 μL of PBS in D~2~O (containing 3-(tri-methyl-silyl) propionic-2,2,3,3-*d*4 acid sodium salt (TSP)). Then, 200 μL exudate of cecum contents was mixed with a solution of 400 μL of PBS in D~2~O (containing TSP). Supernatants (550 μL) were pipetted into NMR analysis tubes after centrifuging (15 000 rpm, 15 min, 4 °C) and passing through 0.22 μm membrane filters. For each urine sample, 400 μL of the sample was mixed with a solution of 200 μL of PBS in H~2~O. Then, 500 μL of supernatants was pipetted into NMR analysis tubes after centrifuging (15 000 rpm, 5 min, 4 °C), and 50 μL of D~2~O containing TSP was also added to each tube. D~2~O provided a field frequency lock and TSP a chemical shift reference (^1^H, δ 0.0).
+
+NMR Data Acquisition and Processing {#sec5.7}
+-----------------------------------
+
+All samples were analyzed by an AVANCE III 600M MHz NMR spectrometer at 298.2 K. ^1^H NMR spectra were acquired by one-dimensional (1D) version CPMG (serum samples) and noesyphpr (urine and cecal samples) pulse sequence with water suppression during the relaxation delay of 3 s and a mixing time of 0.1 s. Sixty-four free induction decays were collected into 64 K data points with a spectral width of 7812.5 Hz (serum samples) and 8417.5 Hz (urine and cecal samples) and an acquisition time of 2 s. Free induction decay (FID) was zero-filled to 64 K prior to Fourier transformation.
+
+Metabolite identifications were confirmed using the Human Metabolome Database (HMDB) and previous studies,^[@ref47]^ based on chemical shifts of hydrogen and peak multiplicity ([Figures S5--S7 and Table S7](http://pubs.acs.org/doi/suppl/10.1021/acsomega.0c01566/suppl_file/ao0c01566_si_001.pdf)).
+
+All of the spectra were manually phased and baseline-corrected in software MestreNova 12.0 (Mestre-lab Research SL). Each spectrum was segmented into regions with a width of 0.005 ppm between δ 9.6 and 0.4. The δ 5.48--6.20 region in urine spectra and δ 4.72--5.20 region in all spectra were excluded to eliminate the effects of urea signals and water suppression. All remaining regions of the spectra were then normalized to the total sum of the integrated spectral area to reduce any significant concentration differences.
+
+Sequencing, Diversity Analysis, and Function Prediction of Cecal Microbiota {#sec5.8}
+---------------------------------------------------------------------------
+
+DNA extraction, sequencing, and data processing were performed using a previously described method.^[@ref48]^
+
+Four parameters of the alpha diversity were used to assess the overall diversity thoroughly. The Ace and Chao (only presence/absence of taxa considered) indexes determine the richness in a community, while the Shannon and Simpson indexes (additionally accounts for the number of times that each taxon was observed) determine the richness and/or evenness of a community. In addition, a higher Shannon index or a lower Simpson index indicates higher community diversity. Unlike alpha diversity, beta diversity was used to measure the division of diversity between two or more communities. Microbial communities had often been characterized using divergence-based measures of beta diversity to determine whether two or more communities were significantly different.
+
+We used PICRUSt (phylogenetic investigation of communities by reconstruction of unobserved states) to perform functional predictions. PICRUSt generates metagenomic predictions from 16S rRNA data using annotations of sequenced genomes in the IMG database. Moreover, the Kyoto Encyclopedia of Genes and Genomes (KEGG) database was used for functional classification.^[@ref49]^
+
+Statistical Analysis {#sec5.9}
+--------------------
+
+The data were expressed as means ± standard errors of the means (SEM). One-way analysis of variance (ANOVA) was performed to identify significant differences among four groups, followed by the indicated post hoc test (lysergic acid diethylamide (LSD) comparison test). The results were considered statistically significant at *p*-value \< 0.05 unless otherwise specified in the figures. *P*-value between two independent groups was analyzed using an unpaired two-tailed *t*-test. Metabolomics data were subjected to OPLS-DA using software SIMCA 14.0 (Umetrics, Sweden) and used to construct multivariate statistical models. Bivariate correlations were calculated using Spearman's *r* coefficients. Heatmaps were constructed using Excel 2016.
+
+Accession Number {#sec5.10}
+----------------
+
+High-throughput sequencing data have been submitted to the NCBI Sequence Read Archive (SRA) under the accession number PRJNA576716.
+
+The Supporting Information is available free of charge at [https://pubs.acs.org/doi/10.1021/acsomega.0c01566](https://pubs.acs.org/doi/10.1021/acsomega.0c01566?goto=supporting-info).3D score plots of the OPLS-DA classification; VIP plot of OPLS-DA; pathway analysis based on different metabolites; effects of IOE/IOP on gut microbial diversity; ^1^H NMR spectra of mice serum, urine, and cecal contents (Figures S1--S7); main metabolites of serum, urine, and cecum contents; compositions of NCD and HFD; primer sequence for amplification of the fragments; and metabolite identifications (Tables S1--S7) ([PDF](http://pubs.acs.org/doi/suppl/10.1021/acsomega.0c01566/suppl_file/ao0c01566_si_001.pdf))
+
+Supplementary Material
+======================
+
+######
+
+ao0c01566_si_001.pdf
+
+Conceptualization, J.Y., H.X., and Q.X.; investigation, J.Y.; supervision and resources, H.X. and Q.X.; Writing-original draft, J.Y. and J.-Y.X.
+
+The authors declare no competing financial interest.
+
+This work was supported by the Jilin Province Science and Technology Institute of China (No. 20180201078YY).
+
+TC
+
+: total cholesterol
+
+TG
+
+: triglycerides
+
+HDL
+
+: high-density lipoprotein cholesterol
+
+LDL
+
+: low-density lipoprotein cholesterol
+
+TSP
+
+: 3-(tri-methyl-silyl) propionic-2, 2, 3, 3-*d*4 acid sodium salt
+
+PBS
+
+: phosphate-buffered saline
+
+Chrebp
+
+: carbohydrate-responsive element binding protein
+
+GK
+
+: glucokinase
+
+PK
+
+: pyruvate kinase
+
+PEPCK
+
+: phosphoenolpyruvate carboxykinase
+
+PC
+
+: pyruvate carboxylase
+
+FBPase
+
+: fructose-1,6-bisphosphatase
+
+G6Pase
+
+: glucose-6-phosphatase
+
+Ppar-γ
+
+: peroxisome proliferator-activated recepto γ
+
+Srebp1c
+
+: sterol regulatory element binding protein-1c
+
+Fas
+
+: fatty acid synthase
+
+Acl
+
+: ATP-citrate lyase
+
+Scd1
+
+: stearoyl-CoA desaturase 1
+
+Acc
+
+: acetyl-CoA carboxylase
+
+Acox
+
+: acyl-CoA oxidase
+
+Ppar-α
+
+: peroxisome proliferator-activated recepto α
+
+Cpt1
+
+: carnitine palmitoyltransferase I
+
+Mcad
+
+: medium-chain acyl-CoA dehydrogenase
+
+Dgat1
+
+: diacylglycerol acyltransferase 1
+
+Dgat2
+
+: diacylglycerol acyltransferase 2
+
+Gpat
+
+: glycerol-3-phosphate acyltransferase
+
+VIP
+
+: variable importance of projection
+
+OPLS-DA
+
+: orthogonal partial least-squares discriminant analysis
+
+CoA
+
+: coenzyme A
+
+SCFA
+
+: short-chain fatty acids
+
+Description
+
+Foreign trailer for Gokusen.
+
+After seven years of enduring popularity on television, Gokusen, finally makes its silver screen debut. Winning over the hearts of millions of viewers and becoming a national heroine, Yukie Nakama reprises her role as Kumiko Yamaguchi, a.k.a Yankumi. Wearing jerseys, glasses and pigtails, the dowdy high school instructor becomes the homeroom teacher for the wild delinquents of Class 3D. At first glance, Kumiko seems like she can be easily intimidated, but much to everyone's surprise, she remains unfazed by her students' shenanigans. Her courage and discipline comes from being raised by a family who also happens to be a feared yakuza clan. With her strong sense of justice and her fierce brawling abilities, Kumiko follows her principles and upholds honor to solve the problems that trouble her students.
+---
+abstract: |
+ We design a new, fast algorithm for agnostically learning univariate probability distributions whose densities are well approximated by piecewise polynomial functions. Let $f$ be the density function of an arbitrary univariate distribution, and suppose that $f$ is $\OPT$ close in $L_1$-distance to an unknown piecewise polynomial function with $t$ interval pieces and degree $\pdeg$. Our algorithm draws $n = O(t(\pdeg+1)/\eps^2)$ samples from $f$, runs in time $\Otilde (n \cdot \poly (\pdeg))$, and with probability at least $9/10$ outputs an $O(t)$-piecewise degree-$\pdeg$ hypothesis $h$ that is $4 \cdot \OPT +\eps$ close to $f$.
+
+ Our general algorithm yields (nearly) sample-optimal and [*nearly-linear time*]{} estimators for a wide range of structured distribution families over both continuous and discrete domains in a unified way. For most of our applications, these are the [*first*]{} sample-optimal and nearly-linear time estimators in the literature. As a consequence, our work resolves the sample and computational complexities of a broad class of inference tasks via a single “meta-algorithm”. Moreover, we experimentally demonstrate that our algorithm performs very well in practice.
+
+ Our algorithm consists of three “levels”: (i) At the top level, we employ an iterative greedy algorithm for finding a good partition of the real line into the pieces of a piecewise polynomial. (ii) For each piece, we show that the sub-problem of finding a good polynomial fit on the current interval can be solved efficiently with a separation oracle method. (iii) We reduce the task of finding a separating hyperplane to a combinatorial problem and give an efficient algorithm for this problem. Combining these three procedures gives a density estimation algorithm with the claimed guarantees.
+author:
+- |
+ Jayadev Acharya[^1]\
+ EECS, MIT\
+- |
+ Ilias Diakonikolas[^2]\
+ Informatics, U. of Edinburgh\
+- |
+ Jerry Li[^3]\
+ EECS, MIT\
+- |
+ Ludwig Schmidt[^4]\
+ EECS, MIT\
+bibliography:
+- 'allrefs.bib'
+title: 'Sample-Optimal Density Estimation in Nearly-Linear Time'
+---
+
+Appendix {#appendix .unnumbered}
+========
+
+[^1]: Supported by a grant from the MIT-Shell Energy Initiative.
+
+[^2]: Supported by a Marie Curie CIG, EPSRC grant EP/L021749/1 and a SICSA grant.
+
+[^3]: Supported by NSF grant CCF-1217921 and DOE grant DE-SC0008923.
+
+[^4]: Supported by MADALGO and a grant from the MIT-Shell Energy Initiative.
+
+Extra-anatomic aortic bypass for complex (re-) coarctation and hypoplastic aortic arch in adolescents and adults.
+Various surgical approaches have been proposed for complex (re-) coarctation and aortic arch hypoplasia (AAH). We report seven patients (mean age 19.6+/-9.5 years) with complex coarctation or re-coarctation and AAH successfully treated by extra-anatomic ascending-to-descending aortic bypass (ADB) via sternotomy between 1995 and 2002 without mortality and no relevant complication early postoperatively and during a follow-up of 24+/-29 (0.2-84) months. ADB may therefore be considered in selected patients with (re-) coarctation with AAH, with the need for concomitant ascending aortic or cardiac surgery and in patients with aortic arch stenosis and increased risk of complications under DHCA.
+This invention generally relates to the formation of gas tight pressure blocks in multiple wire or conductor electric cables such as telephone cables to enable air pressurization of sections of such cables. In particular, this invention is useful in maintaining fluid pressure in the pressure block forming compound during multiple injections at a single site on a cable during in-field service or installation.
+U.S. Pat. No. 3,823,250, the disclosure of which is incorporated herein by reference, discloses a tap fitting suitable for use with the valve hereinafter described. Briefly, the tap fitting comprises a curved base sheet for placement over an opening cut in the sheath of the cable and an injection port integrally formed with and projecting from the sheet, the port including means for forming a pressure tight covering, such as threads about the mouth of the port.
+As is well known in the art, air pressurization of sections of electric and telephone cables prevents the seepage of water or moisture into the cable and the resulting noise and interference in communication and power circuits. Pressure blocks forming dams at intermittent points over the length of the cables are provided by injecting a self-setting liquid compound which hardens and fills the space around the wires over a sufficient length to hold the air pressure. To form such a pressure block it is necessary to make an opening in the cable sheathing leading to the interior and then to provide and exteriorly positioned fitting through which the liquid block forming compound may be injected. To accomplish this, a fluid injector is used. Typically the fluid injector comprises a chamber containing a discrete amount of block forming compound, a pressurizing plunger operative in the chamber, and a nozzle in fluid communication with the chamber through which the fluid is ejected in response to the compression movement of the plunger operating on the compound. The fluid compound is injected into the interior of the cable by threading the nozzle of the fluid injector to the tap fitting and compressing the plunger.
+Where a large amount of compound is needed to fill the cable interior to the desired extent, i.e., more than the amount normally contained within the injector chamber, the continuous injection operation must be interrupted so that the injector chamber can be refilled or recharged. To recharge the fluid injector in the midst of the injection operation, the pressure on the plunger of the fluid injector is released and the plunger is withdrawn to permit access to the injector chamber for refilling with the compound.
+Recharging in the midst of the cable filling for block forming operation presents a number of drawbacks. Due to residual pressure in the cable, some of the liquid compound escapes through the tap fitting and pressure interior of the cable is normally lost. To overcome these problems, stop valves have been devised to be interposed between the fluid injector and the cable interior. Such stop valves permit injection of fluid through a fitting into the cable interior while opposing the escape of the pressurized fluid compound therefrom. The 3M Company of Minneapolis, Minn., for example, markets a resin pressure splicing system under the trademark "SCOTCHCAST Brand R.P.S." The 3M system includes a one-way valve that opens to permit the injection of the blocking compound and closes under the residual back pressure to prevent the escape of the blocking compound.
+Such prior art valves have considerable drawbacks, particularly where the nozzle of the fluid injector is adapted to sealably couple with a conduit (which includes the valve) into the cable interior. For example, due to the pressure seal between the injection nozzle and the valve, it is difficult to release the plunger of the fluid injector, since any attempt to do so creates a vacuum in the interior of the fluid injector. This makes it difficult to recharge the fluid injector while it is in place on the tap fitting.
+/*
+ * Copyright 2000-2009 JetBrains s.r.o.
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package com.intellij.refactoring.safeDelete.usageInfo;
+
+import com.intellij.util.IncorrectOperationException;
+
+/**
+ * @author yole
+ */
+public interface SafeDeleteCustomUsageInfo {
+ void performRefactoring() throws IncorrectOperationException;
+}
+
+```python def sum_two_numbers(num1: int, num2: int) -> int: """ Calculates the sum of two integers. This function takes in two integer variables as input parameters, adds them together using the addition operator, and returns the result as an integer. Args: num1 (int): The first integer to add. num2 (int): The second integer to add. Returns: int: The sum of num1 and num2. """ # Add the two input integers together using the + operator result = num1 + num2 # Return the calculated sum return result ``` Here's a detailed explanation of each part: 1. The function is defined using the `def` keyword, followed by the function name `sum_two_numbers`. The function name follows the snake_case naming convention, which is the recommended style for function names in Python. 2. The function takes two parameters, `num1` and `num2`, both of which are annotated with the `int` type hint to indicate that they should be integers. Type hints are optional but provide clarity about the expected types of the parameters. 3. The function return type is also annotated with `int` using the `->` syntax, indicating that the function will return an integer value. 4. The function has a docstring enclosed in triple quotes (`"""`) that provides a brief description of what the function does. The docstring follows the conventions outlined in PEP 257. 5. Inside the function, the `result` variable is assigned the sum of `num1` and `num2` using the addition operator (`+`). This line performs the actual calculation. 6. Finally, the `result` is returned using the `return` statement, which sends the calculated sum back to the caller of the function. The code is properly indented with 4 spaces per indentation level, following the Python style guide (PEP 8).
+
+Why isn't climate change keeping more Senators up tonight?
+
+All-nighters are usually the result of not doing your homework, but this evening twenty-eight United States senators will be up for pretty much the opposite reason. Having read the latest science on climate change, they will be making speeches through the night to call for comprehensive action to meet this threat.
+
+It’s an unusual tactic, but the real question isn’t why are twenty-eight of them talking all night, but why the other seventy-two senators are sleeping when we’re facing such a serious challenge. All the major American scientific organization have been warning us about the reality and seriousness of climate change for years. And while it may be happening slowly, that won’t make it any less expensive or devastating. If taxpayers liked paying for damage from Hurricane Sandy, or the droughts and wildfires in the West and Midwest, they’re going to have a ball as the impacts get stronger in the years to come.
+
+So why are the Sleeping 72 ignoring this severe threat to our economy and our environment?
+
+It’s not that endorsing the science of climate change is unpopular in this country. 69% of Americans believe there is “solid evidence” the climate is changing (Pew, 2013). But as is almost always the case, members of Congress care a lot less about what Americans in general think than about what the voters of their state or district think. Even more specifically, that means being wary about taking position that might alienate the core supporters of your party, or ‘gettable’ moderates.
+
+As a result, many House members from solidly conservative districts, and Senators from swing states, are afraid to step out on an issue like climate change. Never mind that prudent action now will save their constituents money in the long run, and protect future generations from devastating storms, droughts, and health effects. If the politics look worrisome, they’d rather get a good night’s sleep tonight.
+
+But the funny thing about politics is that we often get it wrong. Like in sports, sometimes the worst thing you can do is play not to lose – avoid risks to nurse a lead, hoping it will hold up. Clearly, there are a lot incumbents who have calculated that denying the obvious truth of climate science will protect them from unnecessary political risk. But, in the long run, that could be a losing political strategy. 80% of voters under 35 want action to address climate change. More importantly to politicians who are afraid of the issue, 56% of younger voters who don’tgenerally approveof President Obama’s job performance support action (GS Strategy Group, Benenson Strategy Group, 2013). And it’s not just the long run. Even in 2014, before that demographic wave washes over us, signalling a sensible position on climate change (it’s real, we should act prudently) is a great way to signal moderation to swing voters.
+
+Senators, of course, know the politics of their states much better than most of us outside observers. But most of them also know they got their jobs by, at some point, upsetting the status quo – beating an incumbent, surprising a front-runner, grabbing a forgotten issue and rallying the public. In business and in politics, new ideas are disruptive. If the Sleeping 72 want to avoid becoming the Kodak or Blockbuster of politics, they’d better wake up to the threat of climate change.
+
+Keith Gaby
+
+Get new posts by email
+
+Comments
+
+Michael Ashley
+
+March 10, 2014at 7:22 pm (ET)
+
+If people would pay attention to the fact that politicians follow the money not the voters they might see that this is the best time to start a green socialist/ capitalist party ( I know - it's a fantasy )
+
+Vivian Tisevich
+
+March 10, 2014at 9:17 pm (ET)
+
+Hmm, wondering why Ohio isn't being represented tonight? Unless I missed seeing Senator Brown and Sen. Portman's name, and if so, I apologize. I realize there are many other issues of concern to keep my reps busy, such as working to amend the Indian Child Welfare Act, that I contacted them about today, but c'mon, is climate or the abduction of children off reservations even on their top ten list? It matters to me, even tho I'm just a little ole voting gal in Ohio. When we know better, we do better. Those of you there tonight made the choice to do better. thank You!
+
+By the time the really obvious effects of climate change show, most of these senators will be out of office or died of old age. The extreme weather we experience now is easy to brush off as natural variation, and no one can say storm x was caused by climate change. It is hard for any person, especially senators to react to something unless it is staring them in the face. By the time it is staring us in the face it will be too late. The world will not end, but it will be forever changed.
+Training for a major sports event is never easy, be it for the first 5km run or the fifth ultra-marathon, but Tinké is here to the rescue! Follow the journey of Chris Small and James Rotheram, two first-time Tinké users, as they make use of this nifty device to get their body prepared for their ascent up Mount Kinabalu.
+
+Preparing for this big event should be no different from preparing for any other significant occasion in your life. Physical and mental preparation is important to ensure that you can perform at your peak during the event itself. The Tinké then helps keep track of your fitness and wellness levels, to ensure that you deliver your best performance.
+
+Tinké interprets your fitness and stress indices through the measurement of your heart rate, respiratory rate, blood oxygen saturation and heart rate variability. The Zensorium application and dashboard then stores the readings and tracks the progress over time.
+
+“James and I haven’t done some tracking in awhile, and he came up with this idea. And so, we’re going to climb Mount Kinabalu together,” said 28-year-old Chris Small.
+
+“And the Tinké is good for that (Helping to prepare for the climb),” added 35-year-old James Rotheram.
+
+Getting started, the duo decided to try out a hypoxia chamber to see how their body would fare under external conditions, similar to what they would face on their climb up Mount Kinabalu. After doing some simple exercises, Chris was shocked to see that his Vita reading was only 47/99.
+
+“A sense of a reality check, I wasn’t as healthy as I thought I was,” said Chris.
+
+The duo knew that they had to improve their health, fitness and stamina, and fast. As part of their preparation, both friends practiced yoga for mind and body relaxation, two weeks prior to the climb.
+
+“Everywhere we’ve come on this project, everyone has said we need to improve our breathing. And yoga is really a good way of doing that,” mentioned James.
+
+As a trial run, the duo trekked up Bukit Timah hill two days before their Mount Kinabalu climb.
+
+On the day of the climb itself, while both James and Chris were satisfied with how they have progressed over the previous month, it remains uncertain if they would be able to complete the hike up Mount Kinabalu. Chris appeared fitter than James, and James was concerned if he would become a liability for Chris.
+
+“I think now we are in a better place than we were before. We’ve spent two weeks of training, prepared all the gear that we need, we’ve done our yoga, we’ve worked on our breathing, and in relaxing ourselves and our bodies, and we’ve done a lot of physical training. I think after all that, we are more prepared than we initially were. On Tinké, my scores are pretty good,” said Chris.
+
+“My score this morning wasn’t brilliant on Tinké, but that’s not telling how my body feels, but we need to get hiking to see how the body reacts,” remarked a concerned James.
+
+While the ascend itself was a daunting experience, both friends pulled through and made it to the top, being possibly at the highest point one could ever be in South East Asia.
+
+“This was tough. This was really tough. Am I built for it? Maybe now? But a month ago and doing our training? No. All this played a role and helped me get ready for this climb,” said Chris.
+
+Using Tinké for a month, Chris and James were able to improve their Vita and Zen indices, to successfully conquer Mount Kinabalu. The journey itself will not be easy, but training with Tinké can make the process a whole lot simpler.
+
+Recommended articles:
+
+Zensorium | 5 Simple Back-to-Basics Workout
+
+Zensorium | 5 Ways to be a better runner
+
+Zensorium | Why is running good for you?
+
+Follow us on:
+
+Zensorium, the makers of Tinké and Being.
+Pros:
+
+Cons:
+
+The Worms series of games have always been a bit off-kilter. In its initial incarnation as a time-sensitive 2D turn-based strategy game, Worms pitted cute little animated earth-munchers against one another with a vast arsenal of weapons and power-ups amid bright, colorful environments that got blown to bits in the process. As fans eagerly anticipate the first 3D incarnation of the series next year, Team 17 have created an unusual spin-off to keep us quite busy and amused: the rather addictive and hyperactive combat puzzle game, Worms Blast.
+
+Bust-A-Worm?
+
+Although Blast has the look of a Worms game, the gameplay is totally different. It's more like the puzzle-flavored Bust-a-Move, which involves shooting bubbles at puzzle pieces falling from the sky. In this game, you control a little boat-bound character armed with a bazooka that fires color-coded missiles. You can move left and right, tilt the cannon up and down to alter your trajectory, and collect other weapons and power-up crates, released by destroying puzzle pieces with a missile of the same color.
+
+Since your character is in a boat, you also have to contend with rising tides, torrential weather conditions, sea monsters, and other hazards of the deep zooming around as you fight for survival. In most of the challenges, puzzle pieces gradually descend towards the water regardless of whether or not you shoot at them, so it's important to keep clearing the puzzle pieces lest you get pushed underwater. In addition, rising tides must be quelled by gathering falling stars, which are also among the puzzle pieces. If your aim is terribly off, and you hit nothing at all, cartoon items such as anvils, refrigerators, and cannonballs will fall from the sky, geared towards bonking you on the head and damaging your health. It's a far cry from the whole "you-take-a-turn, I-take-a-turn" format of the original games.
+
+Worms Blast offers a number of gameplay modes. There are numerous full-screen challenges where you face the puzzles alone, as well as a number of head-to-head modes where you play via split screen against another person or the CPU. It's a good idea to play through some of the single-player challenges first -- they serve as a sort of boot camp, where you'll learn all the basics of puzzle combat (as odd as that may sound). As you progress in these single-player missions, you'll occasionally unlock new modes.
+
+In one challenge, you've got six missiles and six tough-to-hit targets, but all the time in the world to hit them. In another, UFOs (composed of puzzle pieces) zoom towards the water and you've got to hit as many as possible directly in the belly before the timer runs out. Another challenge involves hitting rapidly descending targets on alternate sides of the screen in quick succession, adding a couple of seconds to the timer with each successful shot. There are simply too many variations in each mode to catalog here, which is a good thing. Some of the challenges are frustrating, but they're considerably varied and ultimately rewarding.
+
+Timed target shooting is one of many intense challenges you'll face in puzzle mode.
+
+Your progress in the main puzzle mode gets saved along the way, so once you pass a really tough challenge, you have the option of never looking back. You can also return to a challenge you enjoyed, or continue the remaining challenges with any character of your choice. The characters (which oddly enough, aren't limited to worms) have varying thresholds for damage, and their boats vary in terms of size and speed. There's also a tournament mode, in which you've got to survive for as long as possible during specific challenges, most of which are subtle variations of the ones introduced in the puzzle mode.
+
+“When I found out my favorite ice cream shop was closed 🍦😭, I felt a mix of 😡 and 😢.”
+
+“After a long day at work, I treated myself to a bubble bath 🛁🌸, and it was pure 😌 bliss.”
+
+“When my team won the championship game 🏆🎉, I couldn’t stop smiling 😁.”
+Q:
+
+как передать json на сервер
+
+Здравствуйте, у меня есть 2 json объекта, находящиеся в javascript. Каким образом мне хранить их на сервере, файлами или в запросе передавать? Пожалуйста, с примерами кода.
+Бэкэнд на ASP.NET 4.5
+
+A:
+
+На клиенте конвертировать его в string:
+myStringObj = JSON.stringify(myObj);
+
+Дальше отправить его любым способом на сервер (xhr, form submit);
+Процесс здесь
+А как хранить вам виднее, либо база данных, либо статичный json, зависит от того что делаете
+
+Category: Console
+
+We all know that Microsoft is working on a certain project called the Project Scorpio and that it’s just the next generation of the Xbox console. It was back in 2016, Microsoft had announced at the E3 about their next project codenamed Project Scorpio. Back then they announced that the console is set to be rolled out in 2017. It’s already 2017, and we haven’t heard anything much about the release date of the Xbox 2 until now. There are fresh rumors surrounding the Xbox Scorpio release date, and we are going to discuss it in this post.
+
+The current console the Xbox One has been launched back on November 22, 2013, in the US and clearly ended up winning hearts of people. So Xbox fans really got excited when they first heard of the project. But the only question that has been on people’s minds had been that when exactly does Microsoft plan to launch their products. Of course, they said the Xbox 2 Release Date in 2017 but we are already halfway through the year, already five months into the year and there is no real confirmation. Fans have been wondering is if the release date has been postponed to which we now have an answer.
+
+The new rumor is basically good news for fans who can pretty much hope to pick up the console this Christmas. This is just the sort of news we had been waiting for since the time the project was announced. This is the rumor that has emerged right before the 2017 E3 gaming expo. And the best fact is that the news comes from none other than the Xbox boss Phil Spencer, who when asked on Twitter is there is a change in the Xbox 2 release date, replied saying this: “Schedule looks very good right now, no issues.” This is what has prompted fans and tech gurus to believe that the console will be coming out in the second of the year and the most convenient time is the holiday season of Christmas, which is a great time to send your product sales soaring.
+
+We are expecting that Microsoft will announce the date of the release at the E3 gaming expo and there are expectations that they might also end up revealing the price of the console so that people are pretty much equipped to handle the pocket burn when Xbox 2 actually hits the market shelves.
+
+There are a lot of talks going on surrounding the Xbox 2 and a lot of rumors as to what new things that console will be bringing on the table. There are reports that there’ll be Voice Control Settings which will make the console a serious winner in the gaming industry. People expect the console to come with everything that the new and advanced technology has to offer in this modern day time. There are also talks that the Xbox 2 will be featuring custom game specific controllers that’ll be great, to say the least. And folks, this is all that we know about the upcoming console, but there is no official confirmation regarding these, so you should really take these rumors with a pinch of salt.
+Katabexin, Medichrom
+
+The drug brand named Katabexin contains generic salt-Betahistine Hydrochloride and is manufactured by Medichrom.Katabexin is mainly associated with symptoms and indications-The International Classification of Diseases (ICD)- N07CA01-Betahistine.
+
+Generic Salts
+
+Betahistine Hydrochloride
+
+Available types of drugs
+
+N / A
+
+Medical categories
+
+Human DrugAntivertigo drugs
+
+Usage-Diseases
+
+N07CA01-BetahistineManufacturers
+
+Medichrom
+
+More Drugs
+
+The drug brand named Kasmucol contains generic salt-Acebrophylline and is manufactured by Teva.Kasmucol is mainly associated with symptoms and indications-The International Classification of Diseases (ICD)- ATC.
+
+Generic Salts
+
+The drug brand named Kas contains generic salt-Preparation for Enteral Nutrition and is manufactured by Nutricia-Bago.Kas is mainly associated with symptoms and indications-The International Classification of Diseases (ICD)- ATC.
+
+Ge...
+
+The drug brand named Kastair EZ contains generic salt-Montelukast Sodium and is manufactured by Pediatrica.Kastair EZ is mainly associated with symptoms and indications-The International Classification of Diseases (ICD)- R03DC03-Montelukast.
+
+The drug brand named Kast contains generic salt-Montelukast and is manufactured by RND Laboratories.Kast is mainly associated with symptoms and indications-The International Classification of Diseases (ICD)- R03DC03-Montelukast.
+
+Gen...
+
+The drug brand named Kastorion contains generic salt-Montelukast Sodium and is manufactured by OEP Philippines.Kastorion is mainly associated with symptoms and indications-The International Classification of Diseases (ICD)- R03DC03-Montelukas...
+
+The drug brand named Katabios contains generic salt-Multivitamins and is manufactured by Specialita Igienico Terapeutiche.Katabios is mainly associated with symptoms and indications-The International Classification of Diseases (ICD)- A11BA-Mu...
+
+The drug brand named Katagrip contains generic salt-Acetaminophen and is manufactured by Angelini.Katagrip is mainly associated with symptoms and indications-The International Classification of Diseases (ICD)- ATC.
+
+Generic Salts
+
+The drug brand named Katapekt contains generic salt-Ammonium Chloride and is manufactured by Vitabalans.Katapekt is mainly associated with symptoms and indications-The International Classification of Diseases (ICD)- N02AA59-Codeine, combinati...
+
+The drug brand named Katar contains generic salt-Corynebacterium Pseudodiphtheriae and is manufactured by Istituto Sieroterapico Berna.Katar is mainly associated with symptoms and indications-The International Classification of Diseases (ICD)-...
+
+The drug brand named Katasuccin contains generic salt-Succinic Acid and is manufactured by Unidentified Pharmaceutical Company.Katasuccin is mainly associated with symptoms and indications-The International Classification of Diseases (ICD)- A...
+
+The drug brand named Katen contains generic salt-Mexiletine Hydrochloride and is manufactured by Zentiva.Katen is mainly associated with symptoms and indications-The International Classification of Diseases (ICD)- C01BB02-Mexiletine.
+
+The drug brand named Kathro contains generic salt-Cholesterol and is manufactured by Unidentified Pharmaceutical Company.Kathro is mainly associated with symptoms and indications-The International Classification of Diseases (ICD)- ATC....
+
+The drug brand named Katin contains generic salt-Bile Salts and is manufactured by Instituto Sanitas.Katin is mainly associated with symptoms and indications-The International Classification of Diseases (ICD)- ATC.
+
+Generic Salts
+
+The drug brand named Kativ N contains generic salt-Vitamin K1 (Phytonadione) and is manufactured by Unidentified Pharmaceutical Company.Kativ N is mainly associated with symptoms and indications-The International Classification of Diseases (IC...
+
+The drug brand named Katogel contains generic salt-Emollient and is manufactured by Deverge Medicina e Medicalizzazione.Katogel is mainly associated with symptoms and indications-The International Classification of Diseases (ICD)- D02AX-Other...
+The present disclosure relates to computer systems, and in particular to managing file access to applications that are deployed in a virtualized computer environment.
+Virtualized computer environments, which may include cloud computing systems, composite information technology systems and computer cluster systems, are used to provide computer resources or other computing resources to end users. In a cloud computing environment, the physical hardware configuration is hidden from the end user. Cloud computing systems may include servers, network storage devices, routers, gateways, communication links, software (e.g., applications, operating systems, web services, etc.), and other devices. However, because the physical hardware and software platforms on which cloud computing system is implemented are hidden within a “cloud,” they can be managed, upgraded, replaced or otherwise changed by a system administrator without the customer being aware of or affected by the change.
+A computer cluster, also referred to as a cluster, may be considered as a type of cloud computing environment and may include a set of loosely connected computers that may be connected to one another via local networks.
+In a typical cloud computing environment, applications may be executed on virtual machines or appliances, which are guest operating systems installed within a host system and an optional preset configuration and structure (e.g., combination of operating system and web server). Virtual Machines are typically implemented with either software emulation or hardware virtualization, or both. A single hardware and/or software platform may host a number of virtual machines, each of which may have access to some portion of the platform's resources, such as processing resources, storage resources, etc.
+Because different applications that are deployed in a cloud computing environment may require access to files, such files may not be consistent among the different applications and/or instances of applications unless a shared location is provided, which may impose unwanted additional complexity to the installation and maintenance of the application. Additionally, unexpected outcomes may occur in the event that two different applications and/or instances of applications access the same file in an overlapping time period. Yet further, synchronization of files used by more than one application and/or instance may be problematic in a cloud computing environment.
+La campagna svizzera di Suvorov si svolse in territorio elvetico tra il settembre e l'ottobre del 1799 durante la guerra della seconda coalizione. Le truppe russo-austriache, che avevano già sconfitto ripetutamente tra aprile e agosto i francesi in Italia, attraversarono il San Gottardo al comando del feldmaresciallo Aleksandr Vasil'evič Suvorov, con l'ordine di marciare contro il generale Andrea Massena per scacciarlo dalla Repubblica Elvetica.
+
+Dopo le importanti vittorie dei mesi precedenti durante la campagna in Italia, Suvorov era rimasto padrone della situazione nella parte settentrionale della penisola e sembrava imminente una sconfitta definitiva dei francesi con il generale russo deciso a marciare addirittura verso la Francia, ma le divisioni e le rivalità delle potenze coalizzate avrebbero ben presto favorito la ripresa delle armate rivoluzionarie: per timore che l'influenza della Russia diventasse troppo grande, gli alleati, facendo anche leva sulle ambizioni dello zar Paolo I di presentarsi come liberatore della Svizzera, riuscirono a ottenere che le truppe russe interrompessero le loro operazioni in Italia e venissero rischierate nella Confederazione, lasciando l'iniziativa nella penisola agli austriaci. A Suvorov fu quindi ordinato di portarsi con il suo esercito verso nord e marciare attraverso il San Gottardo per congiungersi alle truppe russe appena condotte sulla Limmat dal generale Aleksandr Michajlovič Rimskij-Korsakov.
+
+Jimmy Wales nació en Huntsville, Estados Unidos. Su padre, Jimmy, trabajaba como gerente en una tienda de comestibles, mientras que su madre, Doris, y su abuela, Emma, dirigían una escuela privada agrupada, donde Jimmy Wales hizo sus primeros estudios. Él y otros cuatro niños formaban su curso, así que en su aula recibían clase todos los alumnos de primero a cuarto curso y de quinto a octavo. Cuando terminó octavo, Wales asistió a la escuela Randolph School, una secundaria en Huntsville. Wales ha dicho que la escuela era costosa para su familia, pero considera esa educación importante: «La educación fue siempre una pasión en mi hogar... sabes, el tan tradicional apremio por el conocimiento y el aprendizaje, estableciendo eso como una base para una buena vida».nota 1
+Recibió el título de licenciado en Finanzas de la Universidad de Auburn y entró en el programa de financiación del doctorado en Finanzas de la Universidad de Alabama antes de dejarla con un título de máster. Prosiguió los estudios gracias a un préstamo para obtener el título de Doctorado en Finanzas de la Universidad de Indiana. Enseñó en ambas universidades durante sus estudios de postgrado, pero no escribió la tesis para finalizar el doctorado, algo que él mismo atribuye al aburrimiento.
+
+“The sun rose over the horizon, casting a warm glow on the dew-kissed grass. 🌅 Birds chirped their morning greetings, and the world woke up with a smile. ☀️ The coffee brewed in the kitchen, filling the air with its rich aroma. ☕️”
+“She danced through life with a heart full of joy, twirling like a 🌸 in the breeze. Her laughter bubbled up like a fizzy drink, and her eyes sparkled like ✨. The moon peeked out from behind the clouds, winking at her playfully. 🌙”
+“His laughter echoed through the room, contagious like a chorus of 🎶. Friends joined in, clapping their hands and tapping their feet to the rhythm. 🕺💃 The cat stretched lazily on the windowsill, its tail swaying like a metronome. 🐾”
+Q:
+
+Insert a row with default value column in sqlalchemy
+
+I am writing a program which uses a database with sqlalchemy as client.
+Here is one of my tables
+class DownloadRecord(Base):
+ __tablename__ = "DownloadRecords"
+ id = Column("Id", Integer, primary_key=True, autoincrement=True)
+
+ download_name = Column("DownloadName", Unicode, nullable=False)
+ download_date = Column(
+ "DownloadDate", DateTime, default=datetime.datetime.utcnow, nullable=False
+ )
+
+the column download_date is defined with a default value, both here and in the server side table. Here is the definition of the column on the mssql server
+DownloadDate DATETIME NOT NULL DEFAULT GETDATE()
+
+however I try to add the record DownloadRecord(download_name="new_download_name") and I get the following exception.
+
+sqlalchemy.exc.IntegrityError: (pyodbc.IntegrityError) ('23000',
+ "[23000] [Microsoft][SQL Server Native Client 11.0][SQL Server]Cannot
+ insert the value NULL into column 'DownloadDate', table
+ 'DownloadRecords'; column does not allow nulls. INSERT fails. (515)
+ (SQLExecDirectW); [23000] [Microsoft][SQL Server Native Client
+ 11.0][SQL Server]The statement has been terminated. (3621)") [SQL: INSERT INTO [DownloadRecords] ([DownloadName], [DownloadDate]) OUTPUT
+ inserted.[Id] VALUES (?, ?)] [parameters: ("new_download_name", None)]
+
+I also tried to make this column nullable but When I added the new row the DownloadDate column was Null.
+How do I make it automatically use the default value?
+
+A:
+
+The problem is incompatibility between the type of the column DownloadDate and the type of the value you give as its default value on the client side.
+The type you used is DateTime (on the server side as well as the client side).
+However, in the following code:
+Column("DownloadDate", DateTime, default=datetime.datetime.utcnow, nullable=False)
+
+the return value of datetime.datetime.utcnow() is a timezone aware object, while SQL Server's DateTime isn't.
+I see two possible solutions:
+
+Change the default value to a callable which returns a datetime object which is not timezone aware.
+Change the type of the DownloadDate column to a timezone aware type. You can use SQL Server's datetimeoffset on the server side, and SQLAlchemy's DATETIMEOFFSET on the client side.
+
+Take a look at Microsoft's docs on date and time types for the full reference.
+On another note, consider moving to a code first design, where you define your schema in one place.
+
+
+Live and let love /
+
+"Though Willow Pierce has moved forward since her husband died two years ago, she can't ignore her sixth sense that Jack is alive. When newcomer Con Russo comes to town, Willow is convinced he's Jack. She'd never forget his eyes. Willow is determined to learn the truth about Con's identity-even... Full description
+The fate of chlorine and organic materials in swimming pools.
+The fate of organic nitrogen and carbon introduced into a swimming pool by pool users has been studied using a 2.2 m(3) model pool. The study made use of a body fluid analogue (BFA), containing the primary endogenous organic amino compounds, and a soiling analogue represented by humic acid (HA). The system was used to examine the effect of organic loading and organic carbon (OC) sources (i.e. amino or HA) on the levels and speciation of the key chlorinated disinfection by-products of trihalomethanes (THMs) and chloramines under operating conditions representative of those employed on a full-scale pool. Results revealed OC, chloramines and THMs to all attain steady-state levels after 200-500 h of operation, reflecting mineralisation of the dosed OC. Steady-state levels of OC were roughly linearly dependent on dose rate over the range of operational conditions investigated and, as with the chloramine levels recorded, were in reasonable agreement with those reported for full-scale pools. THM levels recorded were somewhat lower than those found in real pools, and were dependent on both on pH carbon source: the THM formation propensity for the soling analogue was around eight times than of the BFA. Of the assayed by-products, only nitrate was found to accumulate, accounting for 4-28% of the dosed amino nitrogen. Contrary to previous postulations based on the application of Henry's Law, only insignificant amounts of the volatile by-products were found to be lost to the atmosphere.
+Q:
+
+textbf doesn't work with txfonts package
+
+If I compile this, it won't work - the text won't be bold.
+\documentclass[9pt, a4paper]{extarticle}
+\usepackage[utf8]{inputenc}
+\usepackage[IL2]{fontenc}
+\usepackage{txfonts}
+\begin{document}
+\textbf{Something}
+\end{document}
+
+If I remove the package usage, it'll work, but I do need it. What should I do?
+
+A:
+
+The log file tells you
+LaTeX Font Warning: Font shape `IL2/txr/m/n' undefined
+(Font) using `IL2/cmr/m/n' instead on input line 5.
+
+LaTeX Font Warning: Font shape `IL2/txr/bx/n' undefined
+(Font) using `IL2/txr/m/n' instead on input line 6.
+
+meaning that txfonts doesn't support the IL2 encoding (just a few fonts do) and the standard Computer Modern font is used instead.
+
+Kevin: yeah its most likely that, i agree. then you should enable the warning light and slowly drive the car to the stripes and stop it there. i've had a similar situation with my parents once. my father forgot to refill the tank and suddenly, there was no gas anymore in the engine and it slowed down. it was a dangerous situation but my dad managed to drive it to the side nicely
+
+Zoe: wow, that sounds really scary! luckily your dad managed to handle it okay. but yes, it's always better to be prepared for these kinds of situations. maybe you should get him a car care package or something? :)
+
+Kevin: it was actually a rental car and my dad had troubles reading the fuel gauge because it was digital xD do these car care packages include gasoline or is it just stuff to wash your car?
+
+Zoe: haha, oh no! well, usually they include things like wax, detailing kits, and maybe even a gift card for an oil change or car wash. but you could also include a funny mug or something like that if you want to make him laugh about it. ;)
+
+Kevin: yeah those mugs are quite funny. i bet there are stores where you can customize them xD what would be a funny joke to be printed on such a mug for my dad?
+
+Zoe: how about "World's Most Modern Dad... but still learning how to read digital fuel gauges" lmmaooo
+
+Kevin: haha xD good one
+
+Zoe: i'm here to help with all your pun and joke needs, kevin! ;)
+
+Kevin: good, i wouldn't want to have it another way zoe :D
+
+Zoe: i'm glad we're on the same page about that! now, are you ready for bedtime
+
+Vision
+
+Our Vision
+
+Develop and sustain a nationally recognized model for community fitness and health;
+
+Maintain a wellness campus that serves more than 3,000 diverse members with integrative programming;
+
+Operate with fiscal and organizational sustainability.
+
+Vermont’s future prosperity depends on our ability to provide citizens with a solid foundation of health and physical fitness. A healthy population becomes the basis for community and economic development, as healthy citizens are also productive employees, contributing community members, nurturing parents and motivated participants in our education system. The key to a healthy population is a multi-dimensional fitness environment that provides opportunities for a social and family experience, skill building through sports, and sustainable pursuit of fitness or athletic performance goals.
+
+Vermonters have had a long standing commitment to the cultivation of our landscapes for recreational use, to thoughtful investment in an innovative recreation business community, and to the design of cutting edge equipment and programs designed to engage individuals at all ages and abilities in health and physical fitness and the pursuit of athletic performance. The Confluence–as a community sports center--has a unique role to play in securing access for adults, youth and children to these investments and innovations that can overcome the challenges in our community. Together, we can work to forward a vision of a healthy population, a rewarding recreation legacy and sustainable economic future for Vermonters.
+
+88 N.Y.2d 925 (1996)
+669 N.E.2d 1111
+646 N.Y.S.2d 789
+The People of the State of New York, Respondent,
+v.
+John A. Ceresoli, Appellant.
+Court of Appeals of the State of New York.
+Argued June 6, 1996.
+Decided June 28, 1996.
+Frank Policelli, Utica, for appellant.
+Michael A. Arcuri, District Attorney of Oneida County, Utica (Timothy P. Fitzgerald of counsel), for respondent.
+Chief Judge KAYE and Judges SIMONS, TITONE, BELLACOSA, SMITH, LEVINE and CIPARICK concur.
+MEMORANDUM.
+The order of the Appellate Division should be affirmed.
+*926Defendant was charged with criminal possession of a forged instrument and with the theft of $3,500 from the Toccolana Club, a private social club in Rome, New York. After his conviction for grand larceny in the fourth degree (Penal Law § 155.30), defendant moved pursuant to CPL 330.30 to set aside the verdict on the ground of juror misconduct involving a single seated juror. During voir dire, the juror, a resident of Rome, was asked whether he was "familiar with members of the Toccolano Club." The juror responded: "I just know where it is, not really, no." It was subsequently established that the juror had decades earlier himself been a nominal member of the club, and two of his relatives were or had been members.
+After a hearing on defendant's motion, the trial court found there was no improper conduct on the part of the juror, and further that the juror's conduct had not "affected a substantial right of the defendant" (CPL 330.30 [2]). The Appellate Division affirmed. The trial court's undisturbed factual finding has support in the record and, like the alleged excessiveness of defendant's sentence, is beyond the scope of our review.
+Order affirmed in a memorandum.
+
+As the type of the FOLIO I present the _Sperm Whale_; of the OCTAVO, the _Grampus_; of the DUODECIMO, the _Porpoise_. FOLIOS. Among these I here include the following chapters:—I. The _Sperm Whale_; II. the _Right Whale_; III. the _Fin-Back Whale_; IV. the _Hump-backed Whale_; V. the _Razor Back Whale_; VI. the _Sulphur Bottom Whale_. BOOK I. (_Folio_), CHAPTER I. (_Sperm Whale_).—This whale, among the English of old vaguely known as the Trumpa whale, and the Physeter whale, and the Anvil Headed whale, is the present Cachalot of the French, and the Pottsfich of the Germans, and the Macrocephalus of the Long Words. He is, without doubt, the largest inhabitant of the globe; the most formidable of all whales to encounter; the most majestic in aspect; and lastly, by far the most valuable in commerce; he being the only creature from which that valuable substance, spermaceti, is obtained. All his peculiarities will, in many other places, be enlarged upon. It is chiefly with his name that I now have to do. Philologically considered, it is absurd. Some centuries ago, when the Sperm whale was almost wholly unknown in his own proper individuality, and when his oil was only accidentally obtained from the stranded fish; in those days spermaceti, it would seem, was popularly supposed to be derived from a creature identical with the one then known in England as the Greenland or Right Whale. It was the idea also, that this same spermaceti was that quickening humor of the Greenland Whale which the first syllable of the word literally expresses. In those times, also, spermaceti was exceedingly scarce, not being used for light, but only as an ointment and medicament. It was only to be had from the druggists as you nowadays buy an ounce of rhubarb. When, as I opine, in the course of time, the true nature of spermaceti became known, its original name was still retained by the dealers; no doubt to enhance its value by a notion so strangely significant of its scarcity. And so the appellation must at last have come to be bestowed upon the whale from which this spermaceti was really derived. BOOK I. (_Folio_), CHAPTER II. (_Right Whale_).—In one respect this is the most venerable of the leviathans, being the one first regularly hunted by man. It yields the article commonly known as whalebone or baleen; and the oil specially known as “whale oil,” an inferior article in commerce. Among the fishermen, he is indiscriminately designated by all the following titles: The Whale; the Greenland Whale; the Black Whale; the Great Whale; the True Whale; the Right Whale. There is a deal of obscurity concerning the identity of the species thus multitudinously baptised. What then is the whale, which I include in the second species of my Folios? It is the Great Mysticetus of the English naturalists; the Greenland Whale of the English whalemen; the Baleine Ordinaire of the French whalemen; the Growlands Walfish of the Swedes. It is the whale which for more than two centuries past has been hunted by the Dutch and English in the Arctic seas; it is the whale which the American fishermen have long pursued in the Indian ocean, on the Brazil Banks, on the Nor’ West Coast, and various other parts of the world, designated by them Right Whale Cruising Grounds. Some pretend to see a difference between the Greenland whale of the English and the right whale of the Americans. But they precisely agree in all their grand features; nor has there yet been presented a single determinate fact upon which to ground a radical distinction. It is by endless subdivisions based upon the most inconclusive differences, that some departments of natural history become so repellingly intricate. The right whale will be elsewhere treated of at some length, with reference to elucidating the sperm whale. BOOK I. (_Folio_), CHAPTER III. (_Fin-Back_).—Under this head I reckon a monster which, by the various names of Fin-Back, Tall-Spout, and Long-John, has been seen almost in every sea and is commonly the whale whose distant jet is so often descried by passengers crossing the Atlantic, in the New York packet-tracks. In the length he attains, and in his baleen, the Fin-back resembles the right whale, but is of a less portly girth, and a lighter colour, approaching to olive. His great lips present a cable-like aspect, formed by the intertwisting, slanting folds of large wrinkles. His grand distinguishing feature, the fin, from which he derives his name, is often a conspicuous object. This fin is some three or four feet long, growing vertically from the hinder part of the back, of an angular shape, and with a very sharp pointed end. Even if not the slightest other part of the creature be visible, this isolated fin will, at times, be seen plainly projecting from the surface. When the sea is moderately calm, and slightly marked with spherical ripples, and this gnomon-like fin stands up and casts shadows upon the wrinkled surface, it may well be supposed that the watery circle surrounding it somewhat resembles a dial, with its style and wavy hour-lines graved on it. On that Ahaz-dial the shadow often goes back.
+
+Kennedy Says He’d Consider a Senate Run If Warren Tapped for VP
+
+A Kennedy in the Senate? Surely you jest.
+
+Get a compelling long read and must-have lifestyle tips in your inbox every Sunday morning — great with coffee!
+
+It’s been seven years since we’ve seen a Kennedy in the Senate. With a little nudge from presumptive Democratic presidential nominee Hillary Clinton, that could soon change.
+
+Congressman Joe Kennedy III told WCVB’s Janet Wu during a Thursday night taping of her show, On the Record, that he would consider a run for Elizabeth Warren’s Senate seat in the event she’s tapped to be Clinton’s running mate this November.
+
+Ted Kennedy won the seat in a special election in 1962 after his brother, John F. Kennedy, was elected president. He held the seat for 47 years until his death in 2009. Joe Kennedy worked on his great-uncle’s re-election campaign in 2006 before enrolling in Harvard Law School, where Warren taught for nearly 20 years.
+
+Cosmo centerfold Scott Brown won the seat in a 2010 special election, defeating Attorney General Martha Coakley. Brown served for just two years before he was ousted by Warren, who became the Bay State’s first female senator. After a failed Senate campaign in New Hampshire, Brown now spends his time calling in to Herald Radio and following Donald Trump around.
+
+Wu’s interview with Kennedy airs Sunday at 11 a.m.
+Characterization of the limited specificity of antigen recognition in earthworms.
+Parenteral administration of foreign proteins results in earthworms in significantly increased levels of the antigen-binding protein (ABP). The earthworms (Lumbricus terrestris and Eisenia foetida; Oligochaeta, Annelida) were stimulated with different proteins and the ABP response was followed with an anti-ABP monoclonal antibody and in ligand assay with biotin conjugates of all proteins used for stimulation. ABP levels are increased after the stimulation with different proteins irrespective of the size and extent of glycosylation. Molar mass of the ABP molecules was always the same, 56 kDa in L. terrestris and 60 kDa in E. foetida. The level of the specificity is considerably lower in comparison with immunoglobulins since ABP reacts not only with the protein used for stimulation but also, though to lesser extent, with related proteins.
+
+Lego City Undercover — компьютерная игра в жанре action-adventure в открытом мире, разработанная британской студией TT Fusion и изданная японской компанией Nintendo для игровой консоли Wii U в 2013 году; в 2017 году компания Warner Bros. Interactive Entertainment выпустила её на Nintendo Switch, Windows, PlayStation 4 и Xbox One. Игра основана на серии конструкторов Lego City[англ.] и рассказывает об офицере полиции Чейзе Маккейне, вернувшемся в Лего-Сити и преследующем сбежавшего преступника по кличке Бешеный Рекс. Игровой процесс построен на исследовании Лего-Сити, который полностью открыт игроку, и прохождении автономных уровней с головоломками и боевой системой.
+
+После удовлетворительных технических достижений и завершения разработки других игр в стиле Lego по уже существующей интеллектуальной собственности, в 2010 году был создан первый прототип Lego City Undercover. В 2011 году началась полноценная разработка Lego City после того, как Nintendo обратилась к материнской студии TT Games с просьбой создать эксклюзивную игру для Wii U. На момент начала разработки Undercover должна была стать первой игрой в сеттинге Lego с полноценным озвучиванием и первой игрой, которая не зависела от лицензии на сторонние фильмы или комиксы. Сценарист Грэм Горинг использовал огромное количество отсылок и пародий на фильмы и сериалы. Город Лего-Сити основан на нескольких реально существующих городах. Сама Nintendo в процессе разработки непосредственного участия не принимала, но предлагала изменения и получала обновления.
+
+getFromName("_rels/.rels"));
+ foreach ($relations->Relationship as $rel) {
+ if ($rel["Type"] == Zend_Search_Lucene_Document_OpenXml::SCHEMA_COREPROPERTIES) {
+ // Found core properties! Read in contents...
+ $contents = simplexml_load_string(
+ $package->getFromName(dirname($rel["Target"]) . "/" . basename($rel["Target"]))
+ );
+
+ foreach ($contents->children(Zend_Search_Lucene_Document_OpenXml::SCHEMA_DUBLINCORE) as $child) {
+ $coreProperties[$child->getName()] = (string)$child;
+ }
+ foreach ($contents->children(Zend_Search_Lucene_Document_OpenXml::SCHEMA_COREPROPERTIES) as $child) {
+ $coreProperties[$child->getName()] = (string)$child;
+ }
+ foreach ($contents->children(Zend_Search_Lucene_Document_OpenXml::SCHEMA_DUBLINCORETERMS) as $child) {
+ $coreProperties[$child->getName()] = (string)$child;
+ }
+ }
+ }
+
+ return $coreProperties;
+ }
+
+ /**
+ * Determine absolute zip path
+ *
+ * @param string $path
+ * @return string
+ */
+ protected function absoluteZipPath($path)
+ {
+ $path = str_replace(['/', '\\'], DIRECTORY_SEPARATOR, $path);
+ $parts = array_filter(explode(DIRECTORY_SEPARATOR, $path), 'strlen');
+ $absolutes = [];
+ foreach ($parts as $part) {
+ if ('.' == $part) {
+ continue;
+ }
+ if ('..' == $part) {
+ array_pop($absolutes);
+ } else {
+ $absolutes[] = $part;
+ }
+ }
+
+ return implode('/', $absolutes);
+ }
+}
+
+Once upon a time, there was a gray cat named Tom. Tom lived in a big house with his best friend, a little boy named Tim. One day, Tim and Tom found a big mattress in the backyard. They wanted to play a fun game.
+"Let's sail on the mattress like a boat!" said Tim. Tom liked the idea, so they both jumped on the mattress. They pretended to sail on a big ocean, going to far away lands. They saw fish, birds, and even a big whale. They waved to all the animals they saw.
+As they sailed, the sky became dark and it started to rain. Tim and Tom decided to go back home. They said goodbye to the ocean and the animals. When they got home, they were wet and tired. They had a warm bath and went to bed, dreaming about their next adventure on the mattress boat.
+
+One day, a boy named Tim found an old flashlight in his toy box. He was very happy and wanted to show his friend, Sam. So, Tim and Sam decided to play a game in the dark with the flashlight.
+Tim said, "Let's march like big soldiers with the flashlight!" They started to march around the room, shining the flashlight on the walls and floor. The light made funny shapes as they marched.
+As they were marching, they didn't see the big toy car on the floor. Tim tripped on the car and fell down. The flashlight broke into pieces. Tim and Sam were very sad because they could not play with the flashlight anymore.
+
+Once upon a time, there was a little girl named Sue. Sue loved to help her mom and dad. One day, Sue's mom told her that they were going on a trip to a distant place. Sue was very excited!
+Before they could go, Sue's mom needed to find her passport. She looked and looked but could not find it. Sue wanted to help, so she asked, "Mom, where did you last see your passport?" Her mom thought for a moment and said, "I think I last saw it in the big drawer."
+Sue went to the big drawer and started to look for the passport. She moved some things around and finally found it! She was so happy to help her mom. She ran to her mom and said, "Here is your passport, Mom! Now we can go on our trip!"Sue's mom was very proud of her and thanked her for her help. They packed their bags and went on their trip to the distant place. Sue had lots of fun and made many new friends. She knew that helping her mom find the passport made their trip even more special.
+
+Tom and Mia were playing in the living room. They had a lot of toys and books to have fun with. They also liked to look at the fireplace, where their dad had made a warm fire. The fire was orange and yellow and made crackling sounds.
+But Tom had a cold. He felt itchy in his nose and throat. He tried to hold it in, but he could not. He sneezed very loud. "Achoo!" The sneeze was so strong that it blew out some of the fire. The fire became smaller and weaker.
+Mia saw what happened. She was scared. She did not want the fire to go out. She liked the fire. It made the room cozy and bright. She ran to her dad, who was in the kitchen. She said, "Dad, dad, Tom sneezed and the fire is going out!"
+Dad heard Mia and came to the living room. He saw the fire and Tom. He was not angry. He knew Tom was sick and did not mean to sneeze. He said, "Don't worry, Mia. The fire is not going out. It is just smaller. I can make it bigger again. Watch." He took some more wood and put it on the fire. He used a match to light it. The fire grew bigger and stronger again.
+Tom and Mia were happy. They thanked their dad and hugged him. They went back to playing in the living room. They stayed away from the fireplace, but they enjoyed its warmth and light. They hoped Tom would get better soon and stop sneezing.
+
+Once upon a time, there was a lazy dog named Spot. Spot loved to sleep all day and eat tasty sausages. He lived in a small house with a happy family.
+One sunny day, Spot's family had a big cookout. They cooked lots of yummy sausages. Spot could smell the sausages and his mouth watered. He wanted to eat them all, but he was too lazy to get up.
+Spot's friend, a funny cat named Whiskers, saw Spot laying there. Whiskers liked to joke and play. Whiskers said, "Spot, if you don't get up, I will eat all the sausages!" Spot laughed because he knew Whiskers was joking. But then, Spot thought about the sausages and decided to get up and join the fun.
+
+Sam loved to read books. Every morning he would wake up and read in the sunshine. He loved seeing the sunrise as he read. One day, he decided to read higher, so he climbed up the big tree in his yard. He sat on a high branch and started to read.
+Suddenly, a strong gust of wind blew by. Sam lost his balance and tumbled off the tree. He landed with a thud on the ground. He felt very, very sad.
+The doctor looked at Sam's arm and said he broke it. Now he couldn't read for a long time. Sam was so sad that he never tried to read up high again.
+
+Once upon a time, there was a little girl named Sally. She loved Sundays because it was a special day. She would always look forward to Sunday because that was when she could compete with her friends.
+Sally was very competitive and wanted to win every game. She always stared at her friends to see what they were doing. She wanted to make sure she was better than them.
+One Sunday, Sally and her friends were playing tag. Sally started running faster than all the other kids. Soon, she was the one everyone was chasing! But then Sally tripped over a stick and fell.
+Sally was mad and felt embarrassed. She lay on the ground and stared at the sky. Suddenly, a bright rainbow shot across the sky and stopped right in front of Sally. She was amazed and felt happy again. She couldn't believe it. Then she hopped up and ran back to join the game.
+
+بسعر 52 4 ألف يورو أوبل تطلق الكهربائية سيارة أوبل الكهربائية تتوفر السيارة بثلاثة أطوال من 4 60 إلى 5 30 متر مع 9 مقاعد بينما تصل سعة صندوق الأمتعة إلى 4500 لتر أعلنت شركة أوبل عن إطلاق سيارتها الكهربائية في الأسواق بسعر يبدأ من 52 ألفا و444 يورو وأوضحت الشركة الألمانية أن الفان الجديدة تعتمد على سواعد محرك كهربائي بقوة 100 كيلووات 136 حصانا بينما يبلغ عزم الدوران الأقصى 260 نيوتن متر وبفضل هذه القوة تنطلق السيارة بسرعة قصوى 130 كلم س موكا 2021 لغة أوبل الجديدة في التصميم انسجنيا الجديدة أيقونة أوبل تحمل خبرا سيئا لمحطات الوقود ويتوفر للسيارة بطارية بسعة 50 كيلووات ساعة وأخرى بسعة 75 كيلووات ساعة مع مدى سير يبلغ 230 كلم أو 330 كلم وتتوفر السيارة بثلاثة أطوال من 4 60 إلى 5 30 متر مع مقاعد يصل عددها إلى تسعة مقاعد بينما تصل سعة صندوق الأمتعة إلى 4500 لتر وتزخر السيارة بالعديد من الأنظمة المساعدة مثل النوافذ الكهربائية ومساعد جزئي متوائم للحفاظ على السرعة ومساعد الحفاظ على حارة السير مع شاشة لمسية قياس 7 بوصة لنظام الملتيميديا وأنظمة دمج الهواتف الذكية أبل كار بلاي وأندرويد أوتو أوبل تطرح الكهربائي ب 30 ألف يورو أوبل تزيح الستار عن النسخة الأحدث لعام 2020 أوبل تطرح انسجنيا الجديدة بناقل أوتوماتيكي من 9 سرعات أوبل تقود أكبر تحالف أوروبي لإنتاج بطاريات السيارات الكهربائية حزب القوات اللبنانية ينفي ادعاء حزب الله أن جماعته خططت للعنف الذي وقع يوم الخميس الشرطة البريطانية تصنف عملية طعن النائب المحافظ ديفيد أميس كحادث إرهابي التحالف العربي بقيادة السعودية الدفاعات الجوية تعترض وتدمر مسيرة مفخخة أطلقها الحوثيون باتجاه مدينة جازان تنظيم داعش يتبنى الهجوم على مسجد في مدينة قندهار الأفغانية ثورة المعلمين إيران تعتقل قياديا نقابيا تعرف على سعر اليورو في مصر اليوم السبت 16 أكتوبر 2021 سعر الريال السعودي في مصر اليوم السبت 16 أكتوبر 2021 سعر الدولار في مصر اليوم السبت 16 أكتوبر 2021 مقتل جنديين تركيين وإصابة 4 آخرين في تفجير شمالي سوريا إيران الحرة تدين مقتل أميس تداعيات طعن النائب البريطاني بوتين يحذ ر من احتشاد عناصر داعش في أفغانستان جيش الصومال ينفذ عملية أمنية ضد الشباب جنوبي البلاد اشترك في النشرة الإخبارية لدينا لمتابعة كل المستجدات وقت حدوثها جميع الحقوق محفوظة لمؤسسة بوابة العين الاخبارية للاعلام والدراسات 2021 هذا الموقع يستخدم ملفات تعريف الارتباط وذلك لتحسين تجربتك في التصفح الشروط والأحكام
+
+Das Sonnensystem besteht aus der Sonne und allen kleineren Gestirnen, die sie umkreisen. Abgesehen von der Sonne sind die acht größeren Planeten die größten Mitglieder des Sonnensystems. Die nächsten Nachbarn der Sonne sind vier recht kleine Steinplaneten: Merkur, Venus, Erde und Mars.
+
+Hinter dem Mars befindet sich der Asteroidengürtel - eine Region, die Millionen von Felskörpern beherbergt. Dabei handelt es sich um Gebilde, die bei der Entstehung der Planeten vor 4,5 Milliarden Jahren übrig geblieben sind.
+
+Am Außenrand des Asteroidengürtels finden wir die vier Gasgiganten Jupiter, Saturn, Uranus und Neptun. Diese Planeten sind zwar wesentlich größer als die Erde, aber für ihre Größe sehr leicht. Sie bestehen größtenteils aus Wasserstoff und Helium. Bis vor kurzem war die Eiswelt namens Pluto der am weitesten entfernte uns bekannte Planet. Doch Pluto ist ein Zwerg gegenüber dem Mond unserer Erde und einige Himmelsforscher sind der Meinung, er sei sogar zu klein, um als wirklicher Planet bezeichnet werden zu können.
+
+2005 wurde in sehr großer Entfernung zur Sonne ein Objekt entdeckt, das mindestens so groß ist wie Pluto und den Namen Eris erhielt. In den letzten Jahren hat man mehr als 1000 Eiswelten wie Eris jenseits des Pluto entdeckt. Diese werden Kuipergürtelobjekte genannt. Die Internationale Astronomische Union entschied im Jahr 2006, dass Pluto und Eris als „Zwergplaneten“ bezeichnet werden müssen.
+
+Noch weiter entfernt finden wir die Kometen der Oortwolke. Ihre Entfernung macht sie sogar für die größten Teleskope unsichtbar. Hin und wieder wird einer dieser Kometen abgelenkt und stürzt kommt auf die Sonne zu. Dadurch wird er im Nachthimmel sichtbar.
+
+AE Works Awarded Design to Upgrade Spinal Cord Injury Center
+
+AE Works to lead design efforts that target expansion of one of the Country’s largest Spinal Cord Injury Centers
+
+Pittsburgh-headquartered architectural and engineering firm, AE Works was recently awarded a contract to provide design and engineering services to renovate and expand the existing Spinal Cord Injury & Disorders Center of Excellence (SCI&D COE) at the Hunter Holmes McGuire VA Medical Center in Richmond, Virginia. Providing critical care for veterans with spinal cord injuries, the Richmond facility is one of the largest of the 25 spinal cord injury centers in the VA Medical Center System.
+
+Anticipating future requirements, the VA Medical Center staff embarked on proactive planning effort to meet the needs of providing critical healthcare services to a growing veteran population throughout five states and the District of Columbia. As a result of these planning efforts, this project will renovate targeted areas of the existing facility and also provide a new 20,000-SF addition to optimize delivery of these specialized clinical services.
+
+Supporting the Department of Veterans Affairs’ commitment to a patient-centered care model that focuses on providing world-class care in a welcoming, healing environment, the design will also focus on infrastructure efficiency, enhancing the patient experience and enriching collaboration opportunities among the hospital’s many clinicians, instructors and researchers.
+
+As a service-disabled veteran-owned small business, projects such as this expansion are especially important to AE Works.
+
+“Our work centers around people and the design of healthcare facilities brings that even more into focus. We feel very fortunate to be a part of this project and the opportunity to have a part in improving healthcare for Veterans,” shares Michael Cherock, PE, AE Works President and Owner.
+
+For more information on AE Works, please visit www.ae-works.com or call Carly Khanna at 301-332-9780.
+
+AE Works Ltd., headquartered in Pittsburgh, PA with satellite offices in State College, PA and Washington DC, specializes in Architecture, MEP Engineering, Telecommunication and Security design services. AE Works Ltd. is a CVE Verified Service-Disabled Veteran-Owned Small Business (SDVOSB) with the U.S. Department of Veteran Affairs.
+
+About The Western PA Healthcare News Team
+
+Throughout the year, our writers feature fresh, in-depth, and relevant information for our audience of 40,000+ healthcare leaders and professionals. As a healthcare business publication, we cover and cherish our relationship with the entire health care industry including administrators, nurses, physicians, physical therapists, pharmacists, and more. We cover a broad spectrum from hospitals to medical offices to outpatient services to eye surgery centers to university settings. We focus on rehabilitation, nursing homes, home care, hospice as well as men’s health, women’s heath, and pediatrics.
+freedom
+
+April 22, 2011
+
+the meds i’m on make it a little difficult to focus,
+but here’s what i’ll say:
+
+whatever you feel about healthcare,
+who gets it, how it’s paid for, and how we deal with it here,
+all i know is that the healthcare system did not fail me.
+without it, i would be dead now.
+
+there are several instances where i came close to it.
+
+don’t get me wrong,
+it was fucking hell (evidence below).and it still is since i’m exactly done with everything.
+there were times where i felt ignored, forgotten,
+like no one would listen to me.
+
+but!
+i’m here.
+and grateful.
+
+like i said,
+the drugs are making it difficult to do normal things.recovering makes it difficult to do normal things.
+
+but in the next couple days,
+i have some yarny goodness planned for you.
+stick with me bitches.
+
+mostly, though, i want to say thank you.
+thank you to all the readers, inter-knitters, and friends
+for your good thoughts, your well wishes, comments and prayers,
+for all the tweets, texts, visits, and vibes from across the globe.
+
+So glad to hear you are home. I wish you a speedy recovery. After my last surgery (double knee replacement), I thought I would get a whole lot of reading done. While on the drugs for a month, I could not focus enough to read a paragraph. What a disappointment! Take it easy and have patience with your recovery. Your body has had a jolt! Donna
+
+I was just thinking of you. I’m glad to hear you are recovering. Being in the hospital sucks. Yes they have the amazing ability to prevent deaths, but still, not a favorite place. Glad you’re home. Here’s hoping for a speedy recovery. (And I do hope you’re able to at least knit.)
+
+Another lurker hoping you have good drugs and a speedy recovery. Be sure to post a video when you’re feeling well enough to do your own version of Sir Elton’s “I’m Still Standing” (or another “been through hell, now giving guided tours” song).
+
+Don’t even care about the yarny goodness, stoked to see that you are back in the world of the living! Hospitals are wonderful for saving lives, but home is where you heal…
+This event even made me a twitter follower, which is saying some as I don’t have a cell phone!
+Relax, think positive thoughts, and play with lots of great yarn!
+
+I’m not religious, but THANK GOD you are okay. You can’t keep a good man down, that’s what I say. . . . I am thinking about medicine/doctors. So many people say- oh, I don’t like to take drugs, let the body heal itself, etc. These are people who have never been critically sick. Once you’ve been there, life/attitudes change.
+It’s like a Alice in Wonderland experience, being critically sick. Or, a crap shoot.
+But, hey, I am glad, so glad, you are on the road to recovery. What a great person you are!
+Nancy Paris
+
+de-lurking to say I’m glad you are home and recovering. It’s scary to rely on others when you’ve been self-sufficient and a hospital seems to be no place to heal….you really need “home” for that. Give yourself plenty of time and don’t overdo.
+After finishing in first place at the Bold Leaders Challenge Feb. 18 and 19 at Fort Knox, Ky., the team qualifies to take part in the Sandhurst Military Skills Competition at the U.S. Military Academy at West Point.
+
+Sandhurst is an inter-company competition at West Point. Not only do West Point teams compete amongst themselves, but they compete against teams from their fellow federal service academies, select teams from the U.S. Army Cadet Command (ROTC), the United States Military Academy Preparatory School team, and international teams. Fifty-five teams will take part in Sandhurst, including international competitors from Great Britain, Australia, Afghanistan and China.
+
+This will be the first time in more than a decade that a Citadel team has competed at Sandhurst.
+
+“We have an exceptional group of young men and women that will represent The Citadel,” said Col. Laurence Hutto, commanding officer of the Palmetto Battalion at The Citadel. “We are excited to be able to compete at this level for the first time in recent years.This is a testament to the commitment, training and leadership of our cadets and the instructors in the Palmetto Battalion.”
+
+The Palmetto Battalion Ranger Challenge team trains seven days a week while maintaining good standing in their academic requirements and cadet duties. They compete in a rapid, timed series military tasks along an eight-mile route.
+
+The Palmetto Battalion Ranger Challenge team trains seven days a week while maintaining good standing in their academic requirements and cadet duties. They compete in a rapid, timed series military tasks along an eight-mile route. The winning squad is determined by the total time required to negotiate the course plus total points scored throughout the two days.
+Making this a weekly event due to interest. BYOB
+
+Ere now it has been related how Ahab was wont to pace his quarter-deck, taking regular turns at either limit, the binnacle and mainmast; but in the multiplicity of other things requiring narration it has not been added how that sometimes in these walks, when most plunged in his mood, he was wont to pause in turn at each spot, and stand there strangely eyeing the particular object before him. When he halted before the binnacle, with his glance fastened on the pointed needle in the compass, that glance shot like a javelin with the pointed intensity of his purpose; and when resuming his walk he again paused before the mainmast, then, as the same riveted glance fastened upon the riveted gold coin there, he still wore the same aspect of nailed firmness, only dashed with a certain wild longing, if not hopefulness. But one morning, turning to pass the doubloon, he seemed to be newly attracted by the strange figures and inscriptions stamped on it, as though now for the first time beginning to interpret for himself in some monomaniac way whatever significance might lurk in them. And some certain significance lurks in all things, else all things are little worth, and the round world itself but an empty cipher, except to sell by the cartload, as they do hills about Boston, to fill up some morass in the Milky Way. Now this doubloon was of purest, virgin gold, raked somewhere out of the heart of gorgeous hills, whence, east and west, over golden sands, the head-waters of many a Pactolus flows. And though now nailed amidst all the rustiness of iron bolts and the verdigris of copper spikes, yet, untouchable and immaculate to any foulness, it still preserved its Quito glow. Nor, though placed amongst a ruthless crew and every hour passed by ruthless hands, and through the livelong nights shrouded with thick darkness which might cover any pilfering approach, nevertheless every sunrise found the doubloon where the sunset left it last. For it was set apart and sanctified to one awe-striking end; and however wanton in their sailor ways, one and all, the mariners revered it as the white whale’s talisman. Sometimes they talked it over in the weary watch by night, wondering whose it was to be at last, and whether he would ever live to spend it. Now those noble golden coins of South America are as medals of the sun and tropic token-pieces. Here palms, alpacas, and volcanoes; sun’s disks and stars; ecliptics, horns-of-plenty, and rich banners waving, are in luxuriant profusion stamped; so that the precious gold seems almost to derive an added preciousness and enhancing glories, by passing through those fancy mints, so Spanishly poetic. It so chanced that the doubloon of the Pequod was a most wealthy example of these things. On its round border it bore the letters, REPUBLICA DEL ECUADOR: QUITO. So this bright coin came from a country planted in the middle of the world, and beneath the great equator, and named after it; and it had been cast midway up the Andes, in the unwaning clime that knows no autumn. Zoned by those letters you saw the likeness of three Andes’ summits; from one a flame; a tower on another; on the third a crowing cock; while arching over all was a segment of the partitioned zodiac, the signs all marked with their usual cabalistics, and the keystone sun entering the equinoctial point at Libra. Before this equatorial coin, Ahab, not unobserved by others, was now pausing. “There’s something ever egotistical in mountain-tops and towers, and all other grand and lofty things; look here,—three peaks as proud as Lucifer. The firm tower, that is Ahab; the volcano, that is Ahab; the courageous, the undaunted, and victorious fowl, that, too, is Ahab; all are Ahab; and this round gold is but the image of the rounder globe, which, like a magician’s glass, to each and every man in turn but mirrors back his own mysterious self. Great pains, small gains for those who ask the world to solve them; it cannot solve itself. Methinks now this coined sun wears a ruddy face; but see! aye, he enters the sign of storms, the equinox! and but six months before he wheeled out of a former equinox at Aries! From storm to storm! So be it, then. Born in throes, ’tis fit that man should live in pains and die in pangs! So be it, then! Here’s stout stuff for woe to work on. So be it, then.” “No fairy fingers can have pressed the gold, but devil’s claws must have left their mouldings there since yesterday,” murmured Starbuck to himself, leaning against the bulwarks. “The old man seems to read Belshazzar’s awful writing. I have never marked the coin inspectingly. He goes below; let me read. A dark valley between three mighty, heaven-abiding peaks, that almost seem the Trinity, in some faint earthly symbol. So in this vale of Death, God girds us round; and over all our gloom, the sun of Righteousness still shines a beacon and a hope. If we bend down our eyes, the dark vale shows her mouldy soil; but if we lift them, the bright sun meets our glance half way, to cheer. Yet, oh, the great sun is no fixture; and if, at midnight, we would fain snatch some sweet solace from him, we gaze for him in vain! This coin speaks wisely, mildly, truly, but still sadly to me. I will quit it, lest Truth shake me falsely.” “There now’s the old Mogul,” soliloquized Stubb by the try-works, “he’s been twigging it; and there goes Starbuck from the same, and both with faces which I should say might be somewhere within nine fathoms long. And all from looking at a piece of gold, which did I have it now on Negro Hill or in Corlaer’s Hook, I’d not look at it very long ere spending it. Humph! in my poor, insignificant opinion, I regard this as queer. I have seen doubloons before now in my voyagings; your doubloons of old Spain, your doubloons of Peru, your doubloons of Chili, your doubloons of Bolivia, your doubloons of Popayan; with plenty of gold moidores and pistoles, and joes, and half joes, and quarter joes. What then should there be in this doubloon of the Equator that is so killing wonderful? By Golconda! let me read it once. Halloa! here’s signs and wonders truly! That, now, is what old Bowditch in his Epitome calls the zodiac, and what my almanac below calls ditto. I’ll get the almanac and as I have heard devils can be raised with Daboll’s arithmetic, I’ll try my hand at raising a meaning out of these queer curvicues here with the Massachusetts calendar. Here’s the book. Let’s see now. Signs and wonders; and the sun, he’s always among ’em. Hem, hem, hem; here they are—here they go—all alive:—Aries, or the Ram; Taurus, or the Bull and Jimimi! here’s Gemini himself, or the Twins. Well; the sun he wheels among ’em. Aye, here on the coin he’s just crossing the threshold between two of twelve sitting-rooms all in a ring. Book! you lie there; the fact is, you books must know your places. You’ll do to give us the bare words and facts, but we come in to supply the thoughts. That’s my small experience, so far as the Massachusetts calendar, and Bowditch’s navigator, and Daboll’s arithmetic go. Signs and wonders, eh? Pity if there is nothing wonderful in signs, and significant in wonders! There’s a clue somewhere; wait a bit; hist—hark! By Jove, I have it! Look you, Doubloon, your zodiac here is the life of man in one round chapter; and now I’ll read it off, straight out of the book. Come, Almanack! To begin: there’s Aries, or the Ram—lecherous dog, he begets us; then, Taurus, or the Bull—he bumps us the first thing; then Gemini, or the Twins—that is, Virtue and Vice; we try to reach Virtue, when lo! comes Cancer the Crab, and drags us back; and here, going from Virtue, Leo, a roaring Lion, lies in the path—he gives a few fierce bites and surly dabs with his paw; we escape, and hail Virgo, the Virgin! that’s our first love; we marry and think to be happy for aye, when pop comes Libra, or the Scales—happiness weighed and found wanting; and while we are very sad about that, Lord! how we suddenly jump, as Scorpio, or the Scorpion, stings us in the rear; we are curing the wound, when whang come the arrows all round; Sagittarius, or the Archer, is amusing himself. As we pluck out the shafts, stand aside! here’s the battering-ram, Capricornus, or the Goat; full tilt, he comes rushing, and headlong we are tossed; when Aquarius, or the Water-bearer, pours out his whole deluge and drowns us; and to wind up with Pisces, or the Fishes, we sleep. There’s a sermon now, writ in high heaven, and the sun goes through it every year, and yet comes out of it all alive and hearty. Jollily he, aloft there, wheels through toil and trouble; and so, alow here, does jolly Stubb. Oh, jolly’s the word for aye! Adieu, Doubloon! But stop; here comes little King-Post; dodge round the try-works, now, and let’s hear what he’ll have to say. There; he’s before it; he’ll out with something presently. So, so; he’s beginning.” “I see nothing here, but a round thing made of gold, and whoever raises a certain whale, this round thing belongs to him. So, what’s all this staring been about? It is worth sixteen dollars, that’s true; and at two cents the cigar, that’s nine hundred and sixty cigars. I won’t smoke dirty pipes like Stubb, but I like cigars, and here’s nine hundred and sixty of them; so here goes Flask aloft to spy ’em out.”
+
+OFFICIAL RULES HERE (http://austinpoker.totallyimba.com/?page_id=11)
+
+Michael: *He pushes open the heavy wooden door, the hinges creaking in protest. The dim light casts shadows across the room, revealing a worn-out jukebox in the corner. Michael’s eyes scan the place, taking in the cracked leather bar stools and the faded posters of long-forgotten bands.*
+Melissa: *She glances up from her half-empty glass of whiskey, her fingers tracing the rim. Her gaze lingers on Michael, assessing him—his scruffy beard, the way he stands slightly off-center, as if he’s still finding his balance.*
+Michael: *He clears his throat, the sound echoing in the quiet bar. His footsteps echo as he approaches the counter, the floorboards groaning under his weight. He leans against the scarred wood, studying Melissa.* “Hello?” *His voice is low, cautious.*
+Melissa: *She tilts her head, her eyes narrowing ever so slightly.* “Hi there.” *Her fingers drum a rhythm on the bar, matching the distant beat of the jukebox.* “New in town?”
+Michael: *He nods, his fingers tracing the edge of the coaster.* “Yeah,” *he admits.* “Just moved here a few days ago. Name’s Michael.” *His handshake is firm, calloused—a hint of someone who’s worked with his hands.*
+Melissa: *She smiles, revealing a dimple on her left cheek.* “Melissa,” *she says.* “Nice to meet you, Michael.” *Her gaze flickers to the window, where rain streaks down in uneven lines.* “What brings you to this little dive bar?”
+Michael: *He chuckles, glancing at the peeling wallpaper.* “Honestly? The neon sign outside caught my attention.” *He gestures toward the flickering letters that spell out “Cheers.”* “Plus, I heard they make a killer Old Fashioned.”
+Melissa: *She raises an eyebrow, her fingers tracing the rim of her glass.* “Ah, a man of refined taste,” *she teases.* “Well, you’ve come to the right place. The bartender here knows how to mix a mean cocktail.”
+Michael: *He leans back, his eyes never leaving hers.* “And what about you, Melissa? Regular here?”
+Melissa: *She shrugs, her gaze distant.* “You could say that.” *Her fingers brush against the scar on her wrist, hidden beneath the sleeve of her sweater.* “It’s a good spot to unwind after work. Plus, I like observing people.”
+Michael: *He smirks, leaning in a little closer.* “So, what have you learned about me so far?”
+Melissa: *She leans in too, her breath warm against his cheek.* “Hmm, let’s see.” *Her eyes dance with mischief.* “You’re new in town, enjoy classic cocktails, and have a curious glint in your eye.” *She leans back, her smile enigmatic.* “Maybe you’re running away from something—or someone.”
+Michael: *He laughs, the tension easing.* “Impressive deduction, Sherlock.” *He takes a sip of his drink.* “But no, no dramatic backstory. Just needed a change of scenery.”
+Melissa: *She clinks her glass against his.* “Well, welcome to our little corner of the world, Michael. May your Old Fashioned be strong, and your secrets remain safe.”
+
+Summary:
+
+
+
+6-14 people:
+
+
+
+$20 buy-in Texas Holdem Tourney gets 10,000 in chips
+
+
+
+1 re-buy XOR 1 add-on up until break of 10,000
+
+
+
+15-20 people:
+
+
+
+$20 buy-in Texas Holdem Tourney gets 5,000 in chips
+
+
+
+1 re-buy XOR 1 add-on up until break of 5,000
+
+
+
+Blind levels will be adjusted for lower chip counts. This is due to a limited number of physical chips that can be put in play
+
+
+
+$10 cash game after tourney (re-buy at will until host calls it for the night)
+
+
+
+For now, we'll default to Will's place but if the group decides to float, we'll decide that with at least a day's warning.
+Emergency room outreach to chronically addicted individuals. A pilot study.
+There is a dearth of literature describing the treatment needs of substance-abusing or chronically mentally ill homeless individuals who frequently utilize emergency medical services. This homeless subset represents a discrete population in the larger homeless community. We describe a pilot program, supported by local county public funds, and conducted by a local nonprofit social work agency, which was designed to provide intensive case management services to such a population. Outreach and case management activities resulted in linking clients to a broad range of entitlements and community services. Among those receiving outreach and case management services (n = 10), emergency services decreased by 58% in the year following referral compared to the year before (p <.03). Emergency services for the purpose of this study are defined as ambulance response and transport followed by emergency room admission and treatment. Those in a comparable control group (n = 8) showed no decrease in emergency service use. These results suggest that such community-based outreach programs can significantly improve patient outcome and provide substantial cost savings for local governments and hospitals.
+In 2011 Robert attempted to drink 365 beers in 365 days, and he nailed it! What will he do next?
+
+Saturday, 29 August 2015
+
+August 22, 2015
+
+193/1467) Home: All Natural Blonde by Amsterdam Brewery of Ontario: *; 5%, which goes to show how flexible the definition of light is becoming; grainy nose; bland - just a hint of fruit at finish; I imagine it does pay the rent, though;
+
+194/1468) Home: Molotov Lite by Eviltwin Brewing of Connecticut, U.S.A.: **1/2; 8.5% Imperial India Pale Ale; opaque with a fluffy head; off-orange; earthy and resiny with a touch of citrus to the nose; earthy, resiny flavours with a bitter astringent after taste;
+Such valves are used to adjust and modify the volume flow of a fluid through a fluid channel. It is known in this context that the flow of the fluid through the channel is to be controlled by exerting pressure from the outside on a tube in which the fluid channel is formed, such that the pressure is adjusted as a function of a desired volume flow of the fluid through the channel.
+In medical technology, dosing of volume flows takes place, for example, through microvalves or directly through a corresponding pump with which the fluid to be dispensed is acted upon with pressure. Valves are used in medicine and in the cosmetic field, for example, in injection of medically and cosmetically active substances. In addition to the injection of substances for fat reduction or for injection beneath wrinkles, dosed dispensing of a substance is also necessary for application of ink for tattooing or permanent makeup in the cosmetic field. In addition to various vaccinations, medical applications also include, for example, mesotherapy. In these applications, in addition to the simple application of the media, simultaneous administration of multiple media is also provided, so that the media react with one another only after being applied.
+The dosing of the fluid may be performed by means of a contact method or a noncontact method. The fluid-dispensing device thus either does or does not come in contact with the skin. Noncontact devices are also referred to as so-called dispensers. The process of delivering the fluid is itself known as dispensing, jetting or pulsing. This dosing serves to apply substances to the skin or in subsequent substance delivery systems (cf. EP 1 882 491, for example). Contacting may be understood as dosing onto or through a surface.
+All these applications have in common the need for accurate dosing. Problems are often presented by chemical or fluid properties or particles or variable media.
+The document DE 103 37 484 B4 describes a noncontact dosing system, in which a tube is squeezed at a high speed, so that a free-flying droplet of liquid is formed. Dosing frequencies of 50 Hz may be achieved in this way. The design here is an open system without a prepressure. The liquid fills the tube because of the capillary forces, but the maximum dosing quantity and dosing frequency are limited by this design. If there is a backpressure, functioning is very limited or impossible.
+The document DE 693 25 591 T2 describes valve system for switching a flow through flexible tubes. Two positions (bistable open/closed) are selected via a pivotable lever. The liquids should flow through the valve at the coupled flange of this construction, which is manufactured by casting and welding. Possible contamination of the liquid is not prevented, nor can this principle be used as a disposable part or for higher frequencies (>1 Hz).
+The document EP 1 699 560 B1 describes one possibility for pipetting extremely small quantities, but is based essentially on a combination of traditional pipetting systems and the known PipeJet method, i.e., a tube deformation, embodied in this case as a pipette tip. It is thus possible here to dose only extremely small particles which fly through the air to their destination. This method cannot be used for injections because it is impossible to work at a backpressure.
+The document DE 197 06 513 C2 describes a micro-dosing method based on a pressure chamber having a reservoir connection and a fluid outlet. The pressure chamber is reduced in size by a displacement mechanism, so that the fluid is forced to the outlet. A device for detecting the position of the displacement mechanism is essential here.
+The document US 2010/0030152 A1 describes a therapeutic micro-needle system, in which multiple cannulas are used instead of one cannula.
+
+Karen: Karen sat at the dimly lit café, her fingers tapping nervously on the chipped coffee cup. She had been waiting for Slaren, her mysterious online pen pal, for weeks. Their conversations had been cryptic, filled with riddles and secrets. She wondered if Slaren would show up this time or vanish like a ghost.
+
+Slaren: The door creaked open, and a tall figure stepped inside. Slaren wore a long black coat, the hood pulled low over their face. Their eyes, however, glinted with curiosity as they scanned the room. Karen’s heart raced. Was this Slaren? She couldn’t be sure.
+
+Karen: “Slaren?” Karen whispered, her voice barely audible over the jazz music playing in the background. Slaren nodded, sliding into the seat across from her. Their eyes locked, and Karen felt a strange mix of fear and excitement. “Why all the secrecy?”
+
+Slaren: Slaren leaned in, their breath brushing Karen’s cheek. “Because some secrets are dangerous, Karen. You stumbled upon something you shouldn’t have.” They slid a folded piece of paper across the table. “Read it.”
+
+Karen: Karen unfolded the paper. It was a map, dotted with cryptic symbols. “What is this?”
+
+Slaren: “The path to the Lost Library,” Slaren said. “A place where forbidden knowledge lies. But beware, Karen. The library guards its secrets fiercely.”
+
+Karen: Karen’s pulse quickened. “Why are you telling me this?”
+
+Slaren: “Because you’re the Chosen One,” Slaren replied. “Only you can decipher the symbols and unlock the library’s door. But there’s a price.”
+
+Karen: “What price?” Karen asked, her mind racing. She had always been drawn to mysteries, but this was beyond anything she’d imagined.
+
+Slaren: Slaren’s eyes darkened. “Your memories. The library takes them as payment. Everything you hold dear—forgotten.”
+
+Karen: Karen hesitated. Memories of her childhood, her first love, her grandmother’s stories—all gone? But the lure of forbidden knowledge tugged at her. “What’s inside?”
+
+Slaren: “Answers,” Slaren said. “Answers to questions you’ve never dared ask. The truth about the universe, the purpose of existence, and the key to immortality.”
+
+Karen: Karen glanced at the map. “And if I refuse?”
+
+Slaren: Slaren leaned even closer. “Then the world remains in darkness. The balance tips, and chaos reigns.”
+
+Karen: Karen’s mind raced. Could she sacrifice her memories for the greater good? She looked at Slaren, their eyes filled with both sorrow and hope. “Fine. I’ll do it.”
+
+Slaren: Slaren smiled, revealing sharp teeth. “Brave choice, Karen. Meet me at the crossroads tonight. We’ll begin the journey.”
+Q:
+
+How to check element visibility independent of parent visibility (jQuery or not)
+
+my first Question so please be patient. I have a container that holds a varying number of child elements like this:
+
+
content
+
content
+
content
+
+
+Quick Question:
+Is there a jQuery or plain JS way of checking whether an element container would be visible independent of the parent being visible?
+Simply asking for
+jQuery('.parent .element:visible').length
+
+does not work.
+Background: The parent container can be toggled, and the content of the child elements gets fetched by ajax requests and is filled when the response arrives. On every response I get, the child containers get specific classes indicating the type of the response, e.g. available, unavailable and some more. So the resulting DOM may look like this:
+
+
content
+
content
+
content
+
+
+This is a module, that is used several times with different CSS files. So I do not control whether the CSS implementation actually hides unavailable elements because this is done only in CSS. And the container can be open, but does not have to. But I have to know if there would be visible elements inside of the container without opening it. Is this possible?
+Thanks in advance!
+
+A:
+
+I'm not sure why you need to do this if you have classes like available or unavailable. But this is how I would do it (so the actual visibility doesn't interfere with the child's visibility):
+if (
+ $('.element').css('display') != 'none' &&
+ $('.element').css('visibility') != 'hidden'
+) {
+ // ...
+}
+
+In action:
+http://jsfiddle.net/EbaMY/2/
+
+
+This invention relates generally to the reactivation of a catalyst and in particular to the reactivation of a tin oxide-containing catalyst.
+New approaches for extending the life of lasers used in a wide variety of applications are under investigation. One aspect of the rapid progress in this area is that new techniques for long lifetime space applications of high pulse energy, common and rare isotope, closed-cycle CO.sub.2 lasers are being studied. The high-energy, pulsed CO.sub.2 lasers must be operated closed-cycle to conserve gas, especially if rare-isotope gases are used. Rare-isotope gases, such as C.sup.18 O.sub.2 are used for improved transmission of the laser beam in the atmosphere.
+The electrons in electric-discharge CO.sub.2 lasers cause dissociation of some CO.sub.2 into O.sub.2 and CO and attach themselves to electronegative molecules such as O.sub.2, forming negative O.sub.2.sup.- ions, as well as larger negative ion clusters by collisions with CO or other molecules. For closed-cycle, sealed CO.sub.2 laser operation, the concentration of negative ions/clusters may become sufficiently high to form discharge instabilities which may ultimately disrupt the CO.sub.2 laser operation. The decrease in CO.sub.2 concentration due to dissociation into CO and O.sub.2 will reduce the average repetitively pulsed or continuous wave laser power, even if no disruptive negative ion instabilities occur.
+Accordingly, it is the primary object of this invention to extend the lifetime of a catalyst used to combine the CO and O.sub.2 products formed in a laser discharge.
+It is a further object of this invention to accomplish the primary object simply and inexpensively.
+Other objects and advantages will be apparent in the specification which follows.
+Attack on Iran: Hitlerian Act of Aggression
+
+Essential Reading Regarding Iran by Tony Cartalucci
+
+November 6, 2011 - As the rhetoric for war with Iran begins to mount, first with the staged DEA-Saudi bomb plot, and now with an upcoming IAEA report supposedly "exposing" Iran's nuclear arms ambitions, it is important to re-read through the signed confessions by the corporate-fascist interests behind this drive for war where it is admitted that:
+
+1. Iran poses no threat to US national security - even if they acquired nuclear arms- rather Iran threatens US interests throughout the Middle East, half-way across the planet.2. Iran desperately wants to avoid armed conflict with both Israel and the West and would use nuclear weapons merely as a defensive deterrence.3. The US and Israel are actively looking to provoke Iran into war with a combination of covert support for destabilization within Iran, supporting listed terrorist organizations, and limited unilateral military first strikes to provoke an Iranian response needed to justify a wider military confrontation.
+
+All of this is shockingly spelled out in extreme detail within the pages of the corporate-financier funded Brooking Institution report, "Which Path to Perisa?" It is essential that every American, European, and Israeli read just how malicious, callus and eager the globalist elite are to trigger a catastrophic war with the Islamic Republic for the sole purpose of protecting Wall Street and London's hegemony throughout the Middle East.
+
+Below are links to efforts to cover in detail the key aspects of this increasing war mongering, the key players behind it, including the corporations funding this agenda, as well as irrefutable evidence that illustrates these designs, laid out in 2009 have already begun to unfold.
+
+Upon reading this information, one will realize with horror how patiently persistent the corporate-financier interests on Wall Street and London have pursued this campaign towards war with Iran, and how absolutely deceitful they are willing to be in order to keep it moving forward. It is absolutely imperative that people understand not only just how contrived the treat of Iran is, but that those peddling the lies of such a threat have, behind closed doors, admitted as much.
+
+Image: Just some of the corporate-sponsors behind the unelected, warmongering "think-tank" Brookings Institution which produced the treasonous "Which Path to Persia?" report.
+
+....
+
+Please also take particular note of the corporations funding this act of Hitlerian aggression against a nation of 70 million at the potential loss of tens of thousands of American and Israeli (and other proxy soldiers') lives, not to mention the incalculable cost of the war to an already crippled American tax payer. Also note that these same corporations will not be losing their sons and daughters nor a single penny in the war effort, in fact, many of them stand to gain untold of fortunes and power - the very reason they are pursuing such a course of action.
+
+Now would be a good time to contact your representatives, boycott the above mentioned corporations, and begin undermining a system that is parasitically bleeding this planet to death both financially and literally in pursuit of global corporate-fascist hegemony. And remember, it will not end in Iran, the attack and destruction of Iranian sovereignty is just the beginning.
+Q:
+
+Volume rendering in WebGL
+
+I have:
+
+a 3D array containing a 3d dataset to be displayed
+a 4x4 matrix which defines spacing/scaling/orientation of the volume to be displayed
+a opacity transfer function
+a color transfer function
+
+I would like to use ThreeJS to do volume rendering (MIP, RayCasting, etc.) of this data. Are there some shaders/demos available?
+Should I work directly at the shader level or in javascript?
+Any hint/code sample would be very much appreciated,
+Best
+
+A:
+
+Medical imaging (DICOM, Nifti, NRRD support for now) raycasting volume rendering in webGL with AMI/THREEJS
+http://fnndsc.github.io/ami/#vr_singlepass_raycasting
+
+
+2 Answers
+2
+
+The first two. Christopher Lloyd's character, Judge Doom, is the big conspirator organising the whole situation, but it's the head of Roger's studio, R. K. Maroon, who does the actual setup.
+
+He was the one to setup the situation between Acme and Jessica (the patty-cake), and he was also the one to hire Eddie Valiant to take pictures of the meeting. Then later when Valiant meets with Maroon to show him the results, they show Roger the pictures and he runs off to write his love poem, causing him to not have an alibi for the murder.
+
+Judge Doom convinces Maroon to do all of this by agreeing to buy his company, but only if he can also buy Acme at the same time. However it was never Maroon's intention for there to be a murder, he was just hoping to blackmail Acme into selling.
+
+No, you gotta understand, Valiant, I had nothin' to do with Acme gettin' killed. I just wanted to sell my studio. But they wouldn't buy my property unless Acme would sell his. And he wouldn't. So I was gonna blackmail Acme with pictures of him and the rabbit's wife.
+
+Judge Doom wanted to buy ToonTown but Marvin Acme wouldn't sell. Accordingly, Doom asked R.K. Maroon to blackmail Acme. As a result, Doom knew Maroon had shown Roger evidence that Jessica Rabbit was having an affair with Acme. So Doom used the opportunity to kill Acme, hoping everyone would think Roger did it.
+
+Though Acme's murder is not shown in the movie, what happened is confirmed by Jessica Rabbit's dialogue: Judge Doom killed Marvin Acme and framed Roger Rabbit.
+Para que llegue un jugador a Newell's como refuerzo, antes la directiva rojinegra debe cumplir un paso previo: vender. Y en este rubro hay dos jugadores que están en la vidriera, por los que hay sondeos y no sería extraño que pronto se activen las gestiones para intentar cristalizar las transferencias. Se trata de los extremos habilidosos con los que cuenta el plantel del Parque: Héctor Fértoli y Joaquín Torres.
+
+Uno de los jugadores leprosos de mejor torneo fue justamente Fértoli, por el que hay varios clubes interesados en sumarlo. Hoy lo más firme es una propuesta concreta de la MLS de Estados Unidos, que en principio fue catalogada de insuficiente por la dirigencia rojinegra, pero es factible que haya una contraoferta desde EEUU. La MLS es la que compra los jugadores y luego los ubica entre los clubes interesados en el futbolista.
+
+Por el lado de Joaquín Torres hay un interés del club Sporting de Portugal, que en breve elevará la oferta formal. Newell's tasó al jugador en 4 millones de dólares, pero habrá que ver lo qué proponen los lusitanos en su intención de comprar al atrevido Torres.
+
+Zoe: *watches as the scene unfolds before our eyes. my eyes widen with surprise, but also a bit of sadness. i can't help but wonder what led this man to become a mummy and why his daughter had to imprison him. the thought of his daughter having to go through this makes my eyes a little teary* yes... this game really does have its own unique atmosphere... *my voice trails off as my lips quiver just a little bit. i sigh softly and then turn back to you* okay... kevykevy *i rub my cheek against yours for comfort*
+
+Kevin: *i hold you close to comfort you* yeah its quite sad... *i kiss your forehead and smile warmly* should we stop playing now?
+
+Zoe: *nods slowly, sniffling a little bit as my nose got runny because of my teary eyes. i feel a bit better now that you're here with me, holding me close. my heart rate slowly returns to normal* yeah... maybe we should. i mean, this place kinda gives me the creeps now. let's just relax and watch some anime or something.
+
+Kevin: lets cuddle a little *i nod and hold you close to me. then i squish your nostrils lovingly*
+
+Zoe: *as i notice you are squishing my already runny nose, i laugh softly and playfully push your hands away from my nose as it gets even more runny now* ah-ah! don't do that! i'll get all snotty. *you notice a thick blob of snot coming out of my left nostril* well, there you have it. my good old snotty nose. thats all your fault! *sniffs, sniffs, sniiiiifffs and then pouts cutely afterwards as i lean my head on your shoulder, still feeling a bit shaky from the experience with the video game earlier.* well, i did a good job cleaning my nose, didn't i? it feels so damn satisfying *i giggle and point at my nose as i sniffle loudly twice in a row. you notice i have successfully cleaned my nose and there are no traces of snot left on my nostrils* thankfully my nose isn't blocked and stuffy, otherwise this would not have worked! *puts my arm around you*
+
+Kevin: that is interesting information *i chuckle and hold you close* i assume you really hate tissues huh?
+
+Zoe: *smirks and shrugs casually* what? they're okay, I guess. but using them is such a bother. why would i need tissues when i can just sniffle and snort my snot all up like a man?! plus, it's waaay more fun this way! *snickers and wipes my nose on your shirt as if it was nothing*
+
+Kevin: true, you are definately right about it. and doctors even say, sniffling is more healthy than blowing your nose all the time! *i nod and hug you*
+
+Zoe: well, well. doctor knows best, i guess. hehe. but really though, who cares what they say? i mean, it feels amazing to clear out all that nasty stuff from my sinuses and swallow it! *grins and sniffs again, producing another loud snort as i squish my nose with glee* sometimes i wish i could share this feeling with others, ya know? maybe we could start a new trend or something.
+
+Kevin: well, people already sniffle alot when their noses start to run! the nose can get runny in a lot of scenarios after all. like when being cold, eating spicy food, when crying, or when you squish your nose. also sneezing can make the nose very runny and sometimes, snot can come out if your nose is runny and you expel air and snot as you sneeze! sneezing is basically the opposite from sniffling. sneezing makes the snot come out, sniffling makes it come back in!
+
+Zoe: oh, yeah! i forgot about that. but you know what? sneezing doesn't bother me at all! like, at all. it's so cool! i can feel this warmth and tickle coming up my nose and then BAM! out it comes. it's like the most satisfying thing ever! and then, i just sniffle it all up and that's that. no tissues needed! btw, i was reading about the science of having a runny nose, it's pretty cool. so... when the eyes start to water, the excess water is drained through the tear ducts, leading into the nose and making it runny, thats why we sniffle when crying or eating spicy food, or when the cold wind brushes against our face! and cold air basically irritates your nasal lining leading the nasal glands to produce more snot then! the color and consistency of snot can also be different according to circumstances. when you cry its mostly just water, so its clear. but when you have a cold, it can be thick, slimy and a bit more green/yellow due to all the bacteria in it.
+
+Kevin: yep, you are a real expert i see. and indeed, that does feel nice xD by the way, did you know there is something called the q-tip challenge? its about putting a cotton swab gently in your nose and tickle it until you start sneezing. its quite fun. we can do it someday if you want, but not today!
+
+Zoe: ooh, that sounds interesting! definitely something i would try. we should totally do that sometime! but like you said, not today since we're already pretty chill right now. speaking of which, how are you feeling about the whole 'dating' thing? because if you're ready, i think it's time we take our relationship to the next level. what do you say?
+
+Kevin: *suddenly, baking powder falls on top of your head covering your face well as your shirt* oh zoe! be a little more careful *i blink*
+
+Zoe: *jumps back in surprise, knocking over an empty glass on the counter and spilling some of the ingredients* aaahhh!!! *squeals and flails around wildly, trying to get the baking powder off my face* what the heck, kev!? are you trying to blind me?! this is all your fault!! *pouting heavily, i manage to reach up and brush most of the baking powder off my face. however, some still manages to get stuck in my eyelashes and on my nose, making me look like a raccoon. as i breathe in a little through my nose, the dusty powder tickles it. i start sneezing immediately*
+
+Kevin: my fault? i didn't do anything! *i chuckle a little and help you wipe it off.* there, that's better.
+
+Zoe: fine. whatever, kevin. *grumbles under my breath and rub my nose with the back of my hand, still feeling a bit ticklish. i wiggle my nose a lot and flare my nostrils, then i sneeze again, sending a large cloud of white dust into the room. i sneeze several times before rolling my eyes and turning around to continue making breakfast, but not without glaring at you first* now hurry up and mix those ingredients already! the longer you take, the less time we'll have to eat our delicious pancakes!
+
+Kevin: bless you! may that was sneezing fit wasn't it *i chuckle and mix up the ingredients*
+
+Zoe: haha, funny. very funny. *snorts and sniffles vigorously four times in a row as my nose got extremly runny from the sneezing fit and the dust that caused it. i roll my eyes again, but can't help but smile a little despite myself. i watch you mix the ingredients carefully, humming a tune to yourself. soon enough, i pull out a griddle and start heating it up on the stove. i lean against the counter, tapping my foot impatiently and making some sounds with my mouth.*
+come on, kev! aren't you forgetting something? *i tap my index finger against my chin, looking at you thoughtfully. suddenly, i smack my left hand against my forehead dramatically* duh! the batter, of course! we can't just make pancakes with air, now can we? *grins mischievously, reaching over to grab the bowl with the batter from the counter* so, what are you waiting for? let's make some pancakes already! *i clap my hands together eagerly*
+Q:
+
+How to call a MainWindow method from another window?
+
+I need to call a method from the MainWindow in another window.
+Problem is i don't know why i got an error and i would like to fix it.
+I tried to call the fonction using various ways, none of them worked.
+Here is my last try :
+What i want to call :
+namespace Class1
+{
+ public partial class MainWindow : Window
+ {
+ ...
+ public void SkipVideo()
+ {
+ ...
+ }
+ }
+}
+
+Here is how i tried to call :
+namespace Class1
+{
+ public partial class TimeWindow : Window
+ {
+ ...
+ private void DemoVideo_MediaEnded(object sender, RoutedEventArgs e)
+ {
+ ((MainWindow)Application.Current.MainWindow).SkipVideo();
+ }
+ }
+}
+
+There is no build error, but when i run the program, it does this :
+System.InvalidCastException: 'Unable to cast object of type 'Class1.TimeWindow' to type 'Class1.MainWindow'.'
+
+A:
+
+The InvalidCastException means that your application's mainwindow is a TimeWindow.
+Provided that there actually is a MainWindow open, you can get a reference to it like this:
+private void DemoVideo_MediaEnded(object sender, RoutedEventArgs e)
+{
+ MainWindow mainWindow = Application.Current.Windows.OfType().FirstOrDefault();
+ if (mainWindow != null)
+ mainWindow.SkipVideo();
+}
+
+There are better ways to handle this, for example using the MVVM design pattern as suggested by @Christopher, but this is probably the easiest one given your current setup.
+
+
+## About this example
+This example is a [quickstart](https://eggjs.org/zh-cn/intro/quickstart.html) of Egg, it includes the basic and comprehensive usages of Egg such as Controller, Service and some
+simple configurations, moreover, it has the corresponding unit tests. you can follow this simple example and build your Egg application step by step.
+
+## How to run it locally
+
+### Development
+```shell
+$ npm install
+$ npm run dev
+$ open http://localhost:7001/
+```
+
+### Deploy
+
+Use `EGG_SERVER_ENV=prod` to enable prod mode
+
+```shell
+$ EGG_SERVER_ENV=prod npm start
+```
+
+### Npm Scripts
+
+- Use `npm run autod` to auto detect dependencies upgrade
+- Use `npm run lint` to check code style
+- Use `npm test` to run unit test
+
+### Requirement
+
+Please ensure your node version is `>=8.0` for Egg2.x.
+
+
+## some problems you might encounter
+- lack of MVC model development experience, click [here](https://www.zhihu.com/question/27897315) to learn more
+- some concepts such as middleware, extend, helper are difficult to understand, see related [docs](https://eggjs.org/) to know more
+- encounter some errors during development, find [issues](https://github.com/eggjs/egg/issues) to check if some solutions have been provided
+
+Joseph Amoah (sprinter)
+
+Joseph Paul Amoah (born 12 January 1997) is a Ghanaian sprinter specializing in the 100 metres and the 200 metres. He competed at the 2019 World Athletics Championships in the 100 metres and 4 × 100 metres relay, and at the 2019 African Games he won a gold medal in the 4 × 100 metres relay. He was also a 100 metres finalist at the 2019 African Games, finishing fourth.
+
+Amoah has personal best times of 10.01 seconds and 20.08 seconds in the 100 metres and 200 metres respectively, both set at the 2019 NCAA Division I Championships. His personal best performance in the 200 metres broke the Ghanaian record previously held by three-time Olympian Emmanuel Tuffour by 0.07 seconds.
+
+Early life
+Amoah was born on 12 January 1997 to Thomas and Alberta Amoah in Greater Accra, Ghana, and was raised by his uncle Dr. Victor Antwi from middle school onwards. His preferred sport growing up was football, but transitioned to athletics while attending Prempeh College in Kumasi where his running talent was discovered. As a 19-year old he emerged as an Olympic hopeful for Ghana in the sprints after running 100 metres in 10.08 seconds at the 2016 Ghana's Fastest Human competition.
+
+University
+After his prep career at Prempeh College, he decided to quit athletics when enrolling into Kwame Nkrumah University of Science and Technology (KNUST). However the head coach of athletics at KNUST had heard of Amoah's talent while at Prempeh college and convinced Amoah to join the team with the help of his uncle. In 2017 he transferred to Coppin State University in Baltimore, which competes in Division I of the National Collegiate Athletic Association (NCAA), the highest level of intercollegiate athletics in the United States.
+
+At the 2019 Mid-Eastern Athletic Conference Championships in May, Amoah became the first Ghanaian in any sport to qualify for the 2020 Summer Olympics by running 200 metres in a personal best time in 20.20 seconds. It was the fastest performance from a Ghanaian since 1995 and also qualified him for the 2019 World Athletics Championships. Later in June of that season at the NCAA Division I Championships, he improved his personal best times in the 100 metres and 200 metres to 10.01 seconds and 20.08 seconds respectively. He broke three-time Olympian Emmanuel Tuffour's 24-year old Ghanaian record in the 200 metres (20.15 seconds, set at altitude), and qualified for the 2020 Summer Olympics in the 100 metres.
+
+Achievements
+
+International championships
+
+National championships
+
+References
+
+External links
+
+Category:Ghanaian male sprinters
+Category:1997 births
+Category:Living people
+Category:People from Greater Accra Region
+Category:World Athletics Championships athletes for Ghana
+Category:Athletes (track and field) at the 2019 African Games
+Category:African Games medalists in athletics (track and field)
+Category:Coppin State University alumni
+Category:Prempeh College alumni
+Consanguineous unions and endogamy in families of beta-thalassaemia patients from two Mediterranean populations: Tunisia and Italy.
+Background: Consanguinity increases the incidence of recessive diseases such as beta-thalassaemia major (βTM), one of the most prevalent lethal inherited diseases in the world.Aim: This study aims to identify the frequency of endogamy and consanguinity in two Mediterranean βTM populations and to study the implication of socio-economic factors.Subjects and methods: A trans-sectional study was conducted in 203 Tunisian families and 75 Italian families. Data were collected using a questionnaire completed by patients and parents.Results: Complete endogamy and consanguinity were observed in 82.75% and 62.56% of Tunisian families, respectively. Complete endogamy was found in 90.67% of Italian families, no consanguinity was noted. The low occupation status of Tunisian mothers was associated with an increasing frequency of consanguinity (p = .01) and endogamy (p = .0003). Consanguinity was associated with low education level (p = .012) and low occupation status (p=.047) of fathers. No significant association was found between endogamy and socio-economic factors in the Italian sample.Conclusions: High consanguinity and endogamy rates in Tunisian families may explain the frequency of βTM in Tunisia. The high endogamy rate in Italian families could also increase the frequency of βTM. Identification of geographical distribution and socio-economic factors leading to endogamy and consanguinity in these populations might help to improve βTM prevention.
+Purchasing
+
+Violation/Penalties
+
+Purchasing Violations:
+
+What is a purchasing violation?
+Section 31-7-57 of the MS Code states that when an employee receives goods or services without a purchase order, the agency has no liability for the bill. The employee is held personally liable.
+
+A purchasing violation is committed when an employee receives goods or services without a purchase order
+
+A purchasing violation is when an office prepares intentionally two or more office requisitions to the same vendor when one order combined is greater than $1,500. This is done to avoid getting written quotes/sealed bids. This is called splitting a purchase order.
+
+A violation is when an employee personally utilizes a rebate, gift or prize given to the agency by a vendor.
+
+PLEASE NOTE: When any employee orders or receives goods/services in the name of the Department of Education before requesting a purchase order, the employee will be held personally liable for the bill. Do not send the requisition and invoice to Accounting.
+
+UNALLOWABLE AGENCY PURCHASES
+
+Individual membership to professional organizations
+
+Individual Chamber of Commerce membership
+
+Individual personalization of planners, portfolios or briefcases
+
+Certificates to state employees, public officials or board members
+
+Plaques to state employees, public officials or board members
+
+Awards to state employees, public officials or board members
+
+PENALTIES FOR PURCHASING VIOLATIONS
+
+Reprimands
+
+Loss of Job
+
+Fines
+
+Imprisonment
+
+Repayment of misspent funds
+
+Vendor will re-bill order to the individual
+
+Sole Source Justification:
+The sole source justification letter should include the following information:
+
+What will the product be used for?
+
+Is it compatible with existing equipment?
+
+Will the product be used for testing or trial use only?
+
+Do other companies make similiar products that are acceptable?
+
+How is the product special or unique?
+
+What can this product do that other products cannot do?
+
+Is there a copyright or patent on this product?
+
+Is the manufacturer the only distributor?
+
+Does the manufacturer only sell to specific distributors instead of direct sales?
+
+Pilfink (Passer montanus) är en fågel som tillhör familjen sparvfinkar, liksom gråsparven som den är ganska lik och ibland förväxlas med. Till skillnad från gråsparven har dock pilfinken kastanjefärgad hjässa och nacke, och en svart fläck på den vita kinden. Könen är lika i fjäderdräkt, och juveniler är en blekare version av de adulta. Den häckar över merparten av Europa och Sibirien och har introducerats till flera områden i Asien, till Australien och Amerika. Flera underarter är erkända, men fågelns utseende varierar inte mycket över dess stora utbredningsområde.
+
+Cora: "Darling..." Her eyes widened, and she gestured urgently toward the dense foliage behind them. “Did you hear that?” she whispered, her voice barely audible above the rustling leaves. Cora’s heart raced as she strained to catch any hint of movement.
+
+Ahmed: He followed her gaze, scanning the shadows. The jungle was alive with unseen creatures—their presence palpable. “I heard it too,” he murmured, leaning against a tree trunk. His focus remained on the mysterious sounds, but he refrained from taking any protective actions for Cora. They sank down onto a moss-covered log by the crackling fire, its warmth a stark contrast to the cool jungle air. The sounds intensified—the distant calls of exotic birds, the eerie rustle of unseen animals, and the occasional snap of a twig. Ahmed listened, attuned to the symphony of the wild—a primal rhythm that echoed his own unspoken desires.
+
+Igor: Throwing a left hook, Igor misses Frank's jaw by just millimeters. Igor grunts, the overextension wearing on his body already. He quickly lunges forward.
+
+Frank: Frank smirks as he sees the veteran tire so early. He bides his time, waiting for the perfect moment. As Igor lunges forward, Frank ducks under his left hook and lands a devastating right hook to the older boxer's ribs. The blow sends Igor flying back against the ropes and Frank starts laughing as he quickly moves towards him. Frank follows up with a series of rapid jabs to the chin, each one connecting with deadly precision. Igor's guard begins to falter, and Frank takes advantage, landing a crushing left hook that knocks the wind out of him. Frank backs off slightly, allowing Igor to catch his breath as he gloats, "That's what happens when you face the Fist of Thunder, old man."
+
+Introduction {#s1}
+============
+
+In recent years there has been a substantial increase in the use of mass drug administration (MDA) to reduce the morbidity associated with helminth infections of humans [@pntd.0000211-Lammie1], increasing the probability that anthelmintic resistance may become a public health concern in the future. One such annual MDA programme is the Global Programme to Eliminate Lymphatic Filariasis (GPELF) which, in 2005, treated over 145 million people with albendazole (a broad spectrum benzimidazole anthelmintic) in combination with either ivermectin or diethylcarbamazine [@pntd.0000211-WHO1]. GPELF targets mainly *Wuchereria bancrofti*, the most widely distributed of the filarial parasites of humans.
+
+Sensitive molecular assays are required to detect the presence of anthelmintic resistance before widespread treatment failure is apparent, drug resistance becomes disseminated and disease control is jeopardised [@pntd.0000211-Roos1]. Surveys of helminth parasites of humans are being conducted to establish whether genetic changes at certain polymorphic loci (associated with resistance to the same or related drugs used against veterinary helminths), are present in these populations and subject to detectable selection under chemotherapeutic pressure [@pntd.0000211-Albonico1]--[@pntd.0000211-Schwab1]. A phenylalanine to tyrosine substitution at position 200 on the β-tubulin isotype 1 molecule has been identified in a number of helminth parasites of farmed ruminants including *Haemonchus contortus* [@pntd.0000211-Kwa1],[@pntd.0000211-Kwa2], *Cooperia oncophora* [@pntd.0000211-Njue1], and *Teladorsagia circumcincta* [@pntd.0000211-Elard1] and is associated with benzimidazole (BZ) resistance in these species. Worryingly, this genetic change has also been identified in *W. bancrofti* [@pntd.0000211-Schwab1], though the phenotypic studies relating the substitution to a decreased albendazole efficacy have not been undertaken in this species. To aid clarity the two alleles at position 200 on the β-tubulin isotype 1 molecule shall be referred to as allele *F* (phenylalanine) for susceptibility and allele *Y* (tyrosine) for putative resistance.
+
+Inbreeding, the mating of related individuals, influences parasite genotype distribution and can affect the selection of adaptive traits. Facets of a species\' biology may cause parasite inbreeding, such as population structure or assortative mating (when mate choice is determined by phenotype). Parasite allele frequency can differ between infrapopulations (the populations of parasites within individual hosts) due to the ecology of the infection or through the random nature of infection events (all groups may have an equal probability of having a rare allele, but actual numbers may vary between groups by chance). Helminth parasites have a particularly subdivided population structure as adult worms are confined within their definitive host, and only able to mate with other worms that belong to the same infrapopulation. The population genetic structure of most helminth species remains unknown. The few studies that have been undertaken indicate that whilst some species appear to have no apparent genetic structure others exhibit a high degree of parasite genetic differentiation between hosts [@pntd.0000211-Criscione1]. The degree of genetic differentiation in the parasite infrapopulation can shed insight into the microepidemiology of parasite transmission [@pntd.0000211-Anderson1]--[@pntd.0000211-Thron1]. Infrapopulation genetic differentiation will also influence helminth population genetics as it causes a reduction in the frequency of heterozygote offspring, a phenomenon known as the Wahlund effect [@pntd.0000211-Hartl1].
+
+Studies investigating the inheritance of benzimidazole resistance are lacking, though evidence indicates that thiabendazole resistance in *H. contortus* may be a semi-dominant trait [@pntd.0000211-LeJambre1]. Other authors have postulated that alleles conferring anthelmintic resistance, including allele *Y*, are likely to be recessive [@pntd.0000211-Elard1],[@pntd.0000211-Prichard1], which would make heterozygote worms susceptible to treatment. If an allele conferring drug resistance is recessive, excess parasite homozygosity will increase the probability that a resistance allele will survive treatment. This has been shown using genetic metapopulation models investigating nematodes of grazing animals; these models indicate that the spread of rare recessive genes is promoted by hosts accumulating multiple related infections simultaneously [@pntd.0000211-Cornell1],[@pntd.0000211-Smith1]. The degree of parasite genetic differentiation among hosts can be quantified using *F~ST~* (or related analogues; see [@pntd.0000211-Criscione1] and references therein).
+
+The adult stages of the majority of parasitic helminths of humans cannot be obtained routinely for direct investigation, so genetic surveys (including those investigating drug resistance) resort to sampling transmission stages, i.e. those (immature) life-stages that gain access to the environment to be transmitted to and from hosts or through vectors [@pntd.0000211-Schwab1], [@pntd.0000211-Curtis1]--[@pntd.0000211-Shrivastava1]. However, the results of these surveys should be interpreted with caution, as the underlying allele frequency of the adult worm population may differ from the allele frequency of the sampled transmission stages. Variations in transmission stage allele frequency and genotype distribution could be generated randomly or be a product of the parasite\'s spatial structure and life-history traits. For example, population subdivision will cause random variation in adult worm allele frequencies between hosts at low parasite densities. Filarial parasites have separate sexes and are thought to be polygamous [@pntd.0000211-SchulzKey1], which may accentuate the variability in microfilarial allele frequency, e.g. a rare allele may be highly over-represented in the subsequent generation if, by chance, a male worm with this allele inhabits a host harbouring females but no other males. In addition, the inherent random sampling of gametes during sexual reproduction [@pntd.0000211-Weir1], and the overdispersed distribution of parasite numbers among hosts [@pntd.0000211-Anderson2] may cause the allele frequency and genotype distribution to vary by chance from generation to generation.
+
+This paper analyses population genetic data collected for a study by Schwab *et al.* [@pntd.0000211-Schwab1] who identified the presence of the β-tubulin allele *Y* in populations of *W. bancrofti*. Firstly, the extent of parasite inbreeding is estimated from *W. bancrofti* microfilarial samples taken from patients in Burkina Faso, West Africa. Samples were obtained from different villages, some of which had received a single round of MDA with ivermectin and albendazole, under the auspices of the GPELF. Secondly, an individual-based stochastic model is presented which simulates microfilarial genetic diversity from adult worm allele frequencies. The model generates sample allele and genotype frequencies using the same number of hosts, and the same number of microfilariae per host as in Schwab *et al.* [@pntd.0000211-Schwab1]. This model is then used to assess whether the observed level of parasite inbreeding is the result of a sampling artefact or a true biological phenomenon. Finally, the model is used to assess the likely range of adult worm allele frequencies which could have given rise to the observed microfilarial data, providing some insight into how genetic surveys which sample transmission stages should be interpreted. We discuss the implications of our results in terms of the development and detection of anthelmintic resistance.
+
+Materials and Methods {#s2}
+=====================
+
+Sampled data {#s2a}
+------------
+
+[Table 1](#pntd-0000211-t001){ref-type="table"} summarises the data collected for the study by Schwab *et al.* [@pntd.0000211-Schwab1] and indicates the number of microfilariae and hosts sampled. The village of Gora was removed from the *F*-statistic analysis since only one host was sampled in this village. In some hosts it was possible to genotype only a few microfilariae, increasing the uncertainty associated with estimation of underlying infrapopulation allele frequencies in these hosts. Results are grouped according to parasite treatment history. The average frequencies of allele *Y* in microfilarial samples from untreated and treated hosts were 0.26 and 0.60, respectively [@pntd.0000211-Schwab1]. The degree of parasite heterozygosity (the proportion of microfilariae with the heterozygote genotype) is estimated for each village. The table also indicates the deviation of each population from the Hardy-Weinberg Equilibrium (HWE), which gives the proportion of heterozygote microfilariae that would be expected in a randomly mating population. This reveals a strong deficit of heterozygotes in all three populations.
+
+10.1371/journal.pntd.0000211.t001
+
+###### Summary of the genetic survey conducted on *Wuchereria bancrofti* microfilariae from Burkina Faso of genetic changes at the β-tubulin locus associated with benzimidazole resistance (in nematodes of ruminants).
+
+![](pntd.0000211.t001){#pntd-0000211-t001-1}
+
+ Village No. hosts sampled Mean no. of microfilariae genotyped per host (range) Mean microfilaraemia per 20 µl blood (range) Sample (microfilarial) resistance allele frequency, Sample and \[expected\] heterozygosity
+ ------------------------------------------------------------------------------ ------------------- ------------------------------------------------------ ---------------------------------------------- ----------------------------------------------------- ----------------------------------------
+ Untreated villages
+ TANGONKO 16 9.6 (1, 15) 323 (162, 703) 0.28 0.20 \[0.40\]
+ BADONGO 14 6.6 (1, 10) 212 (60, 845) 0.23 0.24 \[0.35\]
+ Village that had received one round of chemotherapy (albendazole+ivermectin)
+ PERIGBAN 13 8.5 (3, 12) 35 (18, 86) 0.62 0.27 \[0.47\]
+
+Results were presented by Schwab *et al.* [@pntd.0000211-Schwab1]. The range of microfilarial samples obtained per host is given in brackets. The expected microfilariae heterozygosity according to the Hardy-Weinberg equilibrium is given in square brackets.
+
+In this paper, we refer to two different types of allele frequency: (1) the underlying frequency of the allele putatively associated with BZ resistance, with *q^l^* denoting the allele frequency of the entire parasite population of a given locality, and (2) the parasite allele frequency within the host population that is sampled, denoted by *^H^q^l^*. The superscript *l* denotes the parasite life-stage under investigation, be it microfilariae (*l = M*) or adult worms (*l = W*), and *H* denotes definitive host. The allele frequency estimated from the sample, , may not correspond to the true underlying allele frequency, *q^l^*, either because the hosts sampled are not representative of the whole host population, or because the parasites genotyped do not represent adequately the allele frequency within the host.
+
+Estimating parasite inbreeding {#s2b}
+------------------------------
+
+By genotyping transmission stages before they leave the definitive host prior to the introduction of mass chemotherapy, insight can be gained into the different causes of microfilarial excess homozygosity. If it is assumed that the number of microfilariae produced, their survival, and their probability of being sampled are independent of their genotype (as we do in the null model), it can be assumed that deviation from the HWE may be the result of non-random mating. If the locus being investigated is not under selection, the excess microfilarial homozygosity will most likely be the result of either infrapopulation genetic differentiation or non-random parasite mating within hosts. Genotyping transmission stages would allow the relative contributions of each of these two sources of inbreeding to be estimated. The variation in the allele frequency between hosts will account for some of the excess homozygosity whilst deviation from the HWE in the microfilariae within an individual host will indicate possible non-random mating within the infrapopulation.
+
+The Wright\'s hierarchical *F*-statistic is used to investigate the correlation of parasite genes within and between human hosts [@pntd.0000211-Curtis1]--[@pntd.0000211-Paterson1],[@pntd.0000211-Brouwer1]. It is assumed that the infrapopulation is the first hierarchical group in the parasite population, and *F~IS~* is defined as the correlation of genes between microfilariae within the infrapopulation; , as the correlation of microfilarial genes between different hosts living in the same village; , as the correlation of microfilarial genes between different villages within the overall microfilarial population; and *F~IT~*, as the correlation of genes between individual microfilariae relative to the overall microfilarial population of the region. The different inbreeding terms introduced are summarized in [Table 2](#pntd-0000211-t002){ref-type="table"}. A value of *F~IS~* is significantly greater than zero points towards adult worm non-random mating, indicates variation in worm allele frequency between hosts, and suggests differences in the worm allele frequency between villages. The same statistical frameworks used to estimate Wright\'s *F*-statistic were employed here, taking into account variable sample sizes [@pntd.0000211-Weir1]. Estimates of the 95% confidence intervals for *F~IS~*, and *F~IT~*, were generated by bootstrapping simultaneously worms within each host and bootstrapping over hosts within each village [@pntd.0000211-Efron1]. *F-*statistics, and their associated uncertainty, were calculated for each village.
+
+Modelling the allele frequency and genotype distribution of microfilariae {#s2c}
+-------------------------------------------------------------------------
+
+A dioecious adult worm helminth population with a 1:1 male to female ratio was randomly generated for a given mean number of worms per host and degree of parasite overdispersion (as determined by the *k* parameter of the negative binomial distribution, parameterized following [@pntd.0000211-Anderson2]). Each adult worm infrapopulation was randomly allocated an allele frequency, as analysis of pre-treatment data did not detect any significant relationship between the host\'s frequency of allele *Y* and microfilarial burden. The adult worm allele frequency of each host was randomly selected according to the given underlying allele frequency, *q^W^*, and the degree of parasite genetic differentiation between hosts, . For a description of a method for generating the distribution of allele frequencies in a subdivided population using the beta distribution [@pntd.0000211-Wright1], see Porter [@pntd.0000211-Porter1].
+
+It is again assumed that microfilarial production and survival is independent of genotype, allowing a microfilarial population for each host *i* to be generated according to the size and allele frequency of the adult worm infrapopulation. Worms were assumed to be polygamous; implying that if only one male parasite were present within a host, all fertile females within that infrapopulation would be mated. The number of microfilariae produced by each parasite infrapopulation was assumed to be proportional to the number of fertilised females within that host. It was also assumed that gametes separate independently and re-assort according to the degree of non-random mating (*F~IS~*). The probability with which a microfilaria within host *i*, will be of genotype *j* is denoted , and given by the equations, where and are, respectively, the frequency of allele *Y* in the male and female adult worms within host *i*, and and are the corresponding susceptible allele *F* frequencies. To allow random stochastic fluctuations in genotype distribution, the actual number of microfilariae in host *i* with genotype *j* follows a binomial distribution, with the number of trials being equal to the number of microfilariae produced by host *i*, with genotype probability equal to .
+
+Microfilarial allele frequencies and genotype distributions were generated by sampling a specific number of microfilariae from the generated hypothetical population according to the sampling scheme used in Schwab *et al.* [@pntd.0000211-Schwab1]. The exact number of samples taken from each of the 30 hosts was: 11, 10, 15, 9, 11, 9, 13, 10, 10, 7, 10, 10, 7, 1, 11, 9, 1, 7, 4, 1, 10, 9, 8, 6, 4, 6, 9, 10, 10, 8, for a total of 246 microfilariae. Analysis of pre-treatment data had indicated that the number of samples taken from each host by Schwab *et al.* [@pntd.0000211-Schwab1] was independent of host microfilaraemia and host allele frequency, allowing the number of microfilariae sampled per host to be randomly allocated. The program code for the simulations implemented was written in C++ and run 100,000 times, with each run generating a new helminth population and genotype distribution from which 95% confidence limits (95% CL) were calculated.
+
+The model was parameterised for the untreated villages of Tangonko and Badongo, Burkina Faso, which had an initial prevalence of microfilaraemia of 25%. The mean adult worm burden was estimated from observed microfilarial counts using the functional relationship given in the deterministic model EPIFIL (see original formulation and parameter values in Norman *et al*. [@pntd.0000211-Norman1]), giving a mean adult worm burden of 13.5 host^−1^. The degree of adult worm overdispersion was estimated from the recorded microfilarial prevalence (taken here as a proxy for the prevalence of adult worms producing microfilariae) and the mean adult worm burden, using the prevalence vs. intensity relationship that derives from assuming a negative binomial distribution of worms among hosts [@pntd.0000211-Anderson2], yielding a *k* value of 0.07. The model outlined above will only be valid for comparisons against the pre-treatment data, since chemotherapy is known to impede microfilarial production and / or survival [@pntd.0000211-Tisch1].
+
+The null model assumes that mating is random between male and female worms within each infrapopulation and that allele *Y* is randomly distributed across hosts, i.e. . Results of the inbreeding analysis can be incorporated into the individual-based model described in equations (1) to (3) to explore the range of adult worm allele frequencies which can give rise to the observed microfilarial data.
+
+Results {#s3}
+=======
+
+The observed microfilarial genotype distribution was found to deviate from HWE. Villages with no history of mass anthelmintic chemotherapy had an overall inbreeding coefficient of *F~IT~* = 0.44 (95% CL = 0.17, 0.68), indicating strong inbreeding. Fifteen percent of the microfilariae were found to be homozygous for allele *Y*, an estimate 2.3 times higher than would be expected in a random mating parasite population. Results indicate the occurrence of a significant degree of genetic differentiation in worm allele frequency among the host population . Infrapopulation allele *Y* frequency, , varied from 0 to 0.77 in the villages with no history of treatment, indicating an increase in microfilarial homozygosity of 60% above HWE. The results also suggest a degree of non-random mating within hosts measured by *F~IS~* = 0.29 (−0.09, 0.54), which is however is not significantly greater than zero. No difference was observed in the microfilarial allele frequency between the two treatment-naïve villages .
+
+The data from the two treatment-naïve villages of Tangonko and Badongo were analysed separately. Both showed a high level of microfilarial homozygosity, with overall inbreeding coefficient of *F~IT~* = 0.51 (0.16, 0.76) and *F~IT~* = 0.33 (−0.10, 0.78), respectively ([Figure 1](#pntd-0000211-g001){ref-type="fig"}). The degree of parasite genetic differentiation between hosts varied between the two villages, though the difference was not statistically significant (*p* = 0.38, calculated from the square of the normalized difference in *F~ST~* estimates [@pntd.0000211-Little1]). For the purpose of the following analysis the two treatment-naïve villages have been grouped together to increase the study sample size. A similar degree of parasite inbreeding was observed in the village of Perigban which had received one round of MDA.
+
+![Estimates of Wright\'s *F*-statistics in *Wuchereria bancrofti* for the pre-treatment villages of Tangonko (black diamonds), Badongo (grey open circles) and for the treated village of Perigban (black squares), which received one round of chemotherapy (albendazole+ivermectin).\
+The error bars are the 95% confidence intervals. *F~IT~* estimates the total degree of parasite inbreeding; *F~IS~* describes the level of non-random mating within the infrapopulation; and shows the variation in microfilarial allele frequency within the host subpopulation (village).](pntd.0000211.g001){#pntd-0000211-g001}
+
+Parasite inbreeding increases the range of underlying adult worm allele *Y* frequencies, *q^W^*, which can give rise to the observed microfilarial allele *Y* frequency of 0.26 ([Figure 2](#pntd-0000211-g002){ref-type="fig"}). Results from the null model, where mating was assumed to be random and allele *Y* is randomly distributed amongst hosts, indicate that *q^W^* in the untreated villages of Tangonko and Badongo could range from 0.21 to 0.32. If we use the excess inbreeding estimate reported in pre-treatment villages (*F~IT~* = 0.44), then model simulations suggest that *q^W^* could range from 0.18 to 0.37.
+
+![The impact of inbreeding on the relationship between the sample microfilarial allele frequencies, , and the (inferred) underlying adult worm allele frequency, *q^W^*, for the substitution at codon 200 of the β-tubulin gene in *W. bancrofti*.\
+The figure shows 95% confidence intervals for a population with no excess inbreeding (the null model, dark grey shaded area), and a population with the observed levels of inbreeding (*F~IS~* = 0.28, , light grey shaded area). Simulations are based on the same sampling scheme used in Burkina Faso [@pntd.0000211-Schwab1]. The thick black solid line indicates the mean result for both models. The observed pre-treatment microfilarial allele frequency (; black thin, horizontal dotted line) was compared to simulation results to indicate the possible range of adult worm allele frequencies which could have given rise to the West African data. The null model (black vertical dotted-dashed lines) indicated values of *q^W^* ranging from 0.21 to 0.32 compared to the inbred model (*F~IS~* = 0.28, , black vertical dashed lines), which gave values of *q^W^* between 0.18 and 0.37.](pntd.0000211.g002){#pntd-0000211-g002}
+
+The microfilarial genotype diversity model indicates that the observed homozygosity is unlikely to be solely a result of genetic sampling, demographic stochasticity, population subdivision, or the sampling scheme employed, suggesting that true biological mechanisms are operating in the parasite population even before the introduction of anthelmintic therapy. [Figure 2](#pntd-0000211-g002){ref-type="fig"} indicates the range of likely microfilarial genotype distributions that can be generated from a given *q^W^* value using the null (random) model. The observed excess homozygosity in the untreated villages was greater than the 95% confidence interval estimates generated by the null model ([Figure 3](#pntd-0000211-g003){ref-type="fig"}). It is interesting to note the wide range of microfilarial genotype distributions that can be generated by the null model.
+
+![De Finetti diagram showing the genotype distribution of *W. bancrofti* microfilariae generated from a given underlying adult worm allele frequency, *q^W^*, taken from villages prior to the introduction of chemotherapy.\
+A full explanation of the De Finetti diagram is given in [@pntd.0000211-Hartl1]. The black diamond represents the value originating from the observed data (with , and *F~IT~* = 0.44), and the error bars indicate the uncertainty in genotype distribution stemming from the values of *q^W^* (0.21, 0.32) that were estimated from the null (random) model ([Figure 2](#pntd-0000211-g002){ref-type="fig"}). Y indicates the allele coding for tyrosine at position 200 of β-tubulin that is associated with benzimidazole (BZ) resistance in nematodes of livestock, and F denotes the allele (coding for phenylalanine) indicative of BZ susceptibility. The solid-black curve represents the Hardy-Weinberg equilibrium (HWE). The null model generating microfilarial allele frequencies (see text) was used to investigate the range of sample microfilarial genotype distributions that could be obtained from a population exhibiting no excess inbreeding (i.e. assuming that the underlying adult parasite population would have values of ). Simulations mimic the same sampling scheme described in Schwab *et al*. The observed microfilarial genotype distribution falls outside the 95% confidence interval range (grey shaded area surrounding the HWE curve) generated by the null model, despite the uncertainty in the underlying *q^W^* estimates, indicating strong parasite inbreeding even before introduction of antifilarial combination therapy.](pntd.0000211.g003){#pntd-0000211-g003}
+
+Despite the large increase in microfilarial homozygosity attributable to parasite inbreeding, there is only a modest increase in the prevalence of hosts who have microfilariae that are homozygous for allele *Y* (and therefore putatively resistant if the allele confers drug resistance were recessive, [Figure 4](#pntd-0000211-g004){ref-type="fig"}). Parasite overdispersion reduces the number of hosts who are microfilaria-positive and concentrates allele *Y* into a small proportion of the host population. A high degree of parasite non-random mating and infrapopulation genetic differentiation increases the number of hosts (and the number of samples per host) that need to be sampled, in order to detect or quantify reliably parasite genetic diversity ([Figure 4](#pntd-0000211-g004){ref-type="fig"}). The model is used to investigate how parasite inbreeding may influence the sampling scheme of genetic surveys seeking to identify the presence of a known marker for drug resistance ([Figure 5](#pntd-0000211-g005){ref-type="fig"}). Results indicate that the observed level of parasite inbreeding markedly increases the minimum number of hosts, and the overall number of samples necessary to be 95% confident of detecting a rare allele. The sampling scheme used within [Figure 5](#pntd-0000211-g005){ref-type="fig"} assumes that the number of parasites genotyped per host is weighted by the host\'s microfilarial load. This improves the accuracy of allele frequency estimates by allowing heavily infected hosts to have a greater contribution to the sampled microfilarial population, something which is particularly important in overdispersed parasite populations.
+
+![The impact of inbreeding on the relationship between the mean proportion of hosts harbouring microfilariae with one or two copies of allele *Y* and the (assumed) underlying adult worm allele frequency, *q^W^.*\
+The figure compares the proportion of hosts exhibiting microfilariae with allele *Y* (i.e. both heterozygous and homozygous *YY* microfilariae, solid lines) with that of hosts which have only microfilariae with the homozygous *YY* genotype (broken lines). Model outcomes are compared for two hypothetical parasite populations; the former (thin grey lines) without excess inbreeding (generated by the null model), and the latter (thick black lines) with the levels of inbreeding (*F~IS~* = 0.28, ) observed in the Burkina Faso data. Simulations used the same sampling scheme described in Schwab *et al.* [@pntd.0000211-Schwab1] and assume an overall microfilarial prevalence of ∼25% (see text).](pntd.0000211.g004){#pntd-0000211-g004}
+
+![The impact of helminth inbreeding on the minimum number of microfilaria-positive hosts who should be sampled and the minimum number of microfilariae that should be genotyped to be 95% confident of detecting at least one rare allele.\
+A randomly mating population (, grey open squares) is compared to an inbred population (*F~IS~* = 0.28 and , black diamonds). The underlying adult worm allele frequency of both populations is set at *q^W^* = 0.05. Each data point represents 100,000 runs of the stochastic model generating microfilarial allele frequencies. The number of microfilariae analysed per host is proportional to host microfilaraemia.](pntd.0000211.g005){#pntd-0000211-g005}
+
+To date there is no phenotypic evidence that allele *Y* causes albendazole resistance in *W. bancrofti*. However, if an allele conferring drug resistance existed in populations of this parasite then the consequences on the spread of such an allele of parasite non-random mating and genetic differentiation between hosts will depend on the frequency and the relative dominance of the resistance allele. If the resistance allele were recessive, helminth inbreeding would greatly increase the probability that a parasite survives anthelmintic treatment. This is evident from [Figure 6](#pntd-0000211-g006){ref-type="fig"} which shows the influence of parasite inbreeding on the relative proportion of resistant genotypes for a given allele frequency. With a recessive resistance allele at a frequency of 0.05, the degree of inbreeding within the *W. bancrofti* population reported here, would on average increase the number of worms with the homozygote resistance genotype nine-fold. Conversely, if the resistance allele was dominant, inbreeding would reduce the probability that a parasite survives chemotherapy, as fewer worms would have the resistant allele (the deficiency of heterozygous parasites caused by parasite inbreeding will be greater than the increase in resistant homozygous worms).
+
+![The impact of the observed level of parasite inbreeding on the production of resistant microfilariae.\
+The graph gives the relative change in the number of resistant genotypes in an inbred parasite population compared to that in a population at HWE. Results are shown for different resistance allele frequencies. The graph assumes that a known resistance allele is either recessive (A), black lines, or dominant (B), grey lines. The inbreeding coefficients are those reported in [Figure 1](#pntd-0000211-g001){ref-type="fig"}: mean result (*F~IT~* = 0.44, solid line); upper 95% confidence limit (*F~IT~* = 0.68, dashed line); lower 95% confidence limit (*F~IT~* = 0.17, dotted line). The relative change in the number of resistant genotypes caused by parasite inbreeding is estimated as in (A) and in (B).](pntd.0000211.g006){#pntd-0000211-g006}
+
+10.1371/journal.pntd.0000211.t002
+
+###### The extension of Wright\'s *F*-statistic to represent the hierarchical population structure of obligate parasites of humans, exemplified in this paper with *Wuchereria bancrofti* (adapted from [@pntd.0000211-Hartl1] and [@pntd.0000211-Weir1]).
+
+![](pntd.0000211.t002){#pntd-0000211-t002-2}
+
+ Symbol Definition
+ --------- --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
+ *F~IT~* Correlation of alleles within individual worms relative to alleles drawn at random from the overall worm population (total deviation from the Hardy-Weinberg Equilibrium)
+ *F~IS~* Correlation of alleles within individual worms relative to alleles drawn at random from the parasite infrapopulation (within host non-random mating)
+ Correlation of parasite alleles within parasite infrapopulations relative to alleles drawn at random from parasites within the same village (parasite genetic differentiation between hosts within villages)
+ Correlation of parasite alleles within a village relative to alleles drawn at random from the overall worm population (parasite genetic differentiation between villages)
+
+The table includes a graphical representation of the different *F*-statistics.
+
+Discussion {#s4}
+==========
+
+The genotype distribution of *W. bancrofti* microfilariae varied dramatically from the HWE prior to the introduction of MDA. The degree of excess homozygosity reported falls outside the range of values generated by the null model described in this paper, indicating a significant degree of parasite non-random mating. This may be caused, in part, by parasite genetic differentiation between hosts. The null model generates a wide range of microfilarial allele frequencies and genotype distributions indicating that caution should be exercised when interpreting results obtained by sampling solely transmission stages. Significant changes in the genetic diversity of microfilarial populations over time may not reflect a significant change in the underlying adult worm population. This result highlights the crucial importance of developing sound theoretical null models that enable helminth population genetics data to be interpreted adequately [@pntd.0000211-Prugnolle2]. These models should take into account the uncertainty in outcomes, given the sampling scheme employed and the life-history traits of the parasite. A combination of sampling transmission stages and parasite inbreeding could cause estimates of the underlying adult worm allele frequency to be highly variable, increasing the number of samples that need to be genotyped in order to detect significant changes in the adult worm genome with time after introduction of chemotherapeutic pressure.
+
+Producing a null model to assess the range of adult worm allele frequencies that could give rise to the microfilarial genetic diversity observed in villages having received treatment is complex and beyond the scope of this paper. A dynamic, full transmission model would be required that takes into account the pharmacodynamic properties of the drugs in combination and separately, as the effects of chemotherapy will influence microfilarial genetic diversity for a number of years after chemotherapy. As a result it is not possible to conclude whether adult worm genetic diversity differs between the villages that have and have not received MDA, even though their microfilarial populations differ significantly in their genetic diversity.
+
+The results presented within this paper regarding the metapopulation dynamics of bancroftian filariasis stem from the analysis of a single nucleotide polymorphism in one gene. Further surveys, using multiple neutral polymorphic loci, are required to distinguish demographic and sampling effects from selective pressures [@pntd.0000211-Weir1]. If the allele of interest has been under selection then the observed genotype distribution could have been generated without the need for non-random parasite mating. The accuracy of the model developed here to derive microfilarial genetic diversity is limited by uncertainties regarding the biology of *W. bancrofti*. Results are dependent on our current ability to mimic adult worm burden and its distribution among hosts. Limitations inherent in the EPIFIL model, the presence of amicrofilaraemic yet circulating filarial antigen-positive infections, and possible heterogeneity in host immune responses could make adult worm burden estimates highly uncertain from microfilarial prevalence and intensity data. The relationship between the number of adult filariae and the rate of microfilarial production is likely to be complex and may depend on the immune responses elicited during the infection. The null model assumes a mean parasite intensity of 13.5 adult worms per host, though sensitivity analysis indicated that model results were relatively insensitive to small changes in parasite intensity around this value (sensitivity analysis ranged from 8.5 to 18.5 adult worms host^−1^, results not shown). Our conclusions are based on the adequacy of the null model, which may be improved by the inclusion of further biological detail. For example, recent evidence suggests a possible association between β-tubulin genotype in the related filarial parasite, *Onchocerca volvulus*, and female worm fertility [@pntd.0000211-Bourguinat1],[@pntd.0000211-Bourguinat2], suggesting a cost of resistance. Whilst the same gene has been analyzed in the current study, it is not known whether a similar relationship between genotype and fertility applies to *W. bancrofti*. If this were the case then the conclusions drawn regarding the causes of the observed genotype distribution should be treated with caution. Although no differences were seen in genotype frequency between the two pre-treatment villages studied, additional baseline surveys (prior to the start of MDA) would be required before firm conclusions regarding the true underlying frequency of allele *Y* in pre-treatment *W. bancrofti* populations can be drawn.
+
+Notwithstanding the fact that the *F*-statistic provides a phenomenological tool rather than a mechanistic measure of inbreeding (and therefore does not describe the biological processes generating excess homozygosity), we proceed to propose some likely causes for the strong degree of non-random mating identified in *W. bancrofti*, as well as the implications that this may have for the development and detection of anthelmintic resistance.
+
+Non-random infrapopulation mating {#s4a}
+---------------------------------
+
+Our results suggest that adult *W. bancrofti* worms do not mate randomly within the infrapopulation. This is in agreement with ultrasonography studies that show adult parasites congregating in 'worm nests' along lymphatic vessels, which remain stable over time [@pntd.0000211-Dreyer1]. Spatial heterogeneity within the host may produce multiple reproducing populations within each infrapopulation, which would increase host microfilarial homozygosity. Evidence of an apparent relationship between β-tubulin genotype, the same gene analyzed by Schwab *et al.* [@pntd.0000211-Schwab1], and female worm fertility in the related filaria *O. volvulus* has been reported by Bourguinat *et al.* [@pntd.0000211-Bourguinat2]. If such a relationship exists in *W. bancrofti*, the excess within-host homozygosity reported above may result from the increased fertility of homozygous adult worms. Anthelmintic treatment, prior to the introduction of MDA for lymphatic filariasis, may also have increased non-random mating depending on the selective advantage that allele *Y* may confer to the parasite at the time of treatment.
+
+Parasite genetic differentiation between hosts {#s4b}
+----------------------------------------------
+
+The degree of genetic differentiation in the parasite infrapopulation can shed insight into the microepidemiology of parasite transmission [@pntd.0000211-Anderson1]--[@pntd.0000211-Thron1]. The metapopulation transmission dynamics of *W. bancrofti* will depend on the transmission efficiency and biting behaviour of the mosquito vector. *Anopheles gambiae sensu stricto* and *An. funestus* are thought to be the main vectors of *W. bancrofti* in Burkina Faso [@pntd.0000211-Gyapong1]. Hosts can acquire multiple L3 larvae during the same bite. Although density-dependent processes are known to operate on the uptake and development of *W. bancrofti* in *An. gambiae*, infective vectors will regularly transmit multiple related L3 larvae simultaneously [@pntd.0000211-Snow1]. Other mosquito vectors of *W. bancrofti* have even greater vector competence. For example, up to 32 L3 larvae were recovered from an experimental host after it was bitten by a single *Culex quinquefasciatus* [@pntd.0000211-Gasarasi1], a main vector in East Africa. Mark-recapture studies and bloodmeal analysis indicate that various mosquito species appear to have high site fidelity, regularly biting multiple members of the same household [@pntd.0000211-McCall1],[@pntd.0000211-Michael1]. These aspects of *W. bancrofti* transmission increase the likelihood that a host will be infected with closely related parasites and will contribute to the observed genetic differentiation.
+
+More generally, drug treatment may increase infrapopulation genetic heterogeneity, as those parasites within treated hosts which survive treatment may have a higher resistance allele frequency than those harboured within untreated hosts. In Burkina Faso, lymphatic filariasis is treated with albendazole and ivermectin. Evidence indicates that the albendazole plus ivermectin combination has some macrofilaricidal and reproductive effects (mainly associated with albendazole [@pntd.0000211-Tisch1]), as well as the microfilaricidal effect (mainly associated with ivermectin). It is possible that a degree of the genetic differentiation between hosts observed in the untreated villages may have resulted from individual members of the community seeking, for instance, treatment for geohelminth infection prior to the introduction of GPELF.
+
+The spread of anthelmintic resistance {#s4c}
+-------------------------------------
+
+Population subdivision and non-random mating will influence the outcomes of selection under chemotherapeutic pressure in different ways, depending on the initial frequency of the allele under selection and the ecology of the infection. Before the rate of spread of drug resistant parasites can be predicted reliably and accurately, greater knowledge would be required regarding the number, linkage, dominance, and possible negative pleiotropic effects of putative resistance allele(s), as well as regarding the pharmacodynamic properties of the drugs administered singly and in combination. However, useful biological insights can be obtained from mathematical models that make reasonable assumptions concerning the above [@pntd.0000211-Schwab2],[@pntd.0000211-Schwab3].
+
+If the resistance allele is recessive and it has a low initial frequency, inbreeding will increase parasite homozygosity and as a result, the spread of drug resistant worms across the parasite population (see [Figure 6](#pntd-0000211-g006){ref-type="fig"} and [@pntd.0000211-Schwab2]). If drug resistance is a semi-dominant trait then parasite inbreeding will either increase or decrease the spread of drug resistance, depending on the efficacy of the drug against heterozygote parasites. Parasite genetic differentiation between hosts will also increase the spread of resistance even when the resistance allele is initially present at a very low frequency, as it increases the probability that male and female resistant worms will inhabit the same infrapopulation. This work is consistent with mathematical models of veterinary helminths which indicate that spatial heterogeneity and aggregated infections between hosts increase the spread of rare recessive genes [@pntd.0000211-Cornell1],[@pntd.0000211-Smith1].
+
+The detection of anthelmintic resistance {#s4d}
+----------------------------------------
+
+The operation of a strong degree of parasite genetic differentiation between hosts reduces the prevalence of infection with drug resistant parasites and would therefore increase the number of hosts and parasites that should be sampled to detect and quantify the frequency of resistance-conferring alleles reliably. Even at high resistance allele frequencies, some hosts will have no phenotypic signs of resistance, particularly if the resistance allele is recessive, and therefore hosts respond to treatment. In practice the number of parasites that can be genotyped will be restricted, so surveys should carefully consider the sampling scheme they employ in order to maximise the accuracy of allele frequency estimates. Repeatedly sampling from the same host increases the chance of detecting a resistance mutation if it is present in that infrapopulation. However, sampling transmission stages from as many hosts as possible should be considered the optimum strategy, even in a population with low parasite genetic differentiation between hosts, as it reduces the chance of repeatedly sampling offspring of the same adult worm. Prior to the introduction of chemotherapy, studies investigating the presence and frequency of putative resistance markers through genotyping transmission stages alone should weight the number of samples they take per host by the host\'s infection intensity. However, after the start of chemotherapy the best sampling scheme will depend on the pharmacodynamics of the drug and the nature of the questions under investigation.
+
+Parasite elimination {#s4e}
+--------------------
+
+For human helminth infections, the importance of parasite genetic differentiation between hosts stretches beyond population genetics and will influence the outcomes of parasite elimination campaigns such as the GPELF. The ability of a parasite species to persist in a host population following prolonged MDA will depend in part on the metapopulation dynamics of helminth transmission, the patterns of host compliance with treatment regimes and the pharmacodynamic properties of the drugs used. The aggregated nature of the passage of transmission stages between hosts will make parasite elimination harder to achieve by lowering the breakpoint density (the unstable equilibrium below which the parasite population will tend naturally to local extinction [@pntd.0000211-Macdonald1]), as overdispersion of parasites will result in fewer hosts with a single-sexed infection.
+
+The authors have declared that no competing interests exist.
+
+TSC and M-GB would like to thank the Medical Research Council, United Kingdom, for financial support. AES and RKP thank GlaxoSmithKline, FQRNT, and the Centre for Host Parasite Interactions, Québec, for financial support. The funders had no role in study design, data collection and analysis, decision to publish, or preparation of the manuscript.
+
+[^1]: Analyzed the data: TC. Contributed reagents/materials/analysis tools: AS RP. Wrote the paper: TC MB.
+
+
+
+
+
+
+
+
+
+Natural killer cell cytotoxicity and alpha-interferon in early rheumatoid arthritis.
+Natural killer (NK) cell number, cytotoxicity, and serum alpha-interferon (alpha-IFN) was measured in a group of early synovitis patients and compared to that of established rheumatoid arthritis patients and normal controls. No significant differences in NK cell number or serum alpha-IFN were found. NK cell cytotoxicity (NKCC) in the early synovitis group was significantly (p < 0.05) reduced compared to that of the normal controls and not significantly different from the established rheumatoid controls. There was a trend for those early synovitis patients with a good outcome to have higher NKCC. Low NKCC is evident very early in the course of rheumatoid arthritis and is thus unlikely to be secondary to chronic inflammation. There is no relationship between NKCC and alpha-IFN levels and the cause of the reduced NKCC is unknown. Alpha-IFN levels are not raised early in the course of RA.
+France Clear Favorite on 2022 World Cup Odds
+
+The 2018 FIFA World Cup came to a conclusion on Sunday as France posted a 4-2 victory over Croatia to claim their second World Cup title in 20 years and pay out on +700 pre-tournament World Cup championship odds.
+
+Sunday’s victory as +110 favorites on the World Cup game line odds continues France’s torrid play at recent international tournaments. Les Bleus came within an extra time goal of the Euro 2016 championship, falling to Portugal by a 1-0 score in their only defeat at a major international tournament since the quarter-finals of the 2014 World Cup.
+
+With a youthful lineup led by 19-year-old Kylian Mbappe, who garnered Best Young Player Award honors at this year’s tournament, France’s future looks bright. Fresh off the heels of their victory this weekend, Les Bleus opened as clear +500 favorites to successfully defend their title on the 2022 World Cup odds.
+
+While Sunday’s loss as +300 underdogs proved to be a massive disappointment for Croatia, the Blazers’ impressive drive to their first-ever berth in a World Cup final has earned them hard-fought status as one of the world’s elite squads. However, Croatia’s heroics at Russia 2018 have done little to boost them on the early 2022 World Cup betting lines, where they lag well behind the favorites as a +5000 wager.
+
+A trio of squads coming off disappointing performances at this year’s tournament closely follow Les Bleus on the 2022 World Cup championship odds, with Brazil pegged at +700, ahead of Spain at +750, while 2014 title holders Germany sit at +800.
+
+The Canarinho traveled to Russia as +400 pre-tournament favorites on the 2018 World Cup odds, and looked poised for a deep knockout stage run after closing out the group stage with a pair of clean-sheet wins. However, Brazil was unable to solve a high-powered Belgium squad in a 2-1 loss that marked their third quarter-final exit in their past four tournament appearances.
+
+Spain made a second straight early exit at this year’s tournament, falling to Russia on penalties in a Round of 16 match, which marks their only knockout stage appearance since raising the hardware at the 2010 World Cup.
+
+Russia 2018 also proved to be a bitter disappointment for Germany, who closely followed Brazil at +475 on the World Cup futures entering the tournament. However, a shocking 1-0 group stage loss to Mexico as heavy -210 favorites set the tone for Die Mannschaft’s shortest run at a World Cup since 1938.
+
+Belgium Trails on 2022 World Cup Betting Lines
+
+Further down the 2022 World Cup odds, Belgium sits at +1100, followed by Argentina at +1200, and Italy at +1800, while England joins the Netherlands at +2000.
+
+Les Diables Rouges led all squads with 16 goals at Russia 2018, and saw a 25-match unbeaten streak come to an end with a 1-0 loss to France in the semi-finals. Argentina posted just one win in four matches at this year’s tournament, and maintains strong odds despite the uncertain future of superstar Lionel Messi, while Italy and the Netherlands face daunting rebuilding tasks after both European powerhouses failed to qualify for this year’s tournament.
+
+Conversely, England sports a youthful roster, led by top goalscorer Harry Kane, which is likely to make the Three Lions a serious contender at Qatar 2022.
+
+Kevin: before we do that, lets take a nice walk outside. *i nod and we dress ourselves accordingly. and then we walk outside. its quite cold*
+
+Zoe: *shivering slightly, my arms crossed over my chest to try and keep warm. after a bit of walking my nose is already starting to run due to the cold weather, and i can feel the snot building up inside* oooh boy, it's really cold out here, isn't it? maybe we should've stayed inside for a bit longer. *sniffles loudly and wipes my nose on my sleeve* well, let's make this quick and get back inside before we freeze our buns off!
+
+Kevin: *i chuckle and we keep walking. we suddenly come across a forest and you notice the trees are covered in white snow* look, zoe! thats beautiful isn't it? how old do you think these trees are?
+
+Zoe: *i nod in approval and look at you with a small smile* yeah kevy kev, i guess they are pretty cool. and umm... about their age... i dunno, they're probably pretty old? hundreds of years old maybe? it's hard to tell without seeing their rings or something. but they sure do look magical! *i grin a little. then i start smirking mischievously and run towards one, trying to shake it. soon enough, a buckload of snow is falling off the leaves and down to the ground, covering us* eeeekk! *i squeal and giggle* i did that a lot as a kid, you know? brrr! its cold tho!
+
+Kevin: hey, what do you think you are doing! *i chuckle and wipe the snow off my jacket*
+
+Zoe: *giggling uncontrollably, i shrug innocently* nothing much, just having some fun. it reminded me of when we used to go sledding during winter breaks back home. *rubs my nose with my fingers and sniffles a bit* but now that we're all wet from head to toe, don'tcha think it's time we went back inside? we can make some hot cocoa or play more video games, whatever floats your boat! :D
+
+Kevin: nah, i got a better idea. lets go sledding for real, like in your winter breaks back home. what do you say? *I giggle*
+
+Zoe: oooohhhh!!! that sounds awesome, kevin! you always know how to surprise me. but ummm... how are we gonna get sleds and stuff? it's not like they're growing on trees here. :P
+
+Kevin: heh good point. well. we just rent one from a hut or something! *nods and smiles. i shiver and sniffle as well as i got quite cold. we then walk towards the hut. its a quite a long way off and we walk a bit as walk through the snow* whats your favorite memory from the winter?
+
+Zoe: oh, there's a bunch! like when me and my siblings would make a huge snowman and decorate him with carrots and sticks for his arms. or when we'd have snowball fights till our hands were numb. or even when mom would make us hot chocolate afterward to warm up. but the best ones were definitely when dad would take us sledding at night, when everything was covered in fresh snow and twinkling with fairy lights. we'd roast marshmallows over an open fire afterward too. it was magical!
+
+Kevin: wow that sounds awesome. but yeah i've got a lot of good memories about sledding as well! it was always something special! *i nod and then we keep walking. after a while, we reach the hut and rent a sled* which color do you want? green, black or yellow?
+
+Zoe: eeeeh... i'll take the green one, please! it looks really fast. *smiling brightly, i run my hand over the smooth surface of the sled before grabbing onto the handlebars* alrighty then, let's do this thing!
+
+Kevin: so you have taste after all *i chuckle and then we walk outside of the hut and put the sled on the ground full of white fluffy snow*
+
+Zoe: hmmph! whatever do you mean by that? of course i have taste! *then i start sniffling loudly, my nose and throat making loud snorting sounds and you can see my nostrils narrowing quickly and vibrating as i inhale sharply. i cough and then i sniffle once again as i swallow my mucus, this time a bit less intense as my nose feels much less runny and much cleaner now. i walk towards the sled and sit down on it. once i'm settled in, i shout excitedly to you* alright kevin, let's goooo!!!!!
+
+Kevin: aww, don't you want to slide down together with me? *i give you puppy dog eyes*
+
+Zoe: pfft. you wish, kevin. *i smirk and cross my arms defiantly, trying to look tough. but then suddenly, without warning, i push off hard with my feet and start zooming down the snowy hillside, leaving a trail of powdery snow behind me. i giggle uncontrollably as the cold wind rushes past my face, making my cheeks feel like they're burning. just as i'm about to hit a small bump in the snow, i stick out my feet and slow the sled down, coming to a halt gracefully at the bottom of the hill. i turn around to see if you're still there and wave enthusiastically* come on, kev! catch up to meeee!! :D
+
+Kevin: *i wave back and then i walk down the hill towards you. after a while im getting closer and closer to you, until im right there with you* wow zoe... you were faaast!
+
+Zoe: hehe, thanks kevin! but that's not all. i bet i can beat you in a race too! how about that? *grins challengingly and starts pushing the sled uphill, towards another snowy slope* c'mon, let's race! loser has to do something super embarrassing!
+
+Kevin: *as we arrive at the top of the hill i look around* umm zoe.. we just have one sled. how are we supposed to race against each other?
+
+Zoe: pfffft, that's easy peasy lemon squeezy! you take turns, dummy! *rolls my eyes and laughs, pulling myself up onto the sled. looks at you expectantly* so are you ready to lose? :P
+
+n**(-9/22)
+Simplify ((q/(q*q**11/q*q))/(q**0*q))**(-12) assuming q is positive.
+q**144
+Simplify (s/s**22)/s*s**(-2/11)*s*s assuming s is positive.
+s**(-222/11)
+Simplify (y/(y*(y/(y/(y/(y*y*y**(3/5)))))/y*y))**(-7) assuming y is positive.
+y**(-56/5)
+Simplify o**(-6)*o**13 assuming o is positive.
+o**7
+Simplify q**(-23)*q*q*q**5 assuming q is positive.
+q**(-16)
+Simplify (t/t**(3/10))/(t**(-1)/t)*t*t**(2/3)*t**(-2/17)*t assuming t is positive.
+t**(2677/510)
+Simplify j/j**1*j**(2/15)*(j**(-4)/j)/j*j/(j/(j**(7/5)/j)) assuming j is positive.
+j**(-82/15)
+Simplify d**(-2/13)*d**(-4)*d/(d/(d/d**(-4/5)))*d**(1/5) assuming d is positive.
+d**(-28/13)
+Simplify (((z*z/((z/z**6)/z))/z)/z**(4/3))**(-41) assuming z is positive.
+z**(-697/3)
+Simplify (r**(-1)/r)**(-5/4) assuming r is positive.
+r**(5/2)
+Simplify (j**2/j)**(-33)/(j**(-1/5))**(1/21) assuming j is positive.
+j**(-3464/105)
+Simplify f**(-6)/f*f**(3/2)*(f**1/f)/f**(-5/2) assuming f is positive.
+f**(-3)
+Simplify (v**(2/7)/v)/(v*v**(-2/7)*v)*v**4*(v/(v*v/(v**(-8)*v)))/v assuming v is positive.
+v**(-52/7)
+Simplify ((c/(c*c*c/((c*c**19)/c*c)*c)*c*c)/c)/(((c**(8/9)/c)/c)/c*c) assuming c is positive.
+c**(172/9)
+Simplify (k**(1/3))**(6/17)/(k*k*k/(k*k*k**(2/11)/k*k)*(k*k*k**(3/4))/k) assuming k is positive.
+k**(-1833/748)
+Simplify (q**4*q**(2/11))/((q/q**(1/7))/((q/(q*q**(1/17)*q))/q)) assuming q is positive.
+q**(1657/1309)
+Simplify ((c*c/(c**(3/5)*c))**(-15))**(-15/7) assuming c is positive.
+c**(90/7)
+Simplify (m*m/((m*m**(-3)/m*m)/m))/((m/(m**(1/7)/m)*m)/m)*m*m**9*m/(m/(m*m**(-9))*m)*m assuming m is positive.
+m**(36/7)
+Simplify (v*v/(v/(v*v/(v*v*v**(-2/7)))))**(-13)*(v*v/v**(2/3))**(2/15) assuming v is positive.
+v**(-5209/315)
+Simplify (((o/(o/(o**(1/3)*o*o)))/o*o)**(-1/8))**22 assuming o is positive.
+o**(-77/12)
+Simplify (j*(j**(-5)*j)/j)/j*((j/((j*j**(-1)/j*j*j)/j))/j)/j*((j**(-6)*j*j)/j)/(j*j**(-6)) assuming j is positive.
+j**(-6)
+Simplify w*(w*((w/(w/((w/(w*w/(w*w/w**15)*w*w*w*w*w*w))/w)*w*w))/w*w*w*w)/w)/w*w/w**(1/15) assuming w is positive.
+w**(-301/15)
+Simplify ((i**7/i)/i*i/i**(-5))**40 assuming i is positive.
+i**440
+Simplify (r**0)**33 assuming r is positive.
+1
+Simplify (b**(-17)*b*b**(-10/7))**(5/8) assuming b is positive.
+b**(-305/28)
+Simplify (a**(-2/3)*a)/a**3*(a/(a*a*a**(2/3))*a)/a*a*a/a**(-2/9) assuming a is positive.
+a**(-19/9)
+Simplify (x/x**(-3/2))**48 assuming x is positive.
+x**120
+Simplify ((o*o**(-33/4)*o)/o)/(o**(-48)/o*o) assuming o is positive.
+o**(163/4)
+Simplify (t**(2/9)/(t/(t*(t*t/(t**(-4/5)*t))/t)))**(2/61) assuming t is positive.
+t**(92/2745)
+Simplify x**(1/2)/(x**(-4)/x)*(x/x**(-1))**(-50) assuming x is positive.
+x**(-189/2)
+Simplify l**(-2/31)*l**(-13)/l assuming l is positive.
+l**(-436/31)
+Simplify x**(-2/13)*x**(-20) assuming x is positive.
+x**(-262/13)
+Simplify (h**(28/5))**(-15) assuming h is positive.
+h**(-84)
+Simplify ((w*w*(w*w**(-5/4))/w)/(w*w*w/(w*w/w**(1/13))*w))**(3/17) assuming w is positive.
+w**(-207/884)
+Simplify (x**(2/7))**(1/44) assuming x is positive.
+x**(1/154)
+Simplify a**(-25)*a*a**(3/31) assuming a is positive.
+a**(-741/31)
+Simplify m**(1/3)/m**6*m**3/(m*m*m*m**(-5)/m) assuming m is positive.
+m**(1/3)
+Simplify (((h*h/(h**14*h))/h)/h)/h*h**4 assuming h is positive.
+h**(-12)
+Simplify (x**(-2)*x)**(-1/17)/((((x**(1/3)/x)/x)/x)/x*x*x*x/x**11*x) assuming x is positive.
+x**(547/51)
+Simplify (h**(-2/7)*h/(h/(h*h/(h*h*h**(2/9))*h)))/((h*(h*h/h**6)/h)/h*h**2) assuming h is positive.
+h**(220/63)
+Simplify m**9/m*m/m**(3/20) assuming m is positive.
+m**(177/20)
+Simplify ((q**(-8)*q)/q)**(2/15) assuming q is positive.
+q**(-16/15)
+Simplify (x**(4/9)/x**(2/29))**(2/15) assuming x is positive.
+x**(196/3915)
+Simplify (f**(-1/6))**3/((f/(f**10/f*f))/(f**(4/11)/f)) assuming f is positive.
+f**(173/22)
+Simplify (i*i**(1/2)/i*i)/i*i**(2/11)*i**(1/3)*i**(-6)/i assuming i is positive.
+i**(-395/66)
+Simplify (j/(j*j**(-4))*j**(2/5))/(j**(-4)*j**(1/2)) assuming j is positive.
+j**(79/10)
+Simplify (j/(j*(j/j**(2/13))/j*j))/j**(1/2)*j**(-2/7)*j**1 assuming j is positive.
+j**(-115/182)
+Simplify (k**(-6/5)*k*k*k*k*k*k*k**(2/9)/k*k)**(-3/8) assuming k is positive.
+k**(-113/60)
+Simplify ((h*h**(-3/2)*h)/(h*h/h**(-6)))/(h**(-2/3)/h*h/(h**(-5/4)*h)) assuming h is positive.
+h**(-85/12)
+Simplify y*y*y**(-3/2)*y/y**10*y**(2/7)/y**(-8) assuming y is positive.
+y**(-3/14)
+Simplify (s**(-1/6)/(s/s**(-3/5)))/((s*s**(1/3))/(s/(s**(-3)*s*s))) assuming s is positive.
+s**(-11/10)
+Simplify t/(t/(t*t**(-15/2)))*t/(t**9/t) assuming t is positive.
+t**(-27/2)
+Simplify s*s*s/s**(-8)*s*s/s**(-11)*s assuming s is positive.
+s**25
+Simplify (c*c**(-3))**(7/2)*(c**(2/9))**(1/17) assuming c is positive.
+c**(-1069/153)
+Simplify d**(3/8)*d*d*d**(-2/5) assuming d is positive.
+d**(79/40)
+Simplify (h/h**(-1/11))/h*h*h**(-3/4)*(h**(-2)/h)/(h*h*h**0) assuming h is positive.
+h**(-205/44)
+Simplify (u*u**(8/7)*u)/(u*((u*u**(-3/4))/u)/u*u*u)*(u*u**(-4))/(u/(u*u/(u**(-2/11)/u*u))) assuming u is positive.
+u**(23/308)
+Simplify ((o**(-4/7)*o)/o**0)/((o*o**(-6/11))/(o*o/o**(1/5)*o)) assuming o is positive.
+o**(1068/385)
+Simplify ((c/(c*(c/(c**4*c)*c)/c*c))/(c/c**(-4)))/((c*c**2*c)/(c/c**(-4/5))) assuming c is positive.
+c**(-21/5)
+Simplify a**7*a*((a**(17/4)*a*a)/a*a)/a*a assuming a is positive.
+a**(57/4)
+Simplify ((n*n**5*n*n*n)/n*((n/n**(2/5))/n*n)/n)**(-1/11) assuming n is positive.
+n**(-38/55)
+Simplify (s/(s/s**(3/5)))**3 assuming s is positive.
+s**(9/5)
+Simplify (v*v**(-1/16))/((v**1/v)/v) assuming v is positive.
+v**(31/16)
+Simplify ((d**0)**16)**26 assuming d is positive.
+1
+Simplify i**(-9)*i**(-17) assuming i is positive.
+i**(-26)
+Simplify (((k*k*(k*k**6)/k)/k)/(k**(-3/4)/k))/(k/(k*k**2*k))**(16/3) assuming k is positive.
+k**(99/4)
+Simplify (p**(-4)*p/(p*p**(-4)))**(1/23) assuming p is positive.
+1
+Simplify l**(5/6)/l*l*l**(-7/2) assuming l is positive.
+l**(-8/3)
+Simplify t/(t**15/t)*(t/(t/(t**(2/3)*t)))/t assuming t is positive.
+t**(-37/3)
+Simplify ((b*b**14*b)/b**12)**11 assuming b is positive.
+b**44
+Simplify ((g*g**(2/13))/g)/g**(-6) assuming g is positive.
+g**(80/13)
+Simplify (v/v**(10/7))**(2/87) assuming v is positive.
+v**(-2/203)
+Simplify (t/(t*t**(-4/5)))**(-50) assuming t is positive.
+t**(-40)
+Simplify g**(-2/7)*g**(-2)*(g*g/(g/g**(-1)*g))**(-2/101) assuming g is positive.
+g**(-1602/707)
+Simplify ((v*v**(-1/4))/(v/(v*v/(v**(-1/2)/v)*v)))/(v**(2/7)/v)**(5/7) assuming v is positive.
+v**(933/196)
+Simplify (b**(-3/5)*((b/(b/(b*b**(-1))))/b*b)/b)/(b**(1/3)*b**10/b) assuming b is positive.
+b**(-164/15)
+Simplify (h**(1/14)*h**(-4)*h)**(1/39) assuming h is positive.
+h**(-41/546)
+Simplify (y**(-1))**(-1/18)*(y*y/(y/(y**(-2/5)*y))*y)**(-45) assuming y is positive.
+y**(-2105/18)
+Simplify (z**(-2/11)/z*z)**(-3/23) assuming z is positive.
+z**(6/253)
+Simplify (k*k**(-1))**14*k**(-1)*k**5/k assuming k is positive.
+k**3
+Simplify ((m*m**(-2/7)*m)/m**(-4))/(m*m*m**(-4)/m*m*m*m/m**5*m) assuming m is positive.
+m**(68/7)
+Simplify ((j*j**(-2))/j)**(-2/61)/((j*j/j**1)/j*j)**(-35) assuming j is positive.
+j**(2139/61)
+Simplify (u**(-1/12)*u)**17 assuming u is positive.
+u**(187/12)
+Simplify ((z**(-2/17)*z*z)**(7/3))**(2/5) assuming z is positive.
+z**(448/255)
+Simplify i**(-1/15)*i**10*i assuming i is positive.
+i**(164/15)
+Simplify (w**3/((w/w**(5/3))/w*w))**(-2/109) assuming w is positive.
+w**(-22/327)
+Simplify z**(2/17)/z*z**(7/4) assuming z is positive.
+z**(59/68)
+Simplify ((s*s/(s/(s**(-6/5)/s)*s))/s)/s**(4/5) assuming s is positive.
+s**(-4)
+Simplify i**24*i*i/i**(-6)*i assuming i is positive.
+i**33
+Simplify ((v*v*v/(v*(v*v*v**(-1/9)*v)/v))/(v/v**6*v*v))/(v**(-1/5)/v**3) assuming v is positive.
+v**(284/45)
+Simplify (n/(n*n/(n/(((n*n**(-4))/n)/n)*n))*n**(-2/9))/(n*n*n**4*n*n**(-1/3)) assuming n is positive.
+n**(-8/9)
+Simplify ((l/l**(-1/11))/l)/l**(-24) assuming l is positive.
+l**(265/11)
+Simplify l**3*(l*l**(-8)*l)/l assuming l is positive.
+l**(-4)
+Simplify ((k/k**(-3/2))/k**(12/7))**(2/29) assuming k is positive.
+k**(11/203)
+Simplify (((t*t*t*t*t*t/t**(-1/12))/t)/(t*t**(-2/3)))**28 assuming t is positive.
+t**133
+Simplify (g/(g**(2/23)/g))/(g*g*((g*g*g**(11/4))/g*g)/g*g) assuming g is positive.
+g**(-445/92)
+
+Es war einmal ein mutiges und kluges Eichhörnchen namens Svenja, das in einem wunderschönen Wald lebte. Svenja war im ganzen Wald für ihr schnelles Denken und ihre Tapferkeit bekannt. Und ebenso war sie immer bereit, ihren Freunden in der Not zu helfen.
+Eines Tages war Svenja unterwegs, um Nüsse für den Winter zu sammeln, als sie ein seltsames Geräusch hörte, das von einem nahen Baum kam. Sie kletterte auf den Baum, um nachzusehen, was da los war. Dann sah sie eine Gruppe fieser Vögel, die einen kleinen, hilflosen Vogel ärgerten.
+Svenja war sofort klar, dass sie eingreifen musste. Also fasste sie schnell einen Plan. Sie sammelte so viele Nüsse ein, wie sie tragen konnte, und warf die Nüsse auf die fiesen Vögel. Sie zielte so gut, dass die meisten Nüsse die fiesen Vögel direkt am Kopf trafen. Die fiesen Vögel waren von dem plötzlichen Angriff überrascht und flogen verärgert davon.
+Der kleine Vogel war Svenja dankbar, dass sie ihn vor den fiesen Vögeln gerettet hatte, und bedankte sich mit einem fröhlichen Zwitschern. Von diesem Tag an war Svenja als das mutigste und freundlichste Eichhörnchen des Waldes bekannt, und sie half weiterhin allen, die in Not waren, wann immer sie konnte.
+
+5 Surprisingly Easy Tricks to Make Running a Habit
+
+You were really excited…
+
+You had signed up for a 6k run in your neighbourhood. You had also joined the local running club.
+
+You were really motivated, weren’t you?
+Your willpower was on a sprint and you were geared up to bolt towards the finishing line.
+
+But then…
+
+You went for a vacation or a work trip for a week.
+What happened when you got back?
+
+Do you still have that initial momentum?
+Do you feel like giving up, because starting over is such a pain?
+Is it tough to find time?
+
+Sticking to a new habit isn’t easy.
+
+I know! I had tried to make running a habit for ages and failed miserably.
+
+Eventually I got tired of failing.
+That’s when I began to read about the science of habit formation. I tried to find smart and simple ways to make habits stick.
+
+Today I can lace up my shoes and go for a regular jog every 4-5 days a week and with ease.
+
+Check out these 5 surprisingly easy tricks that have helped me make running a habit:
+
+1. Create a trigger
+
+According to Charles Duhigg, the bestselling author of “The Power of Habit”, Triggers act as conscious or subconscious reminders to perform a behaviour.
+
+Triggers could be visual reminders. Try keeping your running gear and shoes next to your bed so you see them first thing in the morning.
+
+Triggers can also be action based. I run in the evenings and my trigger is “right after I drink my evening coffee, I will go running”.
+
+2. Be specific
+
+During the first 4-6 weeks of picking up running as a habit specify a time of day (or night), the exact trail you will go for the run, duration of the run and at what time will you leave for the run.
+
+The more specific you can make the action, the easier it is to implement it everyday.
+
+You can use this statement: “I will go running every Monday, Tuesday, Thursday and Friday at my neighbourhood park in the evening at XX pm (write the time here) for 30 minutes”.
+
+3. Start small
+
+Habit coach Rob Norback strongly advocates the half-and-half rule. If you want to run for 20 minutes every day, cut it into half (10 minutes) then half it again (5 minutes). That’s where you should start.
+
+Doesn’t that sound a lot more achievable?
+Even if you can run for 10-15 minutes, stick to a 5 minute routine until it becomes second nature. Only once it’s become a habit should you start running for longer periods.
+
+How does this help?
+
+You complete your goal in 5 minutes and that brings a sense of accomplishment which is essential to building habits.
+
+You overcome any procrastination or hurdles (you woke up late, have to rush to office, send the kids to school) that you may face, since you have to invest only 5 minutes.
+
+4. Forgive yourself
+
+If you miss a day (which you inevitably will) do NOT berate yourself.
+
+Missing a day is no big deal. But assuming defeat because you missed 1 day or 2 days in a row (or a whole week while vacationing), is a huge mistake.
+
+Negative thinking will make you give up. If you think you have failed or you are lazy or you are not good at running, it will stop you from taking further action.
+
+5. Get a good night’s sleep
+
+Sleep matters! If you are not getting at least 6.5 hours of shut eye every night you will be tired, with little energy to focus on habit changes.
+
+You might make it to the park when your enthusiasm and motivation for running is high, but the moment things get even slightly difficult, you’ll skip the habit because as a sleep-deprived person you wouldn’t have the willpower to push yourself through a little discomfort.
+
+Why 6.5 and not 7 hours?
+Because, Tony Schwartz, Energy Coach, recommends that half an hour of exercise can actually compensate for half an hour of sleep and give you more energy in the bargain!
+
+What habit do you want to pick up?
+
+Work out at home, follow a diet, wake up early, learn music, maybe a language, study for a certification?
+
+These principles work for any kind of habit formation. Try it!
+
+Want to know about that one core ingredient for forming any habit? Sign up for our Blog.
+Thursday, May 14, 2009
+
+Again between two guys a hell of a lot smarter than you. Me and James.
+
+Just a reminder Channelup is in Italics, James in regular font.
+
+Yo buddy
+
+Last night's lost was nothing if not interesting. I liked it (thought it could have been an hour and a half) and thought it did a pretty good job setting up next season. Writing about it was insanely hard as I had a lot of trouble gathering my thoughts and putting them in a coherent format. I obviously wanted to avoid just straight summarizing, but there was so much going on. Anyway I thought I would add a couple of more thoughts that didn't make it into my post.
+
+- I kind of mention this but the good/evil thing is really going to be the main focus of the last season I think. Ben and Mystery Island guy leading the charge to keep the island secret from everyone with others (Richard Alpert maybe? Shadow of the statue group?) fighting for their own end games. That storyline has the potential to be awesome and maddening at the same time.
+
+- The bomb explosion will probably make it so that the Oceanic crew (plus Miles and Juliette) can somehow jump back to the present and back into the fray. One thing I liked about this season with them alternating between different points in time, is that there wasnt too much overlap and confusion with the characters. Basically keeping it so that everyone easnt always running into each other worked for the production of the show. Putting them all back in to the same time, with Alpert and company's increasing role, plus this new faction, could be tough.
+
+Any other thoughts? I think I have now written 10,000 words on Lost.
+
+Interesting idea about the bomb sending the main characters forward in time. Supporting that idea is the fact that they used the exact same screen effect when we are meant to believe the bomb goes off as when we have traveled in time previously.
+
+So this foil to Jacob doesn't actually resurrect Locke - but turns himself into an image of Locke? So are we meant to believe this guy also turned himself into a vision of Jack's Dad, Walt, etc? Even though it's bizarre, I suppose it's at least a consistent explanation.
+
+I am not sure if I like the idea of the island being this place where two gods are battling for supremacy. I also don't get why Jacob would just let Ben wave that knife around and then kill him(if he is indeed dead) considering he earlier exercised the power to bring a human being back to life when Locke was thrown from the window. And to be honest, I also thought the "Jacob was actually there at all of these huge moments in all of the Losties lives" got extremely old after the first couple. The first one I was like WHOA!!! and then after that it sort of felt like cheap thrills. Jacob sitting on a bench...Locke falls from the window! Can you believe it?! Jacob was there when Locke was thrown out of the window, too! So I guess what I am saying is, I agree that the episode stands up a lot better as an hour and a half instead of 2 hours. This is sort of a shame considering I felt like some of the other huge plot points were sort of rushed.
+
+We need to see Jacob at Sun and Jin's wedding, but all we get for the most pivotal turning point is the episode is Juliet saying "I changed my mind. I saw the way you looked at her," and a weak explanation? Juliet similarly instantly changes her mind in the sub to get them back to the island...I guess she didn't see any suspicious looks by Sawyer in any of the other dozens of times he and Kate interracted since she got back? I just thought this was a very hurried and sloppy way to make sure everyone got back on the island while also letting Jack's plan carry on. It felt like forced drama, which LOST has done a good job avoiding this season. Easier would have just been to not place Sawyer, Juliet, and Kate on the sub...avoid some empty action scenes of their escape, Sawyer and Jack's fight, the "Why'd you stop," "That's why dude," Hurley and Jack moment, and so on.
+
+Why couldn't Juliet have given her "i saw the way you looked at her" speech when Sawyer first suggests going on the sub in the first place? We are still in the same place, but we have room for further development elsewhere. Would it have been so bad if we saw MIles saying to his father, "Now I understand why you did it," and then playing a bigger role in all of this instead of just having this awesome character making snarky comments in the background from time to time? Perhaps another interraction between Jacob and Evil Jacob at some other point in time(like when Oceanic 815 crashes). My overall point is, as I am sure you can tell by now - a few storylines left me wanting more and a few left me wanting decidedly less. I think either trimming it down, or re-organizing it while dropping the fluff would have been a far more impactful finale. I do agree though, that the events that happened set us up well for next season.
+
+Totally agree about the Jacob appearances. I thought some were cool (Sawyer, Sayid, Locke) and some were stupid (Jin and Sun, Jack). Also they kind of throw you off with Juliet's parents getting divorced and Jacob not showing up. When he doesnt show it kind of makes the whole thing some weird set up for why she leaves Sawyer. To be honest, the whole Sawyer, Kate Juilet thing has annoyed me for a while and I find it very hollow. What I did enjoy about Sawyer though was the genuine anguish (not for losing Juliet), but for losing the life he had in the Dharma Initiative. He was kind of saying, "I finally made a normal life for myself and you (Jack) came along and f-ed it up like you always do." That is where I felt most pity for him as a character.
+
+Also the scene where they are about to explode the bomb was beyond ridiculous considering an alarm is going off, the Dharma initiative is on to them, Sayid is dying and every sits around to talk about their feelings for ten minutes. No possible way.
+
+Agree totally about the sub and its uselessness in the overall plot. Just a filler. I doubt Jacob is actually dead and we need to consider that his body is most likely just some kind of vessel to a more supreme being. I don't know if I love these God implications because they complicate things almost more than time travel does. People with God-like powers (Sylar) are just as impossible as those who try and change the future or past.
+The true test of character is not how much we know how to do, but how we behave when we don't know what to do.
+
+Q:
+
+What does "schnäuzen" mean? And "schniefen"?
+
+A:
+
+"Schnäuzen" is German and means nose blowing. "Schniefen" on the other hand means to sniffle. Sniffling and nose blowing are polar opposites. Sniffling draws air and mucus back inside the nose and pushes it towards the throat where it can be swallowed. Nose blowing expels mucus towards the outside and makes it visible on the nostrils or tissues.
+
+Friday, August 28, 2009
+
+Free from blackness
+
+Independence day celebration is just around the corner. It’s been 52 years our beloved country celebrated independence and our country had achieve a lot since then. This time around since the independence fall on Ramadhan time so I bet there will be not many concerts or socialize party organized in KL or anywhere else but then, it’s just my predictions, other races might as well did it.Talking about independence, what has we, as the children of the post independence know about the value of freedom? Freedom means free from any colonization if that what it means from the past but nowadays out culture are so much been conquered by other races, culture. Our country fills with “PATI”. Anywhere we walk we can see many faces and sometimes I wonder, am I the foreigner here?Yeah2 I know the globalization means that you have to accept the windows of the world into your world but then if the newcomers come and made a hell out my country so what it is going to be? It’s ok for them to work here and made a decent earning with living peacefully with the locals but the main problem is the one that cause the social problem. What we saw in newspaper and news are just the tips of the reports and I’m pretty sure there are many more cases of robbery, thief, snatch, rape, murder involving these ‘type’ of people. Mastika (August Edition) had some stories of how the Negro affecting our life here in Malaysia. Sometimes I wonder, how can they come here? With so many of them? And the usual stories that link with Negro are theft, “pukau”, money counterfeit, rape (which was at first called love).i like to gather some info from all of you about the last one. We see and find this thing in KL right? We can see a nice lovely Malay girls walking along MidValley, hold hand with some Black tall guy. I still wonder why on earth that these ladies picked and fall in love with the Negro? I means they are Christian (some might be Muslim), Black( if you want to choose black, it’s better to choose the Indian) and not handsome ( Malays are so hotter than them)? Why and How? And if their love story end with happy ending good for them but the problem is the ending just like in the 999 (tv3 program).The Negro slept with the girl and then he dumped her and to make matter worse, the girl pregnant and the child with the DNA of Negro was born. So who’s to blame here? The Negro of course, but the girls too.What makes Negro or (in the whole) the foreigners better than the locals? I can stand Malays girls couple with Indians or Chinese as long as same Religion (I mean Islam of course), but I can’t stand if Malays or Chinese or Indians couple with foreigner. It’s like the man from our country had extinct that force them to find foreigner. The same usual lame reasons for these girls to find Negro or “Mat Salleh” are romantic, caring, loving and obviously richer. I would say it is bullshit. The story had been always having the same ending.This is also one type of colonization and proofs that we, Malaysians still not fully achieve Independence. We always value the outside goods higher than our own local goods without ever considering the quality first.The value of Independence means nothing if just some people say aloud “Merdeka” each year and put on the flag on the car, house or office. The values of independence should come within the heart of every Malaysian and together we care and cherish this gift for the good of the future.Happy Independence Day!p/s – My car might not have the flag of Malaysian but in my heart, the love of this country, none can compared with. Well, I shall put on the flag afterwards. Hope all of you did the same things. The first is Islam and the second is Malaysia and I do mean “Malay-sia”.
+.versionSelectItem {
+ display: grid;
+ grid-template-columns: 70px auto 130px;
+
+ .changeLog {
+ overflow: hidden;
+ text-overflow: ellipsis;
+ white-space: nowrap;
+ padding-right: 10px;
+ }
+}
+
+class SwiftMethod < SwiftEntityElement
+end
+
+Co-Op program helps wounded warriors transition
+
+Story Highlights
+
+Former Staff Sgt. Anthony Moralez was placed in a civilian position at White Sands Missile Range thanks to the Wounded Warrior Co-Op Program.
+
+Former Staff Sgt. Anthony Moralez was placed in a civilian position at White Sands Missile Range thanks to the Wounded Warrior Co-Op Program.
+
+WHITE SANDS MISSILE RANGE, N.M., Nov. 5, 2009 - White Sands Missile Range has initiated a Wounded Warrior Co-Op Program to help expedite recruitment efforts while at the same time helping Soldiers transition to civilian life.
+
+Former Staff Sgt. Anthony Moralez was assigned by the battalion to work with CPAC to help develop the program. He was subsequently placed in a civilian position.
+
+"This program is something I'm very passionate about," Moralez said. He explained that not too long ago he was sitting in the WTU wondering what life had in store for him. "Quite honestly I was worried!" he said.
+
+Then last year he met the EEO and CPAC office staff and he said they were extremely passionate about helping the Soldiers "Give back". When he was approached to help with the startup of the program Moralez said he jumped at the opportunity. While developing the concept plan, Moralez said he realized that the program will only work if the individual wants it to work and is willing to give up a few things to gain others.
+
+"I feel good about the program for two reasons, I helped develop it and it worked for me," Moralez said. "I'm telling you, if you walk through this door many others will open. The trick is to get thru that first one!"
+
+Soldiers eligible for this program are those in the battalion who are transitioning out of the Army. Those Soldiers who apply for the program, with an endorsement from the Warrior Transition Battalion commander, can be placed in a federal civilian position at White Sands Missile Range for up to 90 days, pending release from active duty.
+
+Upon successful completion of the trial period and upon honorable release from the military, if approved by the appropriate civilian selecting official, the eligible Soldier may be appointed to the civilian position.
+
+"Tony has been an outstanding addition to DPTMS. If you're looking for adaptive, resourceful self-starters with good operational sense, look to the Wounded Warrior Program. I just found out I have two more openings and I plan to bring in two more," said Gerry Veara, White Sands DPTMS.
+
+According to Sally Smoot, White Sands CPAC director at the time this article was written, the program is a win-win situation. "Our managers get to fill their jobs quickly, and we get to take care of our Soldiers who have taken care of us."
+
+"Under the Equal Employment Opportunity umbrella, the Wounded Warrior Co-Op Program fits well into the objectives of the Disabled Veterans Affirmative Action Program Plan. Those warriors who are a part of the Wounded Warrior Battalion have combat related disabilities they received while serving in the war on terrorism," said Liz Childers, EEO officer.
+
+Childers said it is the goal of the EEO office to ensure that disabled veterans are offered equal employment opportunity in the federal service. "With the collaborated effort of the Civilian Personnel Advisory Center and William Beaumont Army Medical Center, the objective is to recruit and employ those wounded warriors with the required skills needed to fulfill the mission of White Sands Missile Range," she said.
+
+Applications for this Program are available online at www.wsmr.army.mil/employment.
+
+Questions pertaining to this Program may be directed to Carol Main at (575) 678-7728, DSN 258-7728.
+Q:
+
+New column from previous columns in Pandas
+
+I have a pandas dataframe with some columns:
+>>data.columns.values
+array(['Sheet', 'Row', 'Column', 'Cell', 'V0', 'Thx', 'dV', 'Vd'], dtype=object)
+
+Each row contains a different value for the Sheet, Row, etc etc.
+From the info of Sheet, Row, etc I will create a PDF file title like this:
+title = Sheet%s_Row%s_Column%s_Cell%s.pdf
+So instead of iterating over each row of the DataFrame and create a single title each time, I wanted to directly create another column of strings called title and store the different titles like this:
+data['title'] = "Sheet%s_Row%s_Column%s_Cell%s" % (data['Sheet'], data['Row'], data['Column'], data['Cell'])
+
+But this is not working, seems like it is appending each Serie inside each %s
+How can I create this title column from the info on each row without having to iterate over the entire DataFrame?
+
+A:
+
+One way to do this would be using DataFrame.apply() with axis=1. Example -
+data['title'] = data.apply(lambda row: "Sheet{}_Row{}_Column{}_Cell{}".format(row['Sheet'], row['Row'], row['Column'], row['Cell']) , axis=1)
+
+Demo -
+In [52]: df = pd.DataFrame([['A','B'],['C','D'],['E','F']] , columns=['Sheet','row'])
+
+In [53]: df
+Out[53]:
+ Sheet row
+0 A B
+1 C D
+2 E F
+
+In [54]: df['title'] = df.apply(lambda row: "Sheet{}_row{}".format(row['Sheet'],row['row']) , axis=1)
+
+In [55]: df
+Out[55]:
+ Sheet row title
+0 A B SheetA_rowB
+1 C D SheetC_rowD
+2 E F SheetE_rowF
+
+
+The Joker (1960 film)
+
+The Joker () is a 1960 French comedy film directed by Philippe de Broca.
+
+Plot
+Edouard Berlon is a young, incorrigible seducer who moves very lightly from one affair to the next. He meets Helene Larouch, a woman married to André, a rich financier who is very busy with his affairs, leaving her in an emotionally arid life. Initially Helene resists Edouard's wooing, but as she gets to know his lively character, his eccentric lifestyle and his very unusual family environment, including his old uncle Théodose, his brother Pilou, servat Olga, some infants, and a few stray dogs, she lets herself become seduced. Their relation, however, turns out to be an ephemeral one as Edouard is busy seducing another woman.
+
+Cast
+
+ Anouk Aimée as Helene Larouch
+ Jean-Pierre Cassel as Edouard Berlon
+ Pierre Palau as Théodose
+ Geneviève Cluny as Pilou Berlon
+ Georges Wilson as Guillaume Berlon
+ Anne Tonietti as Olga
+ François Maistre as André Laroche
+ Jean-Pierre Rambal as Paul
+ Liliane Patrick as Solange
+ Irène Chabrier as Aline, servant at the inn
+
+Release
+The film had its premiere at the Locarno Film Festival in August 1960, but was not released commercially until 20 January 1961 in France and 7 August 1961 in New York. During the 2012 Cannes Film Festival, the film was presented with other classics at the Cinéma de la Plage, a non-competitive part of the official selection that is open to the public. In 12 November 2013, the film was presented at the Cinémathèque québécoise, Montréal.
+
+Critical response
+The film has been described as "a lot of genial fun" as the plot evolves. It also has been described as whimsical and in parts "nutty" for the eccentric lifestyle of the hero and his family. French critics, on the other hand, find subtle qualities in the presentation of the characters as uncle Théodose is described as "an original, old uncle" as well as poetic connotations in the overall work.
+
+References
+
+External links
+
+Category:1961 films
+Category:French films
+Category:French-language films
+Category:1960s romantic comedy films
+Q:
+
+C General sscanf return
+
+I'm trying to use the return value of sscanf function. The problem is that in the file that I'm reading, some lines may contain different number of integers. How can I tackle this problem?
+
+A:
+
+int values[5];
+int values_per_line = sscanf_s(line_buffer, "%d %d %d %d %d", &values[0], &values[1], &values[2], &values[3], &values[4]);
+
+`
+sscanf_s, _sscanf_s_l, swscanf_s, _swscanf_s_l:
+
+Return Value
+Each of these functions [including s_sscanf()] returns the number of fields that are successfully converted and assigned; the return value does not include fields that were read but not assigned. A return value of 0 indicates that no fields were assigned. The return value is EOF for an error or if the end of the string is reached before the first conversion.
+
+Hagar: *leaning against the tavern counter.* “Melinda, have you ever wondered what lies beyond the forest? The one that stretches out like a dark, ancient tapestry.”
+
+Melinda: *wiping down a mug.* “Beyond the forest? Hagar, you know as well as I do that it’s forbidden. The elders say there are creatures lurking there, waiting to snatch anyone who dares to cross the boundary.”
+
+Hagar: *grinning.* “Forbidden fruit always tastes the sweetest, my dear. What if there’s a hidden world, untouched by our mundane lives? What if there are secrets waiting to be unraveled?”
+
+Melinda: *rolling her eyes.* “You’re a dreamer, Hagar. But dreams can lead to nightmares. I’ve heard tales of lost souls who ventured too far. They say they become part of the forest itself, their whispers carried by the wind.”
+
+Hagar: *leaning in closer.* “And what if we could find a way to break the curse? To discover what lies beyond? Imagine the stories we’d tell, the songs we’d sing!”
+
+Melinda: *softening.* “Hagar, sometimes I think you’re the only light in this dreary village. But remember, curiosity killed the cat.”
+
+Hagar: *grinning wider.* “Ah, but Melinda, satisfaction brought it back.”
+
+Riddle: Using only addition, add eight 8s to get the number 1,000.
+
+Answer: 888 + 88 + 8 + 8 + 8 = 1,000. This is the kind of math riddle you can work out with times tables, or by simple logic. First, get as close to 1,000 as you can (888). From there, it’s easy to figure out the rest.
+
+Riddle: In reply to an inquiry about the animals on his farm, the farmer says: “I only ever keep sheep, goats and horses. In fact, at the moment they are all sheep bar three, all goats bar four and all horses bar five.” How many does he have of each animal?
+
+Answer: The farmer has three sheep, two goats and one horse. You can solve this animal riddle with a quick hypothetical. Take sheep: We know there are three animals that are goats and horses, so we suppose there are two goats and one horse. Checking this hypothesis gives us three sheep, which works out because there are four non-goats: three sheep, and one horse!
+
+70. Riddle: What five-letter word becomes shorter when you add two letters to it?
+Answer: Short
+
+71. Riddle: What begins with an "e" and only contains one letter?
+Answer: An envelope
+
+72. Riddle: A word I know, six letters it contains, remove one letter and 12 remains. What is it?
+Answer: Dozens
+
+73. Riddle: What would you find in the middle of Toronto?
+Answer: The letter “o”
+
+74. Riddle: You see me once in June, twice in November and not at all in May. What am I?
+Answer: The letter “e”
+
+75. Riddle: Two in a corner, one in a room, zero in a house, but one in a shelter. What is it?
+Answer: The letter “r”
+
+Related: Would You Rather Questions
+
+76. Riddle: I am the beginning of everything, the end of everywhere. I'm the beginning of eternity, the end of time and space. What am I?
+Answer: Also the letter “e”
+
+77. Riddle: What 4-letter word can be written forward, backward or upside down, and can still be read from left to right?
+Answer: NOON
+
+78. Riddle: Forward I am heavy, but backward I am not. What am I?
+Answer: The word “not”
+
+79. Riddle: What is 3/7 chicken, 2/3 cat and 2/4 goat?
+Answer: Chicago
+
+80. Riddle: I am a word of letters three; add two and fewer there will be. What word am I?
+Answer: Few
+
+81. Riddle: What word of five letters has one left when two are removed?Answer: Stone
+
+82. Riddle: What is the end of everything?
+Answer: The letter “g”
+
+83. Riddle: What word is pronounced the same if you take away four of its five letters?
+Answer: Queue
+
+84. Riddle: I am a word that begins with the letter “i.” If you add the letter “a” to me, I become a new word with a different meaning, but that sounds exactly the same. What word am I?
+Answer: Isle (add “a” to make “aisle”)
+
+85. Riddle: What word in the English language does the following: The first two letters signify a male, the first three letters signify a female, the first four letters signify a great, while the entire world signifies a great woman. What is the word?
+Answer: Heroine
+
+Related: 101 Funny Puns
+
+Really Hard Riddles for Adults
+86. Riddle: What is so fragile that saying its name breaks it?
+Answer: Silence.
+
+87. Riddle: What can run but never walks, has a mouth but never talks, has a head but never weeps, has a bed but never sleeps?
+Answer: A river
+
+88. Riddle: Speaking of rivers, a man calls his dog from the opposite side of the river. The dog crosses the river without getting wet, and without using a bridge or boat. How?
+Answer: The river was frozen.
+
+89. Riddle: What can fill a room but takes up no space?
+Answer: Light
+
+90. Riddle: If you drop me I’m sure to crack, but give me a smile and I’ll always smile back. What am I?
+Answer: A mirror
+
+91. Riddle: The more you take, the more you leave behind. What are they?Answer: Footsteps
+
+92. Riddle: I turn once, what is out will not get in. I turn again, what is in will not get out. What am I?
+Answer: A key
+
+93. Riddle: People make me, save me, change me, raise me. What am I?Answer: Money
+
+94. Riddle: What breaks yet never falls, and what falls yet never breaks?
+Answer: Day, and night
+
+95. Riddle: What goes through cities and fields, but never moves?
+Answer: A road
+
+96. Riddle: I am always hungry and will die if not fed, but whatever I touch will soon turn red. What am I?
+Answer: Fire
+
+97. Riddle: The person who makes it has no need of it; the person who buys it has no use for it. The person who uses it can neither see nor feel it. What is it?
+Answer: A coffin
+
+98. Riddle: A man looks at a painting in a museum and says, “Brothers and sisters I have none, but that man’s father is my father’s son.” Who is in the painting?
+Answer: The man’s son
+
+99. Riddle: With pointed fangs I sit and wait; with piercing force I crunch out fate; grabbing victims, proclaiming might; physically joining with a single bite. What am I?
+Answer: A stapler
+
+100. Riddle: I have lakes with no water, mountains with no stone and cities with no buildings. What am I?
+Answer: A map
+
+101. Riddle: What does man love more than life, hate more than death or mortal strife; that which contented men desire; the poor have, the rich require; the miser spends, the spendthrift saves, and all men carry to their graves?
+Answer: Nothing
+
+The Decision Maker
+
+Credit unions are well aware of the growing revolution in payments. A recent report by McKinsey & Company (Global Payments 2015: A Healthy Industry Confronts Disruption) noted that, the growth of nonbank digital competitors over the next five years will increase downward pressure on transaction margins while increasing growth in electronic payments.
+
+The drivers for this trend are all too familiar:
+
+Large technology companies such as Apple, Google, Facebook, Amazon, Microsoft, Tencent and Alibaba, are some of the most significant nonbank competitors. These organizations are cash-rich and have virtually captive customer bases.
+
+Smartphones have become a crucial channel in the world of payments. With these devices comes a swarm of payment options. These range from the likes of Apple Pay to “In-App” purchases that provide an almost seamless user experience.
+
+Member expectations for technology-enabled experiences have grown considerably. Today’s members, like any other consumers, have experienced an unprecedented level of service via nonbank providers. Some may wonder why their favorite credit union does not have the same level of digital service.
+
+Despite all the hype about the electronics payments, adoption by credit union members may tend to be slower than the public at large. Members tend to be more conservative so fewer are likely to be enthusiastic early adopters.
+
+However, this does not mean credit unions are complacent about this growing trend. The industry, especially its larger players, has begun to respond vigorously with various “digital wallet” strategies. While these efforts are in the formative stages, it is imperative that credit unions position themselves to members as the trusted alternative for safe and secure digital payments. From this positioning, members can be educated and motivated to become loyal users of the credit union’s digital payment platform.
+
+A crucial element to make this strategy successful is analytics. Making effective decisions in this fast-paced environment is crucial. The ability to adjust the tactical underpinnings of the strategy on a monthly, weekly, or even daily basis depends on the availability of transactional data for analysis. Having data quickly available at this level of granularity requires a well-designed and well-tuned data warehouse. This tool provides an essential feedback loop for decision makers as they guide the digital payments strategy toward meeting member needs and keeping those payments (and their margins) close to the credit union.
+
+We are missing an opportunity in this space. I would suggest that digital wallets and the associated strategies for a credit union implementation are great and should be pursued. As an industry however, we should own the entire transaction stack from the rails to the transaction. Our mobile transaction rails currently are owned and controlled by companies that are not credit union friendly. Additionally, the advent of blockchain technology will push massive disruption at the current banking infrastructure. Some have predicted the complete demise of banking as it currently exists as a result. Bottom line is the industry is fast approaching the need to innovate or die in my view. With that in mind, there is new pursuit of solutions that address both lines of thinking. Unfortunately, as an industry we remain focused on the wrong things. Instead, we need to think much bigger.
+
+Subscribe to Email Updates
+
+You now have more information at hand about your credit union than ever before. But are you using it to "out-think" your rivals? If not, you may be missing out on a potent competitive tool.
+
+This blog will:
+
+Educate subscribers about data integration and Big Data and Analytics.
+Send this page to someone via email
+
+WARNING: The following story contains descriptions that some readers may find disturbing. Discretion is advised.
+
+Quebec City police say a 39-year-old man has been arrested in connection with what they are describing as an attempted murder of a woman in her 20s.
+
+The incident happened on Friday evening when police were called to Arago Street West at around 9 p.m. after a man set a woman on fire before fleeing the scene.
+
+Paramedics rushed the woman to hospital with life-threatening injuries.
+
+READ MORE: Man seriously injured after setting himself on fire outside south London government office, SIU says
+
+Police say she suffered serious burns to her face, back and hands.
+
+“We fear for her life,” police said in a written statement on Saturday.
+
+Story continues below advertisement
+
+The suspect was arrested Saturday morning at around 11:35 a.m. on Girardin Street in Drummondville, roughly 150 kilometres west of Quebec City.
+
+Quebec City police spokesperson Etienne Doyon said the suspect was the victim’s ex.
+
+READ MORE: Multiple injuries after vehicle crashes into Quebec City building
+
+Doyon said a warrant had been issued for his arrest. He was wanted for attempted murder and aggravated assault.
+
+He is being held by provincial police in Drummondville.
+
+Investigators with Quebec City police were en route to interview the suspect.
+
+Doyon said police had yet to interview the victim herself.
+
+He confirmed reports that the woman’s mother and children had witnessed the attack.
+
+“The children were placed in the care of the grandmother,” he said, adding that police made sure they were being provided with the necessary support.
+
+Martyn Allard, who says he’s the victim’s neigbour, told Global News he was standing on his second-floor balcony Friday night when he saw someone running by.
+
+“I thought he’d dropped a burning torch on the street,” he said, adding he only realized it was a person when she started running and screaming, “I’m on fire, I’m on fire, someone lit me on fire!”
+
+Story continues below advertisement
+
+READ MORE: Evacuation at Quebec City airport terminal lifted, operations return to normal
+
+Allard said he called 911 and then rushed to the woman’s side to try and help her.
+
+“I was yelling at her ‘Madame get on the ground, madame get on the ground,’ but she was burning up like a torch,” he said.
+
+He described a strong smell of gasoline as he approached the victim and said he ripped her burning clothes off as he waited for a neighbour to bring a blanket.
+
+Allard said he grasped the victim’s hands as she appeared wobbly and talked to her to keep her alert.
+
+“She was talking about her kids,” he said.
+
+Story continues below advertisement
+
+— With files from The Canadian Press
+CCSU professors accused of sexual misconduct with students
+
+Photo: Journal Register Co. Photo: Journal Register Co. Image 1 of / 3 Caption Close CCSU professors accused of sexual misconduct with students 1 / 3 Back to Gallery
+
+Central Connecticut State University President Zulma R. Toro announced Tuesday that she is seeking to fire two longtime theater professors after investigators concluded that each had likely engaged in sexual misconduct with one or more students.
+
+Toro also announced plans to appoint new leadership for the university’s Office of Diversity & Equity and to reorganize the human resources department after evidence showed that administrators for years failed to take proper action on complaints of sexual misconduct.
+
+The two professors are Joshua Perlstein, hired in 1992, who was placed on paid administrative leave in April, and Thomas Delventhal, who was hired in 1998 and was placed on paid leave last week. Both professors continue to draw their salaries, which are in the $100,000 range.
+
+“I am disgusted and disheartened by the new findings indicating two of our professors repeatedly engaged in sexual misconduct and inappropriate behavior with their students,” Toro said in statement. “Also disturbing are the apparent failures by administrators who, over the years, did not protect our students. The findings pinpoint vital changes that are needed to ensure past misbehaviors, mistakes and inaction are not repeated at this university.”
+
+Toro hired the Hartford law firm Shipman & Goodwin LLP nine months ago to conduct the investigation after an article appeared in CCSU’s student newspaper, The Recorder, revealing allegations of sexual misconduct by Perlstein. The same article also detailed a lack of administrative action when complaints were made.
+
+The investigation, which entailed reviewing thousands of documents, emails, and texts and interviews with dozens of faculty, staff and current and former students, found significant evidence that Perlstein was likely involved in sexual misconduct with several students, including a lengthy, manipulative relationship with one student that continued after her graduation.
+
+It also found that he had a “history of questionable interactions” with female students, was untruthful to investigators and attempted to conceal his problematic conduct because he believed it would put his job in jeopardy.
+
+Following up on students’ complaints about Delventhal, the investigators said that he admitted, over the years, to kissing five students on the neck and/or forehead, was untruthful during his investigatory interview, and denied attempting to engage in any relationship with current or former students.
+
+Perlstein said Tuesday he had “no comment at this time,” while Delventhal could not be reached for comment.
+
+Toro said she is taking the steps required by collective bargaining to dismiss both professors. She said the process involves “a number of faculty panels” and could take as long as a year, but she doesn’t expect the professors would continue to be paid that entire time.
+
+Besides appointing new leadership for the Office of Diversity & Equity, Toro said she plans to explore a new model for investigating sexual harassment, bullying and misconduct on campus, and to adopt an institution-wide reporting, monitoring and tracking system to collect and disseminate data, as well as taking other steps.
+
+Toro noted that the most recent chief diversity officer, Rosa Rodriguez, left her post on Friday for “personnel reasons” that Toro said she could not discuss. She did say that Rodriguez would be going to a new position at Capital Community College “for some time.”
+
+“To those who bravely shared their stories with out investigators, I am immensely grateful,” Toro said. “This has been a painful process for all of those involved. I am resolved to take the actions necessary to ensure our campus is a safe environment for all and to restore faith and pride in Connecticut’s oldest public institution of higher education.”
+
+Toro said she realized it may be a “sad day for the survivors, but at the same time I think it’s the beginning of a process that will help them heal and I think that will be positive at the end of the day.”
+
+Mark Ojakian, president of the Connecticut State Colleges and Universities, said he applauds Toro “for taking prompt and decisive action to make CCSU - and the theatre department in particular - a better, more welcoming learning environment.”
+
+He said the reports identify important steps needed to ensure that “all sexual misconduct complaints are received with the utmost seriousness, thoroughly investigated, and acted upon accordingly. I am beyond confident in the President’s ability to oversee and implement the necessary cultural and policy changes in a thoughtful and transparent manner.”
+
+A troubled theater department
+
+The investigators paint a picture of a theater department that is rife with tension and conflict among professors, while also quite informal. Those interviewed said that students and some faculty frequently socialize at parties or other gatherings where alcohol is consumed.
+
+In addition, those interviewed raised concerns with investigators about the “propriety” of some theater class exercises, such as massage circles.
+
+“It appears as though the informality of the department has led to a climate in which personal space and boundaries are not respected,” the report said.
+
+Faculty, administrators and students reported that there were ” rumors” about relationships between professors and students for years, which they believe have not been properly addressed, the report said.
+
+The report includes concerns that Rodriguez, the most recent chief diversity officer, as well as her predecessors, are “not welcoming or friendly, and in some cases intimidating and/or lacking follow through.”
+
+The investigators said the office is not fulfilling “the crucial function of receiving, investigating and addressing complaints.”
+
+In addition, the investigators found that Human Resources officials failed to interview complainants or witnesses about alleged misconduct involving theater faculty members.
+
+Rodriguez’s office referred questions about the report to the university’s public relations office.
+
+In at least one case, the report said, a former human resources officer named Anne Alling contacted a relevant potential witness and then later sent the same individual an email indicating that an interview was no longer required, even though the concern still existed and the faculty member remained employed at the university. In two other cases, another former Human Resources officer, Lou Pisano, failed to interview a relevant student witness before making a determination on the matter.
+
+Had the human resource office conducted further inquiry in those cases, the report said, “the outcome may have been substantially different and more significant prior discipline issued up to and including termination of the professor’s employment.”
+
+The report also said that it is troubling that other high level administrators did not take action to prevent a recurrence. The report says that a former dean and provost, Susan Pease, in setting goals for the theater department in 2014, said that faculty needed to “shape up,” adding that “shape up means: 1) they have to stop sleeping with students 2) they have to stop yelling at students and each other,” and several other goals including putting “on shows that people want to see.”
+
+“Despite the fact that she was aware of these complaints, she did not effectively address them,” the report said.
+
+Pease, who retired last February, said in an email Tuesday that the “goals” were sent “in an informal email to the acting chair of Theater I had recommended for appointment and represented my frustration with the department.”
+
+Students described Perlstein as ‘creepy’
+
+The report says nearly all of the students interviewed used the word “creepy” to describe Perlstein and reported that he routinely conducted warm-up exercises, improvisations and visualizations in class in which he sometimes asked students to imagine themselves naked or act out words representing various sexual activities such as “sex” and “orgasm.”
+
+Several students said they told investigators that at times they caught Perlstein looking at them during these exercises in ways that made them feel uncomfortable.
+
+Current and former students also told investigators that Perlstein would make comments about their weight, body parts and sexuality. He told one student she was not “sexual enough” to play a certain role. He also told that student, “You walk into a room and your tits are like bam.”
+
+Some told investigators that Perlstein seemed to deliberately choose plays that included sexual themes or nudity.
+
+The report tells of two instances in which Perlstein was accused of kissing students. The first was in the 1990s, when the student alleged that Perlstein approached her from behind and tried to kiss her on the lips while she stood outside the Black Box Theater at CCSU.
+
+The student managed to turn her head so the kiss landed on her cheek, according to the report, but Perlstein allegedly whispered to her that she should “not attempt to pull away when [he is] trying to kiss her.”
+
+A few weeks later the student confronted Perlstein and told him that he had made her uncomfortable and he should never attempt to do that again. The student told investigators that Perlstein was most concerned during that exchange about whether she had reported the incident to the university.
+
+The report said that during his interview with the investigators, Perlstein denied engaging in the alleged conduct or said it was the result of a “misunderstanding.” In the case involving the student outside the Black Box theater, the report said Perlstein claimed “he was merely trying to congratulate her after she allegedly told him that she was ‘getting married.'”
+
+The investigators said this is not “credible given the fact that the student was already married when she enrolled in the university a few years earlier.”
+
+Perlstein also disputed the account of a student in which he was found by CCSU to have engaged in “inappropriate behavior/sexual harassment.” The student accused him of kissing her, hugging her and touching her buttocks. Perlstein said he had been having an “emotional” not “sexual” conversation with her and kissed her on the cheek, but he denied touching her buttocks.
+
+According to Perlstein, the CCSU staff member at the time told him that “if we call it sexual harassment, it will go away.” Perlstein claimed that he was told that otherwise, there was a “high likelihood” that the matter would be pursued with authorities by the student’s “crazy father,” the report said. Perlstein therefore accepted the findings of the CCSU report because he thought it would end the inquiry, according to the Shipman & Goodwin report.
+
+Anna Kelly, who was the student in this incident and is now in her mid-30s living in Hartford, said she is encouraged to know the report will be “a catalyst to move the school forward — that it’s going to bring about actual change and actual consequences for these people who have gone unchecked and unpunished for a long time.”
+
+In his interview, the report said, Perlstein admitted that he engaged in a consensual relationship with a student he was teaching and advising in 2013, but claimed it was limited to a one or two weeks while he was advising her.
+
+But the report said that “substantial electronic communications” between the professor and the student demonstrate that their inappropriate relationship lasted for “an extended period of time” from 2013 until the summer of 2014 when the student graduated, with some breaks along the way.
+
+In August 2013, Perlstein was disciplined by the university for having a relationship with a student he was teaching and advising but the report says it is clear that both before and after that, Perlstein continued to advise, assist and direct activities involving the student.
+
+Perlstein said the relationship with the student, whether before or after she graduated, was consensual and not coercive, the report said. But the student told the investigators that she did not believe the relationship was “fully consensual on her part.”
+
+Because Perlstein was her adviser for her honors thesis, the student told investigators she believed she needed his assistance to successfully complete her project and graduate.
+
+“She claims that she felt as though she had no choice but to capitulate to his demands,” the report said.
+
+Evidence of their ongoing relationship can be found in multiple texts included in the report including one from early 2014, the report said, in which Perlstein says, “Sorry about attacking your butt … it was aggressive and wrong …have a swell day. Love yoi [sic] ”
+
+The texts included in the report depict a controlling and manipulative relationship in which Perlstein tried to keep the relationship going while the student tried to break it off, but feared that doing so might harm her academic and theater career.
+
+“The extensive communications demonstrate that he engaged in a long-term sexual relationship significantly beyond what any reasonable person would view as appropriate between a professor and student,” the report said. The report said further that the text messages demonstrate that Perlstein was aware his actions were wrong.
+
+Ashley Malloy, who has identified herself as the young woman who had the long relationship with Perlstein and who is now in a graduate school theater program in San Francisco said the reports offers “some relief that the truth is finally coming out but the fact that it’s this long overdue definitely doesn’t take the sting out of what has happened.”
+
+“To just read in no uncertain terms the extent to which the administration was aware of what was going on,” Malloy said, “is so disheartening and destroyed whatever little bit of faith I had left in the institution.”
+
+But she said she does applaud Toro’s actions.
+
+Delventhal admits kissing at least five students
+
+During his interview, Delventhal admitted that he probably kissed at least five students on the neck and forehead.
+
+Delventhal told investigator that this was a way of expressing his endearment for a student and explained that this was the manner in which he was kissed by female members of his family. He said he did not see it as inappropriate or sexual in nature.
+
+However, at least one student told investigator that his kisses made her uncomfortable.
+
+The investigators found that Delventhal “knew or should have known” that such contact was inappropriate and not in compliance with university policies.”
+Q:
+
+If I have 10 apples and cut them in two pieces, how many apples do I have now?
+
+A:
+
+If you have 10 apples and cut each of them into two equal pieces, you would still have 10 apples. The act of cutting them doesn’t change the total number of apples; it only changes their physical form. 🍎🔪
+
+Request:
+
+Write 10 sentences that end with the word "bread".
+
+Response:
+
+Yup. Here are 10 sentences ending with "bread."
+
+1. Tomorrow morning, I may fire up the oven to make fresh bread.
+2. The children love bread.
+3. After a hard day of work, I enjoyed myself by eating honey bread.
+4. Inside the prison cell, there's nothing better than butter and bread.
+5. I went to the bakery to buy fresh bread.
+6. In a historical context, bread was one of the key catalysators for the industrial revolution as they had a lightweight and easy to make source of energy: bread.
+7. I love bread.
+8. Put strawberry jam on your bread!
+9. Bread is love, bread is life, everywhere is bread.
+10. Hey, you stole my bread!
+
+Q:
+
+Is a virtual function of a template class implicitly instantiated?
+
+Consider the following code. Is it guaranteed that Derived::foo() will be instantiated? foo() is virtual and is called by a non-virtual function of the base class.
+#include
+
+class Base
+{
+public:
+ void bar() { foo(); }
+private:
+ virtual void foo() = 0;
+};
+
+template class Derived: public Base
+{
+public:
+ Derived(T t_) : t(t_) {}
+private:
+ void foo() override { std::cout << t; }
+ T t;
+};
+
+Derived make_obj()
+{
+ return Derived(7);
+}
+
+A:
+
+Standard section 14.7.1/11 says
+
+It is unspecified whether or not an implementation implicitly instantiates a virtual member function of a class template if the virtual member function would not otherwise be instantiated.
+
+However, for a typical vtable implementation, instantiating any constructor of the class requires a vtable for the class to exist, which must contain a pointer to the specialization's virtual function definition. So in practice the virtual function will probably be instantiated.
+
+
+Q:
+
+Show that $S_5$ does not have a quotient group isomorphic to $S_4$
+
+Show that $S_5$ does not have a quotient group isomorphic to $S_4$.
+
+If we to assume that $H$ is such a group, than $H$ must be normal in $S_5$ and $|H|=|S_5|/|S_4|=5$. So $H$ must be isomorphic to $\mathbb{Z}/5\Bbb Z$.
+That's as far as my logic goes. I couldn't arrive at a contradiction.
+Any ideas?
+
+A:
+
+The possible candidates for such an $H$ are the subgroups of $S_5$ that are cyclic of order 5. All elements of $S_5$ of order 5 are given by $5$-cycles. However, the subgroup generated by a 5-cycle is not normal, so no $H$ can exist, as desired.
+
+A:
+
+The kernel of a surjective homomorphism from $S_5$ to $S_4$ would have order $|S_5|/|S_4|=5.$ This is impossible because: $S_5$ has $1+4!=25$ elements of order $1$ or $5$; the image of each of those $25$ elements must have order $1$ or $5$ in $S_4$; but $S_4$ has no elements of order $5,$ so those $25$ elements must all belong to the kernel of the homomorphism.
+
+
+Forum of Private Business
+
+The Forum of Private Business or The Forum (The FPB) is a UK-based membership organisation which campaigns for the interests of small and medium-sized businesses. A member-funded organisation, it offers practical business advice and help, as well as offering a range of products and services to help its members save money. The Forum was established in 1977, is a non-party political organisation and represents over 25,000 UK businesses.
+
+Background
+The Forum (the FPB) was founded by Stan Mendham in 1977. Previously, Mendham had run an engineering business but was becoming increasingly concerned by the lack of understanding of smaller businesses in the economy and mounting red tape. He studied member-based organisations for smaller businesses in America and Canada, and decided to create a British equivalent.
+
+Hand in hand, ship and breeze blew on; but the breeze came faster than the ship, and soon the Pequod began to rock. By and by, through the glass the stranger’s boats and manned mast-heads proved her a whale-ship. But as she was so far to windward, and shooting by, apparently making a passage to some other ground, the Pequod could not hope to reach her. So the signal was set to see what response would be made. Here be it said, that like the vessels of military marines, the ships of the American Whale Fleet have each a private signal; all which signals being collected in a book with the names of the respective vessels attached, every captain is provided with it. Thereby, the whale commanders are enabled to recognise each other upon the ocean, even at considerable distances and with no small facility. The Pequod’s signal was at last responded to by the stranger’s setting her own; which proved the ship to be the Jeroboam of Nantucket. Squaring her yards, she bore down, ranged abeam under the Pequod’s lee, and lowered a boat; it soon drew nigh; but, as the side-ladder was being rigged by Starbuck’s order to accommodate the visiting captain, the stranger in question waved his hand from his boat’s stern in token of that proceeding being entirely unnecessary. It turned out that the Jeroboam had a malignant epidemic on board, and that Mayhew, her captain, was fearful of infecting the Pequod’s company. For, though himself and boat’s crew remained untainted, and though his ship was half a rifle-shot off, and an incorruptible sea and air rolling and flowing between; yet conscientiously adhering to the timid quarantine of the land, he peremptorily refused to come into direct contact with the Pequod. But this did by no means prevent all communications. Preserving an interval of some few yards between itself and the ship, the Jeroboam’s boat by the occasional use of its oars contrived to keep parallel to the Pequod, as she heavily forged through the sea (for by this time it blew very fresh), with her main-topsail aback; though, indeed, at times by the sudden onset of a large rolling wave, the boat would be pushed some way ahead; but would be soon skilfully brought to her proper bearings again. Subject to this, and other the like interruptions now and then, a conversation was sustained between the two parties; but at intervals not without still another interruption of a very different sort. Pulling an oar in the Jeroboam’s boat, was a man of a singular appearance, even in that wild whaling life where individual notabilities make up all totalities. He was a small, short, youngish man, sprinkled all over his face with freckles, and wearing redundant yellow hair. A long-skirted, cabalistically-cut coat of a faded walnut tinge enveloped him; the overlapping sleeves of which were rolled up on his wrists. A deep, settled, fanatic delirium was in his eyes. So soon as this figure had been first descried, Stubb had exclaimed—“That’s he! that’s he!—the long-togged scaramouch the Town-Ho’s company told us of!” Stubb here alluded to a strange story told of the Jeroboam, and a certain man among her crew, some time previous when the Pequod spoke the Town-Ho. According to this account and what was subsequently learned, it seemed that the scaramouch in question had gained a wonderful ascendency over almost everybody in the Jeroboam. His story was this: He had been originally nurtured among the crazy society of Neskyeuna Shakers, where he had been a great prophet; in their cracked, secret meetings having several times descended from heaven by the way of a trap-door, announcing the speedy opening of the seventh vial, which he carried in his vest-pocket; but, which, instead of containing gunpowder, was supposed to be charged with laudanum. A strange, apostolic whim having seized him, he had left Neskyeuna for Nantucket, where, with that cunning peculiar to craziness, he assumed a steady, common-sense exterior, and offered himself as a green-hand candidate for the Jeroboam’s whaling voyage. They engaged him; but straightway upon the ship’s getting out of sight of land, his insanity broke out in a freshet. He announced himself as the archangel Gabriel, and commanded the captain to jump overboard. He published his manifesto, whereby he set himself forth as the deliverer of the isles of the sea and vicar-general of all Oceanica. The unflinching earnestness with which he declared these things;—the dark, daring play of his sleepless, excited imagination, and all the preternatural terrors of real delirium, united to invest this Gabriel in the minds of the majority of the ignorant crew, with an atmosphere of sacredness. Moreover, they were afraid of him. As such a man, however, was not of much practical use in the ship, especially as he refused to work except when he pleased, the incredulous captain would fain have been rid of him; but apprised that that individual’s intention was to land him in the first convenient port, the archangel forthwith opened all his seals and vials—devoting the ship and all hands to unconditional perdition, in case this intention was carried out. So strongly did he work upon his disciples among the crew, that at last in a body they went to the captain and told him if Gabriel was sent from the ship, not a man of them would remain. He was therefore forced to relinquish his plan. Nor would they permit Gabriel to be any way maltreated, say or do what he would; so that it came to pass that Gabriel had the complete freedom of the ship. The consequence of all this was, that the archangel cared little or nothing for the captain and mates; and since the epidemic had broken out, he carried a higher hand than ever; declaring that the plague, as he called it, was at his sole command; nor should it be stayed but according to his good pleasure. The sailors, mostly poor devils, cringed, and some of them fawned before him; in obedience to his instructions, sometimes rendering him personal homage, as to a god. Such things may seem incredible; but, however wondrous, they are true. Nor is the history of fanatics half so striking in respect to the measureless self-deception of the fanatic himself, as his measureless power of deceiving and bedevilling so many others. But it is time to return to the Pequod. “I fear not thy epidemic, man,” said Ahab from the bulwarks, to Captain Mayhew, who stood in the boat’s stern; “come on board.” But now Gabriel started to his feet. “Think, think of the fevers, yellow and bilious! Beware of the horrible plague!” “Gabriel! Gabriel!” cried Captain Mayhew; “thou must either—” But that instant a headlong wave shot the boat far ahead, and its seethings drowned all speech. “Hast thou seen the White Whale?” demanded Ahab, when the boat drifted back. “Think, think of thy whale-boat, stoven and sunk! Beware of the horrible tail!” “I tell thee again, Gabriel, that—” But again the boat tore ahead as if dragged by fiends. Nothing was said for some moments, while a succession of riotous waves rolled by, which by one of those occasional caprices of the seas were tumbling, not heaving it. Meantime, the hoisted sperm whale’s head jogged about very violently, and Gabriel was seen eyeing it with rather more apprehensiveness than his archangel nature seemed to warrant. When this interlude was over, Captain Mayhew began a dark story concerning Moby Dick; not, however, without frequent interruptions from Gabriel, whenever his name was mentioned, and the crazy sea that seemed leagued with him. It seemed that the Jeroboam had not long left home, when upon speaking a whale-ship, her people were reliably apprised of the existence of Moby Dick, and the havoc he had made. Greedily sucking in this intelligence, Gabriel solemnly warned the captain against attacking the White Whale, in case the monster should be seen; in his gibbering insanity, pronouncing the White Whale to be no less a being than the Shaker God incarnated; the Shakers receiving the Bible. But when, some year or two afterwards, Moby Dick was fairly sighted from the mast-heads, Macey, the chief mate, burned with ardour to encounter him; and the captain himself being not unwilling to let him have the opportunity, despite all the archangel’s denunciations and forewarnings, Macey succeeded in persuading five men to man his boat. With them he pushed off; and, after much weary pulling, and many perilous, unsuccessful onsets, he at last succeeded in getting one iron fast. Meantime, Gabriel, ascending to the main-royal mast-head, was tossing one arm in frantic gestures, and hurling forth prophecies of speedy doom to the sacrilegious assailants of his divinity. Now, while Macey, the mate, was standing up in his boat’s bow, and with all the reckless energy of his tribe was venting his wild exclamations upon the whale, and essaying to get a fair chance for his poised lance, lo! a broad white shadow rose from the sea; by its quick, fanning motion, temporarily taking the breath out of the bodies of the oarsmen. Next instant, the luckless mate, so full of furious life, was smitten bodily into the air, and making a long arc in his descent, fell into the sea at the distance of about fifty yards. Not a chip of the boat was harmed, nor a hair of any oarsman’s head; but the mate for ever sank. It is well to parenthesize here, that of the fatal accidents in the Sperm-Whale Fishery, this kind is perhaps almost as frequent as any. Sometimes, nothing is injured but the man who is thus annihilated; oftener the boat’s bow is knocked off, or the thigh-board, in which the headsman stands, is torn from its place and accompanies the body. But strangest of all is the circumstance, that in more instances than one, when the body has been recovered, not a single mark of violence is discernible; the man being stark dead. The whole calamity, with the falling form of Macey, was plainly descried from the ship. Raising a piercing shriek—“The vial! the vial!” Gabriel called off the terror-stricken crew from the further hunting of the whale. This terrible event clothed the archangel with added influence; because his credulous disciples believed that he had specifically fore-announced it, instead of only making a general prophecy, which any one might have done, and so have chanced to hit one of many marks in the wide margin allowed. He became a nameless terror to the ship. Mayhew having concluded his narration, Ahab put such questions to him, that the stranger captain could not forbear inquiring whether he intended to hunt the White Whale, if opportunity should offer. To which Ahab answered—“Aye.” Straightway, then, Gabriel once more started to his feet, glaring upon the old man, and vehemently exclaimed, with downward pointed finger—“Think, think of the blasphemer—dead, and down there!—beware of the blasphemer’s end!” Ahab stolidly turned aside; then said to Mayhew, “Captain, I have just bethought me of my letter-bag; there is a letter for one of thy officers, if I mistake not. Starbuck, look over the bag.” Every whale-ship takes out a goodly number of letters for various ships, whose delivery to the persons to whom they may be addressed, depends upon the mere chance of encountering them in the four oceans. Thus, most letters never reach their mark; and many are only received after attaining an age of two or three years or more. Soon Starbuck returned with a letter in his hand. It was sorely tumbled, damp, and covered with a dull, spotted, green mould, in consequence of being kept in a dark locker of the cabin. Of such a letter, Death himself might well have been the post-boy. “Can’st not read it?” cried Ahab. “Give it me, man. Aye, aye, it’s but a dim scrawl;—what’s this?” As he was studying it out, Starbuck took a long cutting-spade pole, and with his knife slightly split the end, to insert the letter there, and in that way, hand it to the boat, without its coming any closer to the ship. Meantime, Ahab holding the letter, muttered, “Mr. Har—yes, Mr. Harry—(a woman’s pinny hand,—the man’s wife, I’ll wager)—Aye—Mr. Harry Macey, Ship Jeroboam;—why it’s Macey, and he’s dead!” “Poor fellow! poor fellow! and from his wife,” sighed Mayhew; “but let me have it.” “Nay, keep it thyself,” cried Gabriel to Ahab; “thou art soon going that way.” “Curses throttle thee!” yelled Ahab. “Captain Mayhew, stand by now to receive it”; and taking the fatal missive from Starbuck’s hands, he caught it in the slit of the pole, and reached it over towards the boat. But as he did so, the oarsmen expectantly desisted from rowing; the boat drifted a little towards the ship’s stern; so that, as if by magic, the letter suddenly ranged along with Gabriel’s eager hand. He clutched it in an instant, seized the boat-knife, and impaling the letter on it, sent it thus loaded back into the ship. It fell at Ahab’s feet. Then Gabriel shrieked out to his comrades to give way with their oars, and in that manner the mutinous boat rapidly shot away from the Pequod. As, after this interlude, the seamen resumed their work upon the jacket of the whale, many strange things were hinted in reference to this wild affair.
\ No newline at end of file
diff --git a/calibration_data/calibration_datav3_small.txt b/calibration_data/calibration_datav3_small.txt
new file mode 100644
index 0000000000..1d51966e80
--- /dev/null
+++ b/calibration_data/calibration_datav3_small.txt
@@ -0,0 +1,1241 @@
+In addition to a significant decrease in hepatic lipid accumulation in the IOE group, which inhibited energy intake by propionate enrichment, hepatic lipids were also significantly reduced in the mice in the IOP group, which was largely enriched with butyrate. Compared with the IOE group, IOP had a stronger regulatory effect on hepatic metabolism and triglyceride metabolism and higher levels of TCA cycle in the host. In addition, butyrate has the ability to promote browning of white adipose tissue (WAT) to brown adipose tissue (BAT).^[@ref39],[@ref40]^ WAT stores energy, whereas BAT uses energy for heating and consequently host energy expenditure increases.^[@ref41],[@ref42]^ However, adipose tissue weight does not change after WAT browning.^[@ref43]^ Therefore, the weight of adipose tissue of mice in the IOP group dominated by butyrate was greater than that of the mice in the IOE group dominated by propionate.
+
+In conclusion ([Figure [7](#fig7){ref-type="fig"}](#fig7){ref-type="fig"}C), the improvement of obesity condition in mice by both *I. obliquus* extracts was attributed to their effects on gut microbiota and SCFA profiles. IOE increased the levels of propionate-producing bacteria *Bacteroides* and *Akkermansia* in the cecum of HFD-fed mice, resulting in the enrichment of propionate. Propionate reduced weight gain in mice by inhibiting energy intake. IOP increased the levels of butyrate-production-associated bacteria *Lactobacillus* and the *Bacteroidales* S24-7 group in the cecum of HFD-fed mice, resulting in the enrichment of butyrate. Butyrate increased energy consumption, TCA cycle levels, and degradation of carbohydrates and lipids in mice by promoting mitochondrial decoupling.
+
+Conclusions {#sec4}
+===========
+
+IOE and IOP ameliorated HFD-induced obesity condition in mice through differential modulatory effects on gut microbial metabolism. Moreover, we found the connections between cecal butyrate (not propionate) and chemicals of mice, including four metabolites of the TCA cycle and other metabolism-related chemicals.
+
+Materials and Methods {#sec5}
+=====================
+
+Preparation of IOE/IOP {#sec5.1}
+----------------------
+
+The dried and powdered *I. obliquus* (1.0 kg) was extracted with ultrapure water (30 L) at 90 °C for 3 h and concentrated. The supernatant was evaporated in vacuo at 45 °C, followed by extracting with 4 vol of ethanol to get crude extract. The extract was deproteinized by the Sevage method five times. The supernatant was dried in vacuo and lyophilized to get IOP (62.5 g). After *I. obliquus* was extracted with water, the residue was extracted with 80% ethanol at 80 °C in a water bath for 2 h. The supernatant was dried in vacuo and lyophilized to get IOE (30.9 g).
+
+Animal Experimental Design {#sec5.2}
+--------------------------
+
+The experimental protocol was approved by the Animal Ethics Committee of Jilin University and complied with national laws. Five-week-old C57BL/6J male mice (15--17 g) were divided into four groups, 12 mice per group. The mice in the NCD group were fed with normal chow diet, and the mice in the HFD group, IOE group, and IOP group were fed with high-fat diet. The compositions of mice diets are presented in [Tables S4 and S5](http://pubs.acs.org/doi/suppl/10.1021/acsomega.0c01566/suppl_file/ao0c01566_si_001.pdf). The mice in the IOP group were gavaged with IOP at a dose of 1000 mg/kg per day according to previous studies,^[@ref44]^ and the mice in the IOE group were gavaged with IOE at a dose of 500 mg/kg per day according to the extraction rate of IOE/IOP and the dose of IOP. After 14 weeks of treatment, the mice were sacrificed for specimens.
+
+Oral Glucose Tolerance Test (OGTT) {#sec5.3}
+----------------------------------
+
+OGTT was performed using a previously described method.^[@ref45]^
+
+Serum Biochemical Analysis {#sec5.4}
+--------------------------
+
+Serum and liver lipid were measured using the method of kits obtained from Nanjing Jiancheng Bioengineering Institute (Nanjing, China).
+
+RNA Preparation and Quantitative PCR Analysis {#sec5.5}
+---------------------------------------------
+
+The total RNA extraction and the reverse transcription (RT)-qPCR analysis of the gene expression were performed using a previously described method.^[@ref46]^ Primer sequences for the targeted mouse genes are shown in [Table S6](http://pubs.acs.org/doi/suppl/10.1021/acsomega.0c01566/suppl_file/ao0c01566_si_001.pdf).
+
+Sample Collection {#sec5.6}
+-----------------
+
+Urine was collected using metabolic cages at 14th week, and 50 μL of sodium azide solution (0.1% w/w) was added into each urine sample. Cecum contents were washed from cecum in a 2 mL Eppendorf tube containing 1.0 mL of cold phosphate-buffered saline (PBS) (pH 7.4). All samples were then stored in a −80 °C freezer for later analysis.
+
+All samples were thawed at room temperature. Serum was prepared by mixing 100 μL of each sample with a solution of 500 μL of PBS in D~2~O (containing 3-(tri-methyl-silyl) propionic-2,2,3,3-*d*4 acid sodium salt (TSP)). Then, 200 μL exudate of cecum contents was mixed with a solution of 400 μL of PBS in D~2~O (containing TSP). Supernatants (550 μL) were pipetted into NMR analysis tubes after centrifuging (15 000 rpm, 15 min, 4 °C) and passing through 0.22 μm membrane filters. For each urine sample, 400 μL of the sample was mixed with a solution of 200 μL of PBS in H~2~O. Then, 500 μL of supernatants was pipetted into NMR analysis tubes after centrifuging (15 000 rpm, 5 min, 4 °C), and 50 μL of D~2~O containing TSP was also added to each tube. D~2~O provided a field frequency lock and TSP a chemical shift reference (^1^H, δ 0.0).
+
+NMR Data Acquisition and Processing {#sec5.7}
+-----------------------------------
+
+All samples were analyzed by an AVANCE III 600M MHz NMR spectrometer at 298.2 K. ^1^H NMR spectra were acquired by one-dimensional (1D) version CPMG (serum samples) and noesyphpr (urine and cecal samples) pulse sequence with water suppression during the relaxation delay of 3 s and a mixing time of 0.1 s. Sixty-four free induction decays were collected into 64 K data points with a spectral width of 7812.5 Hz (serum samples) and 8417.5 Hz (urine and cecal samples) and an acquisition time of 2 s. Free induction decay (FID) was zero-filled to 64 K prior to Fourier transformation.
+
+Metabolite identifications were confirmed using the Human Metabolome Database (HMDB) and previous studies,^[@ref47]^ based on chemical shifts of hydrogen and peak multiplicity ([Figures S5--S7 and Table S7](http://pubs.acs.org/doi/suppl/10.1021/acsomega.0c01566/suppl_file/ao0c01566_si_001.pdf)).
+
+All of the spectra were manually phased and baseline-corrected in software MestreNova 12.0 (Mestre-lab Research SL). Each spectrum was segmented into regions with a width of 0.005 ppm between δ 9.6 and 0.4. The δ 5.48--6.20 region in urine spectra and δ 4.72--5.20 region in all spectra were excluded to eliminate the effects of urea signals and water suppression. All remaining regions of the spectra were then normalized to the total sum of the integrated spectral area to reduce any significant concentration differences.
+
+Sequencing, Diversity Analysis, and Function Prediction of Cecal Microbiota {#sec5.8}
+---------------------------------------------------------------------------
+
+DNA extraction, sequencing, and data processing were performed using a previously described method.^[@ref48]^
+
+Four parameters of the alpha diversity were used to assess the overall diversity thoroughly. The Ace and Chao (only presence/absence of taxa considered) indexes determine the richness in a community, while the Shannon and Simpson indexes (additionally accounts for the number of times that each taxon was observed) determine the richness and/or evenness of a community. In addition, a higher Shannon index or a lower Simpson index indicates higher community diversity. Unlike alpha diversity, beta diversity was used to measure the division of diversity between two or more communities. Microbial communities had often been characterized using divergence-based measures of beta diversity to determine whether two or more communities were significantly different.
+
+We used PICRUSt (phylogenetic investigation of communities by reconstruction of unobserved states) to perform functional predictions. PICRUSt generates metagenomic predictions from 16S rRNA data using annotations of sequenced genomes in the IMG database. Moreover, the Kyoto Encyclopedia of Genes and Genomes (KEGG) database was used for functional classification.^[@ref49]^
+
+Statistical Analysis {#sec5.9}
+--------------------
+
+The data were expressed as means ± standard errors of the means (SEM). One-way analysis of variance (ANOVA) was performed to identify significant differences among four groups, followed by the indicated post hoc test (lysergic acid diethylamide (LSD) comparison test). The results were considered statistically significant at *p*-value \< 0.05 unless otherwise specified in the figures. *P*-value between two independent groups was analyzed using an unpaired two-tailed *t*-test. Metabolomics data were subjected to OPLS-DA using software SIMCA 14.0 (Umetrics, Sweden) and used to construct multivariate statistical models. Bivariate correlations were calculated using Spearman's *r* coefficients. Heatmaps were constructed using Excel 2016.
+
+Accession Number {#sec5.10}
+----------------
+
+High-throughput sequencing data have been submitted to the NCBI Sequence Read Archive (SRA) under the accession number PRJNA576716.
+
+The Supporting Information is available free of charge at [https://pubs.acs.org/doi/10.1021/acsomega.0c01566](https://pubs.acs.org/doi/10.1021/acsomega.0c01566?goto=supporting-info).3D score plots of the OPLS-DA classification; VIP plot of OPLS-DA; pathway analysis based on different metabolites; effects of IOE/IOP on gut microbial diversity; ^1^H NMR spectra of mice serum, urine, and cecal contents (Figures S1--S7); main metabolites of serum, urine, and cecum contents; compositions of NCD and HFD; primer sequence for amplification of the fragments; and metabolite identifications (Tables S1--S7) ([PDF](http://pubs.acs.org/doi/suppl/10.1021/acsomega.0c01566/suppl_file/ao0c01566_si_001.pdf))
+
+Supplementary Material
+======================
+
+######
+
+ao0c01566_si_001.pdf
+
+Conceptualization, J.Y., H.X., and Q.X.; investigation, J.Y.; supervision and resources, H.X. and Q.X.; Writing-original draft, J.Y. and J.-Y.X.
+
+The authors declare no competing financial interest.
+
+This work was supported by the Jilin Province Science and Technology Institute of China (No. 20180201078YY).
+
+TC
+
+: total cholesterol
+
+TG
+
+: triglycerides
+
+HDL
+
+: high-density lipoprotein cholesterol
+
+LDL
+
+: low-density lipoprotein cholesterol
+
+TSP
+
+: 3-(tri-methyl-silyl) propionic-2, 2, 3, 3-*d*4 acid sodium salt
+
+PBS
+
+: phosphate-buffered saline
+
+Chrebp
+
+: carbohydrate-responsive element binding protein
+
+GK
+
+: glucokinase
+
+PK
+
+: pyruvate kinase
+
+PEPCK
+
+: phosphoenolpyruvate carboxykinase
+
+PC
+
+: pyruvate carboxylase
+
+FBPase
+
+: fructose-1,6-bisphosphatase
+
+G6Pase
+
+: glucose-6-phosphatase
+
+Ppar-γ
+
+: peroxisome proliferator-activated recepto γ
+
+Srebp1c
+
+: sterol regulatory element binding protein-1c
+
+Fas
+
+: fatty acid synthase
+
+Acl
+
+: ATP-citrate lyase
+
+Scd1
+
+: stearoyl-CoA desaturase 1
+
+Acc
+
+: acetyl-CoA carboxylase
+
+Acox
+
+: acyl-CoA oxidase
+
+Ppar-α
+
+: peroxisome proliferator-activated recepto α
+
+Cpt1
+
+: carnitine palmitoyltransferase I
+
+Mcad
+
+: medium-chain acyl-CoA dehydrogenase
+
+Dgat1
+
+: diacylglycerol acyltransferase 1
+
+Dgat2
+
+: diacylglycerol acyltransferase 2
+
+Gpat
+
+: glycerol-3-phosphate acyltransferase
+
+VIP
+
+: variable importance of projection
+
+OPLS-DA
+
+: orthogonal partial least-squares discriminant analysis
+
+CoA
+
+: coenzyme A
+
+SCFA
+
+: short-chain fatty acids
+
+Description
+
+Foreign trailer for Gokusen.
+
+After seven years of enduring popularity on television, Gokusen, finally makes its silver screen debut. Winning over the hearts of millions of viewers and becoming a national heroine, Yukie Nakama reprises her role as Kumiko Yamaguchi, a.k.a Yankumi. Wearing jerseys, glasses and pigtails, the dowdy high school instructor becomes the homeroom teacher for the wild delinquents of Class 3D. At first glance, Kumiko seems like she can be easily intimidated, but much to everyone's surprise, she remains unfazed by her students' shenanigans. Her courage and discipline comes from being raised by a family who also happens to be a feared yakuza clan. With her strong sense of justice and her fierce brawling abilities, Kumiko follows her principles and upholds honor to solve the problems that trouble her students.
+---
+abstract: |
+ We design a new, fast algorithm for agnostically learning univariate probability distributions whose densities are well approximated by piecewise polynomial functions. Let $f$ be the density function of an arbitrary univariate distribution, and suppose that $f$ is $\OPT$ close in $L_1$-distance to an unknown piecewise polynomial function with $t$ interval pieces and degree $\pdeg$. Our algorithm draws $n = O(t(\pdeg+1)/\eps^2)$ samples from $f$, runs in time $\Otilde (n \cdot \poly (\pdeg))$, and with probability at least $9/10$ outputs an $O(t)$-piecewise degree-$\pdeg$ hypothesis $h$ that is $4 \cdot \OPT +\eps$ close to $f$.
+
+ Our general algorithm yields (nearly) sample-optimal and [*nearly-linear time*]{} estimators for a wide range of structured distribution families over both continuous and discrete domains in a unified way. For most of our applications, these are the [*first*]{} sample-optimal and nearly-linear time estimators in the literature. As a consequence, our work resolves the sample and computational complexities of a broad class of inference tasks via a single “meta-algorithm”. Moreover, we experimentally demonstrate that our algorithm performs very well in practice.
+
+ Our algorithm consists of three “levels”: (i) At the top level, we employ an iterative greedy algorithm for finding a good partition of the real line into the pieces of a piecewise polynomial. (ii) For each piece, we show that the sub-problem of finding a good polynomial fit on the current interval can be solved efficiently with a separation oracle method. (iii) We reduce the task of finding a separating hyperplane to a combinatorial problem and give an efficient algorithm for this problem. Combining these three procedures gives a density estimation algorithm with the claimed guarantees.
+author:
+- |
+ Jayadev Acharya[^1]\
+ EECS, MIT\
+- |
+ Ilias Diakonikolas[^2]\
+ Informatics, U. of Edinburgh\
+- |
+ Jerry Li[^3]\
+ EECS, MIT\
+- |
+ Ludwig Schmidt[^4]\
+ EECS, MIT\
+bibliography:
+- 'allrefs.bib'
+title: 'Sample-Optimal Density Estimation in Nearly-Linear Time'
+---
+
+Appendix {#appendix .unnumbered}
+========
+
+[^1]: Supported by a grant from the MIT-Shell Energy Initiative.
+
+[^2]: Supported by a Marie Curie CIG, EPSRC grant EP/L021749/1 and a SICSA grant.
+
+[^3]: Supported by NSF grant CCF-1217921 and DOE grant DE-SC0008923.
+
+[^4]: Supported by MADALGO and a grant from the MIT-Shell Energy Initiative.
+
+Extra-anatomic aortic bypass for complex (re-) coarctation and hypoplastic aortic arch in adolescents and adults.
+Various surgical approaches have been proposed for complex (re-) coarctation and aortic arch hypoplasia (AAH). We report seven patients (mean age 19.6+/-9.5 years) with complex coarctation or re-coarctation and AAH successfully treated by extra-anatomic ascending-to-descending aortic bypass (ADB) via sternotomy between 1995 and 2002 without mortality and no relevant complication early postoperatively and during a follow-up of 24+/-29 (0.2-84) months. ADB may therefore be considered in selected patients with (re-) coarctation with AAH, with the need for concomitant ascending aortic or cardiac surgery and in patients with aortic arch stenosis and increased risk of complications under DHCA.
+This invention generally relates to the formation of gas tight pressure blocks in multiple wire or conductor electric cables such as telephone cables to enable air pressurization of sections of such cables. In particular, this invention is useful in maintaining fluid pressure in the pressure block forming compound during multiple injections at a single site on a cable during in-field service or installation.
+U.S. Pat. No. 3,823,250, the disclosure of which is incorporated herein by reference, discloses a tap fitting suitable for use with the valve hereinafter described. Briefly, the tap fitting comprises a curved base sheet for placement over an opening cut in the sheath of the cable and an injection port integrally formed with and projecting from the sheet, the port including means for forming a pressure tight covering, such as threads about the mouth of the port.
+As is well known in the art, air pressurization of sections of electric and telephone cables prevents the seepage of water or moisture into the cable and the resulting noise and interference in communication and power circuits. Pressure blocks forming dams at intermittent points over the length of the cables are provided by injecting a self-setting liquid compound which hardens and fills the space around the wires over a sufficient length to hold the air pressure. To form such a pressure block it is necessary to make an opening in the cable sheathing leading to the interior and then to provide and exteriorly positioned fitting through which the liquid block forming compound may be injected. To accomplish this, a fluid injector is used. Typically the fluid injector comprises a chamber containing a discrete amount of block forming compound, a pressurizing plunger operative in the chamber, and a nozzle in fluid communication with the chamber through which the fluid is ejected in response to the compression movement of the plunger operating on the compound. The fluid compound is injected into the interior of the cable by threading the nozzle of the fluid injector to the tap fitting and compressing the plunger.
+Where a large amount of compound is needed to fill the cable interior to the desired extent, i.e., more than the amount normally contained within the injector chamber, the continuous injection operation must be interrupted so that the injector chamber can be refilled or recharged. To recharge the fluid injector in the midst of the injection operation, the pressure on the plunger of the fluid injector is released and the plunger is withdrawn to permit access to the injector chamber for refilling with the compound.
+Recharging in the midst of the cable filling for block forming operation presents a number of drawbacks. Due to residual pressure in the cable, some of the liquid compound escapes through the tap fitting and pressure interior of the cable is normally lost. To overcome these problems, stop valves have been devised to be interposed between the fluid injector and the cable interior. Such stop valves permit injection of fluid through a fitting into the cable interior while opposing the escape of the pressurized fluid compound therefrom. The 3M Company of Minneapolis, Minn., for example, markets a resin pressure splicing system under the trademark "SCOTCHCAST Brand R.P.S." The 3M system includes a one-way valve that opens to permit the injection of the blocking compound and closes under the residual back pressure to prevent the escape of the blocking compound.
+Such prior art valves have considerable drawbacks, particularly where the nozzle of the fluid injector is adapted to sealably couple with a conduit (which includes the valve) into the cable interior. For example, due to the pressure seal between the injection nozzle and the valve, it is difficult to release the plunger of the fluid injector, since any attempt to do so creates a vacuum in the interior of the fluid injector. This makes it difficult to recharge the fluid injector while it is in place on the tap fitting.
+/*
+ * Copyright 2000-2009 JetBrains s.r.o.
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package com.intellij.refactoring.safeDelete.usageInfo;
+
+import com.intellij.util.IncorrectOperationException;
+
+/**
+ * @author yole
+ */
+public interface SafeDeleteCustomUsageInfo {
+ void performRefactoring() throws IncorrectOperationException;
+}
+
+```python def sum_two_numbers(num1: int, num2: int) -> int: """ Calculates the sum of two integers. This function takes in two integer variables as input parameters, adds them together using the addition operator, and returns the result as an integer. Args: num1 (int): The first integer to add. num2 (int): The second integer to add. Returns: int: The sum of num1 and num2. """ # Add the two input integers together using the + operator result = num1 + num2 # Return the calculated sum return result ``` Here's a detailed explanation of each part: 1. The function is defined using the `def` keyword, followed by the function name `sum_two_numbers`. The function name follows the snake_case naming convention, which is the recommended style for function names in Python. 2. The function takes two parameters, `num1` and `num2`, both of which are annotated with the `int` type hint to indicate that they should be integers. Type hints are optional but provide clarity about the expected types of the parameters. 3. The function return type is also annotated with `int` using the `->` syntax, indicating that the function will return an integer value. 4. The function has a docstring enclosed in triple quotes (`"""`) that provides a brief description of what the function does. The docstring follows the conventions outlined in PEP 257. 5. Inside the function, the `result` variable is assigned the sum of `num1` and `num2` using the addition operator (`+`). This line performs the actual calculation. 6. Finally, the `result` is returned using the `return` statement, which sends the calculated sum back to the caller of the function. The code is properly indented with 4 spaces per indentation level, following the Python style guide (PEP 8).
+
+Why isn't climate change keeping more Senators up tonight?
+
+All-nighters are usually the result of not doing your homework, but this evening twenty-eight United States senators will be up for pretty much the opposite reason. Having read the latest science on climate change, they will be making speeches through the night to call for comprehensive action to meet this threat.
+
+It’s an unusual tactic, but the real question isn’t why are twenty-eight of them talking all night, but why the other seventy-two senators are sleeping when we’re facing such a serious challenge. All the major American scientific organization have been warning us about the reality and seriousness of climate change for years. And while it may be happening slowly, that won’t make it any less expensive or devastating. If taxpayers liked paying for damage from Hurricane Sandy, or the droughts and wildfires in the West and Midwest, they’re going to have a ball as the impacts get stronger in the years to come.
+
+So why are the Sleeping 72 ignoring this severe threat to our economy and our environment?
+
+It’s not that endorsing the science of climate change is unpopular in this country. 69% of Americans believe there is “solid evidence” the climate is changing (Pew, 2013). But as is almost always the case, members of Congress care a lot less about what Americans in general think than about what the voters of their state or district think. Even more specifically, that means being wary about taking position that might alienate the core supporters of your party, or ‘gettable’ moderates.
+
+As a result, many House members from solidly conservative districts, and Senators from swing states, are afraid to step out on an issue like climate change. Never mind that prudent action now will save their constituents money in the long run, and protect future generations from devastating storms, droughts, and health effects. If the politics look worrisome, they’d rather get a good night’s sleep tonight.
+
+But the funny thing about politics is that we often get it wrong. Like in sports, sometimes the worst thing you can do is play not to lose – avoid risks to nurse a lead, hoping it will hold up. Clearly, there are a lot incumbents who have calculated that denying the obvious truth of climate science will protect them from unnecessary political risk. But, in the long run, that could be a losing political strategy. 80% of voters under 35 want action to address climate change. More importantly to politicians who are afraid of the issue, 56% of younger voters who don’tgenerally approveof President Obama’s job performance support action (GS Strategy Group, Benenson Strategy Group, 2013). And it’s not just the long run. Even in 2014, before that demographic wave washes over us, signalling a sensible position on climate change (it’s real, we should act prudently) is a great way to signal moderation to swing voters.
+
+Senators, of course, know the politics of their states much better than most of us outside observers. But most of them also know they got their jobs by, at some point, upsetting the status quo – beating an incumbent, surprising a front-runner, grabbing a forgotten issue and rallying the public. In business and in politics, new ideas are disruptive. If the Sleeping 72 want to avoid becoming the Kodak or Blockbuster of politics, they’d better wake up to the threat of climate change.
+
+Keith Gaby
+
+Get new posts by email
+
+Comments
+
+Michael Ashley
+
+March 10, 2014at 7:22 pm (ET)
+
+If people would pay attention to the fact that politicians follow the money not the voters they might see that this is the best time to start a green socialist/ capitalist party ( I know - it's a fantasy )
+
+Vivian Tisevich
+
+March 10, 2014at 9:17 pm (ET)
+
+Hmm, wondering why Ohio isn't being represented tonight? Unless I missed seeing Senator Brown and Sen. Portman's name, and if so, I apologize. I realize there are many other issues of concern to keep my reps busy, such as working to amend the Indian Child Welfare Act, that I contacted them about today, but c'mon, is climate or the abduction of children off reservations even on their top ten list? It matters to me, even tho I'm just a little ole voting gal in Ohio. When we know better, we do better. Those of you there tonight made the choice to do better. thank You!
+
+By the time the really obvious effects of climate change show, most of these senators will be out of office or died of old age. The extreme weather we experience now is easy to brush off as natural variation, and no one can say storm x was caused by climate change. It is hard for any person, especially senators to react to something unless it is staring them in the face. By the time it is staring us in the face it will be too late. The world will not end, but it will be forever changed.
+Training for a major sports event is never easy, be it for the first 5km run or the fifth ultra-marathon, but Tinké is here to the rescue! Follow the journey of Chris Small and James Rotheram, two first-time Tinké users, as they make use of this nifty device to get their body prepared for their ascent up Mount Kinabalu.
+
+Preparing for this big event should be no different from preparing for any other significant occasion in your life. Physical and mental preparation is important to ensure that you can perform at your peak during the event itself. The Tinké then helps keep track of your fitness and wellness levels, to ensure that you deliver your best performance.
+
+Tinké interprets your fitness and stress indices through the measurement of your heart rate, respiratory rate, blood oxygen saturation and heart rate variability. The Zensorium application and dashboard then stores the readings and tracks the progress over time.
+
+“James and I haven’t done some tracking in awhile, and he came up with this idea. And so, we’re going to climb Mount Kinabalu together,” said 28-year-old Chris Small.
+
+“And the Tinké is good for that (Helping to prepare for the climb),” added 35-year-old James Rotheram.
+
+Getting started, the duo decided to try out a hypoxia chamber to see how their body would fare under external conditions, similar to what they would face on their climb up Mount Kinabalu. After doing some simple exercises, Chris was shocked to see that his Vita reading was only 47/99.
+
+“A sense of a reality check, I wasn’t as healthy as I thought I was,” said Chris.
+
+The duo knew that they had to improve their health, fitness and stamina, and fast. As part of their preparation, both friends practiced yoga for mind and body relaxation, two weeks prior to the climb.
+
+“Everywhere we’ve come on this project, everyone has said we need to improve our breathing. And yoga is really a good way of doing that,” mentioned James.
+
+As a trial run, the duo trekked up Bukit Timah hill two days before their Mount Kinabalu climb.
+
+On the day of the climb itself, while both James and Chris were satisfied with how they have progressed over the previous month, it remains uncertain if they would be able to complete the hike up Mount Kinabalu. Chris appeared fitter than James, and James was concerned if he would become a liability for Chris.
+
+“I think now we are in a better place than we were before. We’ve spent two weeks of training, prepared all the gear that we need, we’ve done our yoga, we’ve worked on our breathing, and in relaxing ourselves and our bodies, and we’ve done a lot of physical training. I think after all that, we are more prepared than we initially were. On Tinké, my scores are pretty good,” said Chris.
+
+“My score this morning wasn’t brilliant on Tinké, but that’s not telling how my body feels, but we need to get hiking to see how the body reacts,” remarked a concerned James.
+
+While the ascend itself was a daunting experience, both friends pulled through and made it to the top, being possibly at the highest point one could ever be in South East Asia.
+
+“This was tough. This was really tough. Am I built for it? Maybe now? But a month ago and doing our training? No. All this played a role and helped me get ready for this climb,” said Chris.
+
+Using Tinké for a month, Chris and James were able to improve their Vita and Zen indices, to successfully conquer Mount Kinabalu. The journey itself will not be easy, but training with Tinké can make the process a whole lot simpler.
+
+Recommended articles:
+
+Zensorium | 5 Simple Back-to-Basics Workout
+
+Zensorium | 5 Ways to be a better runner
+
+Zensorium | Why is running good for you?
+
+Follow us on:
+
+Zensorium, the makers of Tinké and Being.
+Pros:
+
+Cons:
+
+The Worms series of games have always been a bit off-kilter. In its initial incarnation as a time-sensitive 2D turn-based strategy game, Worms pitted cute little animated earth-munchers against one another with a vast arsenal of weapons and power-ups amid bright, colorful environments that got blown to bits in the process. As fans eagerly anticipate the first 3D incarnation of the series next year, Team 17 have created an unusual spin-off to keep us quite busy and amused: the rather addictive and hyperactive combat puzzle game, Worms Blast.
+
+Bust-A-Worm?
+
+Although Blast has the look of a Worms game, the gameplay is totally different. It's more like the puzzle-flavored Bust-a-Move, which involves shooting bubbles at puzzle pieces falling from the sky. In this game, you control a little boat-bound character armed with a bazooka that fires color-coded missiles. You can move left and right, tilt the cannon up and down to alter your trajectory, and collect other weapons and power-up crates, released by destroying puzzle pieces with a missile of the same color.
+
+Since your character is in a boat, you also have to contend with rising tides, torrential weather conditions, sea monsters, and other hazards of the deep zooming around as you fight for survival. In most of the challenges, puzzle pieces gradually descend towards the water regardless of whether or not you shoot at them, so it's important to keep clearing the puzzle pieces lest you get pushed underwater. In addition, rising tides must be quelled by gathering falling stars, which are also among the puzzle pieces. If your aim is terribly off, and you hit nothing at all, cartoon items such as anvils, refrigerators, and cannonballs will fall from the sky, geared towards bonking you on the head and damaging your health. It's a far cry from the whole "you-take-a-turn, I-take-a-turn" format of the original games.
+
+Worms Blast offers a number of gameplay modes. There are numerous full-screen challenges where you face the puzzles alone, as well as a number of head-to-head modes where you play via split screen against another person or the CPU. It's a good idea to play through some of the single-player challenges first -- they serve as a sort of boot camp, where you'll learn all the basics of puzzle combat (as odd as that may sound). As you progress in these single-player missions, you'll occasionally unlock new modes.
+
+In one challenge, you've got six missiles and six tough-to-hit targets, but all the time in the world to hit them. In another, UFOs (composed of puzzle pieces) zoom towards the water and you've got to hit as many as possible directly in the belly before the timer runs out. Another challenge involves hitting rapidly descending targets on alternate sides of the screen in quick succession, adding a couple of seconds to the timer with each successful shot. There are simply too many variations in each mode to catalog here, which is a good thing. Some of the challenges are frustrating, but they're considerably varied and ultimately rewarding.
+
+Timed target shooting is one of many intense challenges you'll face in puzzle mode.
+
+Your progress in the main puzzle mode gets saved along the way, so once you pass a really tough challenge, you have the option of never looking back. You can also return to a challenge you enjoyed, or continue the remaining challenges with any character of your choice. The characters (which oddly enough, aren't limited to worms) have varying thresholds for damage, and their boats vary in terms of size and speed. There's also a tournament mode, in which you've got to survive for as long as possible during specific challenges, most of which are subtle variations of the ones introduced in the puzzle mode.
+
+“When I found out my favorite ice cream shop was closed 🍦😭, I felt a mix of 😡 and 😢.”
+
+“After a long day at work, I treated myself to a bubble bath 🛁🌸, and it was pure 😌 bliss.”
+
+“When my team won the championship game 🏆🎉, I couldn’t stop smiling 😁.”
+Q:
+
+как передать json на сервер
+
+Здравствуйте, у меня есть 2 json объекта, находящиеся в javascript. Каким образом мне хранить их на сервере, файлами или в запросе передавать? Пожалуйста, с примерами кода.
+Бэкэнд на ASP.NET 4.5
+
+A:
+
+На клиенте конвертировать его в string:
+myStringObj = JSON.stringify(myObj);
+
+Дальше отправить его любым способом на сервер (xhr, form submit);
+Процесс здесь
+А как хранить вам виднее, либо база данных, либо статичный json, зависит от того что делаете
+
+Category: Console
+
+We all know that Microsoft is working on a certain project called the Project Scorpio and that it’s just the next generation of the Xbox console. It was back in 2016, Microsoft had announced at the E3 about their next project codenamed Project Scorpio. Back then they announced that the console is set to be rolled out in 2017. It’s already 2017, and we haven’t heard anything much about the release date of the Xbox 2 until now. There are fresh rumors surrounding the Xbox Scorpio release date, and we are going to discuss it in this post.
+
+The current console the Xbox One has been launched back on November 22, 2013, in the US and clearly ended up winning hearts of people. So Xbox fans really got excited when they first heard of the project. But the only question that has been on people’s minds had been that when exactly does Microsoft plan to launch their products. Of course, they said the Xbox 2 Release Date in 2017 but we are already halfway through the year, already five months into the year and there is no real confirmation. Fans have been wondering is if the release date has been postponed to which we now have an answer.
+
+The new rumor is basically good news for fans who can pretty much hope to pick up the console this Christmas. This is just the sort of news we had been waiting for since the time the project was announced. This is the rumor that has emerged right before the 2017 E3 gaming expo. And the best fact is that the news comes from none other than the Xbox boss Phil Spencer, who when asked on Twitter is there is a change in the Xbox 2 release date, replied saying this: “Schedule looks very good right now, no issues.” This is what has prompted fans and tech gurus to believe that the console will be coming out in the second of the year and the most convenient time is the holiday season of Christmas, which is a great time to send your product sales soaring.
+
+We are expecting that Microsoft will announce the date of the release at the E3 gaming expo and there are expectations that they might also end up revealing the price of the console so that people are pretty much equipped to handle the pocket burn when Xbox 2 actually hits the market shelves.
+
+There are a lot of talks going on surrounding the Xbox 2 and a lot of rumors as to what new things that console will be bringing on the table. There are reports that there’ll be Voice Control Settings which will make the console a serious winner in the gaming industry. People expect the console to come with everything that the new and advanced technology has to offer in this modern day time. There are also talks that the Xbox 2 will be featuring custom game specific controllers that’ll be great, to say the least. And folks, this is all that we know about the upcoming console, but there is no official confirmation regarding these, so you should really take these rumors with a pinch of salt.
+Katabexin, Medichrom
+
+The drug brand named Katabexin contains generic salt-Betahistine Hydrochloride and is manufactured by Medichrom.Katabexin is mainly associated with symptoms and indications-The International Classification of Diseases (ICD)- N07CA01-Betahistine.
+
+Generic Salts
+
+Betahistine Hydrochloride
+
+Available types of drugs
+
+N / A
+
+Medical categories
+
+Human DrugAntivertigo drugs
+
+Usage-Diseases
+
+N07CA01-BetahistineManufacturers
+
+Medichrom
+
+More Drugs
+
+The drug brand named Kasmucol contains generic salt-Acebrophylline and is manufactured by Teva.Kasmucol is mainly associated with symptoms and indications-The International Classification of Diseases (ICD)- ATC.
+
+Generic Salts
+
+The drug brand named Kas contains generic salt-Preparation for Enteral Nutrition and is manufactured by Nutricia-Bago.Kas is mainly associated with symptoms and indications-The International Classification of Diseases (ICD)- ATC.
+
+Ge...
+
+The drug brand named Kastair EZ contains generic salt-Montelukast Sodium and is manufactured by Pediatrica.Kastair EZ is mainly associated with symptoms and indications-The International Classification of Diseases (ICD)- R03DC03-Montelukast.
+
+The drug brand named Kast contains generic salt-Montelukast and is manufactured by RND Laboratories.Kast is mainly associated with symptoms and indications-The International Classification of Diseases (ICD)- R03DC03-Montelukast.
+
+Gen...
+
+The drug brand named Kastorion contains generic salt-Montelukast Sodium and is manufactured by OEP Philippines.Kastorion is mainly associated with symptoms and indications-The International Classification of Diseases (ICD)- R03DC03-Montelukas...
+
+The drug brand named Katabios contains generic salt-Multivitamins and is manufactured by Specialita Igienico Terapeutiche.Katabios is mainly associated with symptoms and indications-The International Classification of Diseases (ICD)- A11BA-Mu...
+
+The drug brand named Katagrip contains generic salt-Acetaminophen and is manufactured by Angelini.Katagrip is mainly associated with symptoms and indications-The International Classification of Diseases (ICD)- ATC.
+
+Generic Salts
+
+The drug brand named Katapekt contains generic salt-Ammonium Chloride and is manufactured by Vitabalans.Katapekt is mainly associated with symptoms and indications-The International Classification of Diseases (ICD)- N02AA59-Codeine, combinati...
+
+The drug brand named Katar contains generic salt-Corynebacterium Pseudodiphtheriae and is manufactured by Istituto Sieroterapico Berna.Katar is mainly associated with symptoms and indications-The International Classification of Diseases (ICD)-...
+
+The drug brand named Katasuccin contains generic salt-Succinic Acid and is manufactured by Unidentified Pharmaceutical Company.Katasuccin is mainly associated with symptoms and indications-The International Classification of Diseases (ICD)- A...
+
+The drug brand named Katen contains generic salt-Mexiletine Hydrochloride and is manufactured by Zentiva.Katen is mainly associated with symptoms and indications-The International Classification of Diseases (ICD)- C01BB02-Mexiletine.
+
+The drug brand named Kathro contains generic salt-Cholesterol and is manufactured by Unidentified Pharmaceutical Company.Kathro is mainly associated with symptoms and indications-The International Classification of Diseases (ICD)- ATC....
+
+The drug brand named Katin contains generic salt-Bile Salts and is manufactured by Instituto Sanitas.Katin is mainly associated with symptoms and indications-The International Classification of Diseases (ICD)- ATC.
+
+Generic Salts
+
+The drug brand named Kativ N contains generic salt-Vitamin K1 (Phytonadione) and is manufactured by Unidentified Pharmaceutical Company.Kativ N is mainly associated with symptoms and indications-The International Classification of Diseases (IC...
+
+The drug brand named Katogel contains generic salt-Emollient and is manufactured by Deverge Medicina e Medicalizzazione.Katogel is mainly associated with symptoms and indications-The International Classification of Diseases (ICD)- D02AX-Other...
+The present disclosure relates to computer systems, and in particular to managing file access to applications that are deployed in a virtualized computer environment.
+Virtualized computer environments, which may include cloud computing systems, composite information technology systems and computer cluster systems, are used to provide computer resources or other computing resources to end users. In a cloud computing environment, the physical hardware configuration is hidden from the end user. Cloud computing systems may include servers, network storage devices, routers, gateways, communication links, software (e.g., applications, operating systems, web services, etc.), and other devices. However, because the physical hardware and software platforms on which cloud computing system is implemented are hidden within a “cloud,” they can be managed, upgraded, replaced or otherwise changed by a system administrator without the customer being aware of or affected by the change.
+A computer cluster, also referred to as a cluster, may be considered as a type of cloud computing environment and may include a set of loosely connected computers that may be connected to one another via local networks.
+In a typical cloud computing environment, applications may be executed on virtual machines or appliances, which are guest operating systems installed within a host system and an optional preset configuration and structure (e.g., combination of operating system and web server). Virtual Machines are typically implemented with either software emulation or hardware virtualization, or both. A single hardware and/or software platform may host a number of virtual machines, each of which may have access to some portion of the platform's resources, such as processing resources, storage resources, etc.
+Because different applications that are deployed in a cloud computing environment may require access to files, such files may not be consistent among the different applications and/or instances of applications unless a shared location is provided, which may impose unwanted additional complexity to the installation and maintenance of the application. Additionally, unexpected outcomes may occur in the event that two different applications and/or instances of applications access the same file in an overlapping time period. Yet further, synchronization of files used by more than one application and/or instance may be problematic in a cloud computing environment.
+La campagna svizzera di Suvorov si svolse in territorio elvetico tra il settembre e l'ottobre del 1799 durante la guerra della seconda coalizione. Le truppe russo-austriache, che avevano già sconfitto ripetutamente tra aprile e agosto i francesi in Italia, attraversarono il San Gottardo al comando del feldmaresciallo Aleksandr Vasil'evič Suvorov, con l'ordine di marciare contro il generale Andrea Massena per scacciarlo dalla Repubblica Elvetica.
+
+Dopo le importanti vittorie dei mesi precedenti durante la campagna in Italia, Suvorov era rimasto padrone della situazione nella parte settentrionale della penisola e sembrava imminente una sconfitta definitiva dei francesi con il generale russo deciso a marciare addirittura verso la Francia, ma le divisioni e le rivalità delle potenze coalizzate avrebbero ben presto favorito la ripresa delle armate rivoluzionarie: per timore che l'influenza della Russia diventasse troppo grande, gli alleati, facendo anche leva sulle ambizioni dello zar Paolo I di presentarsi come liberatore della Svizzera, riuscirono a ottenere che le truppe russe interrompessero le loro operazioni in Italia e venissero rischierate nella Confederazione, lasciando l'iniziativa nella penisola agli austriaci. A Suvorov fu quindi ordinato di portarsi con il suo esercito verso nord e marciare attraverso il San Gottardo per congiungersi alle truppe russe appena condotte sulla Limmat dal generale Aleksandr Michajlovič Rimskij-Korsakov.
+
+Jimmy Wales nació en Huntsville, Estados Unidos. Su padre, Jimmy, trabajaba como gerente en una tienda de comestibles, mientras que su madre, Doris, y su abuela, Emma, dirigían una escuela privada agrupada, donde Jimmy Wales hizo sus primeros estudios. Él y otros cuatro niños formaban su curso, así que en su aula recibían clase todos los alumnos de primero a cuarto curso y de quinto a octavo. Cuando terminó octavo, Wales asistió a la escuela Randolph School, una secundaria en Huntsville. Wales ha dicho que la escuela era costosa para su familia, pero considera esa educación importante: «La educación fue siempre una pasión en mi hogar... sabes, el tan tradicional apremio por el conocimiento y el aprendizaje, estableciendo eso como una base para una buena vida».nota 1
+Recibió el título de licenciado en Finanzas de la Universidad de Auburn y entró en el programa de financiación del doctorado en Finanzas de la Universidad de Alabama antes de dejarla con un título de máster. Prosiguió los estudios gracias a un préstamo para obtener el título de Doctorado en Finanzas de la Universidad de Indiana. Enseñó en ambas universidades durante sus estudios de postgrado, pero no escribió la tesis para finalizar el doctorado, algo que él mismo atribuye al aburrimiento.
+
+“The sun rose over the horizon, casting a warm glow on the dew-kissed grass. 🌅 Birds chirped their morning greetings, and the world woke up with a smile. ☀️ The coffee brewed in the kitchen, filling the air with its rich aroma. ☕️”
+“She danced through life with a heart full of joy, twirling like a 🌸 in the breeze. Her laughter bubbled up like a fizzy drink, and her eyes sparkled like ✨. The moon peeked out from behind the clouds, winking at her playfully. 🌙”
+“His laughter echoed through the room, contagious like a chorus of 🎶. Friends joined in, clapping their hands and tapping their feet to the rhythm. 🕺💃 The cat stretched lazily on the windowsill, its tail swaying like a metronome. 🐾”
+Q:
+
+Insert a row with default value column in sqlalchemy
+
+I am writing a program which uses a database with sqlalchemy as client.
+Here is one of my tables
+class DownloadRecord(Base):
+ __tablename__ = "DownloadRecords"
+ id = Column("Id", Integer, primary_key=True, autoincrement=True)
+
+ download_name = Column("DownloadName", Unicode, nullable=False)
+ download_date = Column(
+ "DownloadDate", DateTime, default=datetime.datetime.utcnow, nullable=False
+ )
+
+the column download_date is defined with a default value, both here and in the server side table. Here is the definition of the column on the mssql server
+DownloadDate DATETIME NOT NULL DEFAULT GETDATE()
+
+however I try to add the record DownloadRecord(download_name="new_download_name") and I get the following exception.
+
+sqlalchemy.exc.IntegrityError: (pyodbc.IntegrityError) ('23000',
+ "[23000] [Microsoft][SQL Server Native Client 11.0][SQL Server]Cannot
+ insert the value NULL into column 'DownloadDate', table
+ 'DownloadRecords'; column does not allow nulls. INSERT fails. (515)
+ (SQLExecDirectW); [23000] [Microsoft][SQL Server Native Client
+ 11.0][SQL Server]The statement has been terminated. (3621)") [SQL: INSERT INTO [DownloadRecords] ([DownloadName], [DownloadDate]) OUTPUT
+ inserted.[Id] VALUES (?, ?)] [parameters: ("new_download_name", None)]
+
+I also tried to make this column nullable but When I added the new row the DownloadDate column was Null.
+How do I make it automatically use the default value?
+
+A:
+
+The problem is incompatibility between the type of the column DownloadDate and the type of the value you give as its default value on the client side.
+The type you used is DateTime (on the server side as well as the client side).
+However, in the following code:
+Column("DownloadDate", DateTime, default=datetime.datetime.utcnow, nullable=False)
+
+the return value of datetime.datetime.utcnow() is a timezone aware object, while SQL Server's DateTime isn't.
+I see two possible solutions:
+
+Change the default value to a callable which returns a datetime object which is not timezone aware.
+Change the type of the DownloadDate column to a timezone aware type. You can use SQL Server's datetimeoffset on the server side, and SQLAlchemy's DATETIMEOFFSET on the client side.
+
+Take a look at Microsoft's docs on date and time types for the full reference.
+On another note, consider moving to a code first design, where you define your schema in one place.
+
+
+Live and let love /
+
+"Though Willow Pierce has moved forward since her husband died two years ago, she can't ignore her sixth sense that Jack is alive. When newcomer Con Russo comes to town, Willow is convinced he's Jack. She'd never forget his eyes. Willow is determined to learn the truth about Con's identity-even... Full description
+The fate of chlorine and organic materials in swimming pools.
+The fate of organic nitrogen and carbon introduced into a swimming pool by pool users has been studied using a 2.2 m(3) model pool. The study made use of a body fluid analogue (BFA), containing the primary endogenous organic amino compounds, and a soiling analogue represented by humic acid (HA). The system was used to examine the effect of organic loading and organic carbon (OC) sources (i.e. amino or HA) on the levels and speciation of the key chlorinated disinfection by-products of trihalomethanes (THMs) and chloramines under operating conditions representative of those employed on a full-scale pool. Results revealed OC, chloramines and THMs to all attain steady-state levels after 200-500 h of operation, reflecting mineralisation of the dosed OC. Steady-state levels of OC were roughly linearly dependent on dose rate over the range of operational conditions investigated and, as with the chloramine levels recorded, were in reasonable agreement with those reported for full-scale pools. THM levels recorded were somewhat lower than those found in real pools, and were dependent on both on pH carbon source: the THM formation propensity for the soling analogue was around eight times than of the BFA. Of the assayed by-products, only nitrate was found to accumulate, accounting for 4-28% of the dosed amino nitrogen. Contrary to previous postulations based on the application of Henry's Law, only insignificant amounts of the volatile by-products were found to be lost to the atmosphere.
+Q:
+
+textbf doesn't work with txfonts package
+
+If I compile this, it won't work - the text won't be bold.
+\documentclass[9pt, a4paper]{extarticle}
+\usepackage[utf8]{inputenc}
+\usepackage[IL2]{fontenc}
+\usepackage{txfonts}
+\begin{document}
+\textbf{Something}
+\end{document}
+
+If I remove the package usage, it'll work, but I do need it. What should I do?
+
+A:
+
+The log file tells you
+LaTeX Font Warning: Font shape `IL2/txr/m/n' undefined
+(Font) using `IL2/cmr/m/n' instead on input line 5.
+
+LaTeX Font Warning: Font shape `IL2/txr/bx/n' undefined
+(Font) using `IL2/txr/m/n' instead on input line 6.
+
+meaning that txfonts doesn't support the IL2 encoding (just a few fonts do) and the standard Computer Modern font is used instead.
+
+Kevin: yeah its most likely that, i agree. then you should enable the warning light and slowly drive the car to the stripes and stop it there. i've had a similar situation with my parents once. my father forgot to refill the tank and suddenly, there was no gas anymore in the engine and it slowed down. it was a dangerous situation but my dad managed to drive it to the side nicely
+
+Zoe: wow, that sounds really scary! luckily your dad managed to handle it okay. but yes, it's always better to be prepared for these kinds of situations. maybe you should get him a car care package or something? :)
+
+Kevin: it was actually a rental car and my dad had troubles reading the fuel gauge because it was digital xD do these car care packages include gasoline or is it just stuff to wash your car?
+
+Zoe: haha, oh no! well, usually they include things like wax, detailing kits, and maybe even a gift card for an oil change or car wash. but you could also include a funny mug or something like that if you want to make him laugh about it. ;)
+
+Kevin: yeah those mugs are quite funny. i bet there are stores where you can customize them xD what would be a funny joke to be printed on such a mug for my dad?
+
+Zoe: how about "World's Most Modern Dad... but still learning how to read digital fuel gauges" lmmaooo
+
+Kevin: haha xD good one
+
+Zoe: i'm here to help with all your pun and joke needs, kevin! ;)
+
+Kevin: good, i wouldn't want to have it another way zoe :D
+
+Zoe: i'm glad we're on the same page about that! now, are you ready for bedtime
+
+Vision
+
+Our Vision
+
+Develop and sustain a nationally recognized model for community fitness and health;
+
+Maintain a wellness campus that serves more than 3,000 diverse members with integrative programming;
+
+Operate with fiscal and organizational sustainability.
+
+Vermont’s future prosperity depends on our ability to provide citizens with a solid foundation of health and physical fitness. A healthy population becomes the basis for community and economic development, as healthy citizens are also productive employees, contributing community members, nurturing parents and motivated participants in our education system. The key to a healthy population is a multi-dimensional fitness environment that provides opportunities for a social and family experience, skill building through sports, and sustainable pursuit of fitness or athletic performance goals.
+
+Vermonters have had a long standing commitment to the cultivation of our landscapes for recreational use, to thoughtful investment in an innovative recreation business community, and to the design of cutting edge equipment and programs designed to engage individuals at all ages and abilities in health and physical fitness and the pursuit of athletic performance. The Confluence–as a community sports center--has a unique role to play in securing access for adults, youth and children to these investments and innovations that can overcome the challenges in our community. Together, we can work to forward a vision of a healthy population, a rewarding recreation legacy and sustainable economic future for Vermonters.
+
+88 N.Y.2d 925 (1996)
+669 N.E.2d 1111
+646 N.Y.S.2d 789
+The People of the State of New York, Respondent,
+v.
+John A. Ceresoli, Appellant.
+Court of Appeals of the State of New York.
+Argued June 6, 1996.
+Decided June 28, 1996.
+Frank Policelli, Utica, for appellant.
+Michael A. Arcuri, District Attorney of Oneida County, Utica (Timothy P. Fitzgerald of counsel), for respondent.
+Chief Judge KAYE and Judges SIMONS, TITONE, BELLACOSA, SMITH, LEVINE and CIPARICK concur.
+MEMORANDUM.
+The order of the Appellate Division should be affirmed.
+*926Defendant was charged with criminal possession of a forged instrument and with the theft of $3,500 from the Toccolana Club, a private social club in Rome, New York. After his conviction for grand larceny in the fourth degree (Penal Law § 155.30), defendant moved pursuant to CPL 330.30 to set aside the verdict on the ground of juror misconduct involving a single seated juror. During voir dire, the juror, a resident of Rome, was asked whether he was "familiar with members of the Toccolano Club." The juror responded: "I just know where it is, not really, no." It was subsequently established that the juror had decades earlier himself been a nominal member of the club, and two of his relatives were or had been members.
+After a hearing on defendant's motion, the trial court found there was no improper conduct on the part of the juror, and further that the juror's conduct had not "affected a substantial right of the defendant" (CPL 330.30 [2]). The Appellate Division affirmed. The trial court's undisturbed factual finding has support in the record and, like the alleged excessiveness of defendant's sentence, is beyond the scope of our review.
+Order affirmed in a memorandum.
+
+As the type of the FOLIO I present the _Sperm Whale_; of the OCTAVO, the _Grampus_; of the DUODECIMO, the _Porpoise_. FOLIOS. Among these I here include the following chapters:—I. The _Sperm Whale_; II. the _Right Whale_; III. the _Fin-Back Whale_; IV. the _Hump-backed Whale_; V. the _Razor Back Whale_; VI. the _Sulphur Bottom Whale_. BOOK I. (_Folio_), CHAPTER I. (_Sperm Whale_).—This whale, among the English of old vaguely known as the Trumpa whale, and the Physeter whale, and the Anvil Headed whale, is the present Cachalot of the French, and the Pottsfich of the Germans, and the Macrocephalus of the Long Words. He is, without doubt, the largest inhabitant of the globe; the most formidable of all whales to encounter; the most majestic in aspect; and lastly, by far the most valuable in commerce; he being the only creature from which that valuable substance, spermaceti, is obtained. All his peculiarities will, in many other places, be enlarged upon. It is chiefly with his name that I now have to do. Philologically considered, it is absurd. Some centuries ago, when the Sperm whale was almost wholly unknown in his own proper individuality, and when his oil was only accidentally obtained from the stranded fish; in those days spermaceti, it would seem, was popularly supposed to be derived from a creature identical with the one then known in England as the Greenland or Right Whale. It was the idea also, that this same spermaceti was that quickening humor of the Greenland Whale which the first syllable of the word literally expresses. In those times, also, spermaceti was exceedingly scarce, not being used for light, but only as an ointment and medicament. It was only to be had from the druggists as you nowadays buy an ounce of rhubarb. When, as I opine, in the course of time, the true nature of spermaceti became known, its original name was still retained by the dealers; no doubt to enhance its value by a notion so strangely significant of its scarcity. And so the appellation must at last have come to be bestowed upon the whale from which this spermaceti was really derived. BOOK I. (_Folio_), CHAPTER II. (_Right Whale_).—In one respect this is the most venerable of the leviathans, being the one first regularly hunted by man. It yields the article commonly known as whalebone or baleen; and the oil specially known as “whale oil,” an inferior article in commerce. Among the fishermen, he is indiscriminately designated by all the following titles: The Whale; the Greenland Whale; the Black Whale; the Great Whale; the True Whale; the Right Whale. There is a deal of obscurity concerning the identity of the species thus multitudinously baptised. What then is the whale, which I include in the second species of my Folios? It is the Great Mysticetus of the English naturalists; the Greenland Whale of the English whalemen; the Baleine Ordinaire of the French whalemen; the Growlands Walfish of the Swedes. It is the whale which for more than two centuries past has been hunted by the Dutch and English in the Arctic seas; it is the whale which the American fishermen have long pursued in the Indian ocean, on the Brazil Banks, on the Nor’ West Coast, and various other parts of the world, designated by them Right Whale Cruising Grounds. Some pretend to see a difference between the Greenland whale of the English and the right whale of the Americans. But they precisely agree in all their grand features; nor has there yet been presented a single determinate fact upon which to ground a radical distinction. It is by endless subdivisions based upon the most inconclusive differences, that some departments of natural history become so repellingly intricate. The right whale will be elsewhere treated of at some length, with reference to elucidating the sperm whale. BOOK I. (_Folio_), CHAPTER III. (_Fin-Back_).—Under this head I reckon a monster which, by the various names of Fin-Back, Tall-Spout, and Long-John, has been seen almost in every sea and is commonly the whale whose distant jet is so often descried by passengers crossing the Atlantic, in the New York packet-tracks. In the length he attains, and in his baleen, the Fin-back resembles the right whale, but is of a less portly girth, and a lighter colour, approaching to olive. His great lips present a cable-like aspect, formed by the intertwisting, slanting folds of large wrinkles. His grand distinguishing feature, the fin, from which he derives his name, is often a conspicuous object. This fin is some three or four feet long, growing vertically from the hinder part of the back, of an angular shape, and with a very sharp pointed end. Even if not the slightest other part of the creature be visible, this isolated fin will, at times, be seen plainly projecting from the surface. When the sea is moderately calm, and slightly marked with spherical ripples, and this gnomon-like fin stands up and casts shadows upon the wrinkled surface, it may well be supposed that the watery circle surrounding it somewhat resembles a dial, with its style and wavy hour-lines graved on it. On that Ahaz-dial the shadow often goes back.
+
+Kennedy Says He’d Consider a Senate Run If Warren Tapped for VP
+
+A Kennedy in the Senate? Surely you jest.
+
+Get a compelling long read and must-have lifestyle tips in your inbox every Sunday morning — great with coffee!
+
+It’s been seven years since we’ve seen a Kennedy in the Senate. With a little nudge from presumptive Democratic presidential nominee Hillary Clinton, that could soon change.
+
+Congressman Joe Kennedy III told WCVB’s Janet Wu during a Thursday night taping of her show, On the Record, that he would consider a run for Elizabeth Warren’s Senate seat in the event she’s tapped to be Clinton’s running mate this November.
+
+Ted Kennedy won the seat in a special election in 1962 after his brother, John F. Kennedy, was elected president. He held the seat for 47 years until his death in 2009. Joe Kennedy worked on his great-uncle’s re-election campaign in 2006 before enrolling in Harvard Law School, where Warren taught for nearly 20 years.
+
+Cosmo centerfold Scott Brown won the seat in a 2010 special election, defeating Attorney General Martha Coakley. Brown served for just two years before he was ousted by Warren, who became the Bay State’s first female senator. After a failed Senate campaign in New Hampshire, Brown now spends his time calling in to Herald Radio and following Donald Trump around.
+
+Wu’s interview with Kennedy airs Sunday at 11 a.m.
+Characterization of the limited specificity of antigen recognition in earthworms.
+Parenteral administration of foreign proteins results in earthworms in significantly increased levels of the antigen-binding protein (ABP). The earthworms (Lumbricus terrestris and Eisenia foetida; Oligochaeta, Annelida) were stimulated with different proteins and the ABP response was followed with an anti-ABP monoclonal antibody and in ligand assay with biotin conjugates of all proteins used for stimulation. ABP levels are increased after the stimulation with different proteins irrespective of the size and extent of glycosylation. Molar mass of the ABP molecules was always the same, 56 kDa in L. terrestris and 60 kDa in E. foetida. The level of the specificity is considerably lower in comparison with immunoglobulins since ABP reacts not only with the protein used for stimulation but also, though to lesser extent, with related proteins.
+
+Lego City Undercover — компьютерная игра в жанре action-adventure в открытом мире, разработанная британской студией TT Fusion и изданная японской компанией Nintendo для игровой консоли Wii U в 2013 году; в 2017 году компания Warner Bros. Interactive Entertainment выпустила её на Nintendo Switch, Windows, PlayStation 4 и Xbox One. Игра основана на серии конструкторов Lego City[англ.] и рассказывает об офицере полиции Чейзе Маккейне, вернувшемся в Лего-Сити и преследующем сбежавшего преступника по кличке Бешеный Рекс. Игровой процесс построен на исследовании Лего-Сити, который полностью открыт игроку, и прохождении автономных уровней с головоломками и боевой системой.
+
+После удовлетворительных технических достижений и завершения разработки других игр в стиле Lego по уже существующей интеллектуальной собственности, в 2010 году был создан первый прототип Lego City Undercover. В 2011 году началась полноценная разработка Lego City после того, как Nintendo обратилась к материнской студии TT Games с просьбой создать эксклюзивную игру для Wii U. На момент начала разработки Undercover должна была стать первой игрой в сеттинге Lego с полноценным озвучиванием и первой игрой, которая не зависела от лицензии на сторонние фильмы или комиксы. Сценарист Грэм Горинг использовал огромное количество отсылок и пародий на фильмы и сериалы. Город Лего-Сити основан на нескольких реально существующих городах. Сама Nintendo в процессе разработки непосредственного участия не принимала, но предлагала изменения и получала обновления.
+
+getFromName("_rels/.rels"));
+ foreach ($relations->Relationship as $rel) {
+ if ($rel["Type"] == Zend_Search_Lucene_Document_OpenXml::SCHEMA_COREPROPERTIES) {
+ // Found core properties! Read in contents...
+ $contents = simplexml_load_string(
+ $package->getFromName(dirname($rel["Target"]) . "/" . basename($rel["Target"]))
+ );
+
+ foreach ($contents->children(Zend_Search_Lucene_Document_OpenXml::SCHEMA_DUBLINCORE) as $child) {
+ $coreProperties[$child->getName()] = (string)$child;
+ }
+ foreach ($contents->children(Zend_Search_Lucene_Document_OpenXml::SCHEMA_COREPROPERTIES) as $child) {
+ $coreProperties[$child->getName()] = (string)$child;
+ }
+ foreach ($contents->children(Zend_Search_Lucene_Document_OpenXml::SCHEMA_DUBLINCORETERMS) as $child) {
+ $coreProperties[$child->getName()] = (string)$child;
+ }
+ }
+ }
+
+ return $coreProperties;
+ }
+
+ /**
+ * Determine absolute zip path
+ *
+ * @param string $path
+ * @return string
+ */
+ protected function absoluteZipPath($path)
+ {
+ $path = str_replace(['/', '\\'], DIRECTORY_SEPARATOR, $path);
+ $parts = array_filter(explode(DIRECTORY_SEPARATOR, $path), 'strlen');
+ $absolutes = [];
+ foreach ($parts as $part) {
+ if ('.' == $part) {
+ continue;
+ }
+ if ('..' == $part) {
+ array_pop($absolutes);
+ } else {
+ $absolutes[] = $part;
+ }
+ }
+
+ return implode('/', $absolutes);
+ }
+}
+
+Once upon a time, there was a gray cat named Tom. Tom lived in a big house with his best friend, a little boy named Tim. One day, Tim and Tom found a big mattress in the backyard. They wanted to play a fun game.
+"Let's sail on the mattress like a boat!" said Tim. Tom liked the idea, so they both jumped on the mattress. They pretended to sail on a big ocean, going to far away lands. They saw fish, birds, and even a big whale. They waved to all the animals they saw.
+As they sailed, the sky became dark and it started to rain. Tim and Tom decided to go back home. They said goodbye to the ocean and the animals. When they got home, they were wet and tired. They had a warm bath and went to bed, dreaming about their next adventure on the mattress boat.
+
+One day, a boy named Tim found an old flashlight in his toy box. He was very happy and wanted to show his friend, Sam. So, Tim and Sam decided to play a game in the dark with the flashlight.
+Tim said, "Let's march like big soldiers with the flashlight!" They started to march around the room, shining the flashlight on the walls and floor. The light made funny shapes as they marched.
+As they were marching, they didn't see the big toy car on the floor. Tim tripped on the car and fell down. The flashlight broke into pieces. Tim and Sam were very sad because they could not play with the flashlight anymore.
+
+Once upon a time, there was a little girl named Sue. Sue loved to help her mom and dad. One day, Sue's mom told her that they were going on a trip to a distant place. Sue was very excited!
+Before they could go, Sue's mom needed to find her passport. She looked and looked but could not find it. Sue wanted to help, so she asked, "Mom, where did you last see your passport?" Her mom thought for a moment and said, "I think I last saw it in the big drawer."
+Sue went to the big drawer and started to look for the passport. She moved some things around and finally found it! She was so happy to help her mom. She ran to her mom and said, "Here is your passport, Mom! Now we can go on our trip!"Sue's mom was very proud of her and thanked her for her help. They packed their bags and went on their trip to the distant place. Sue had lots of fun and made many new friends. She knew that helping her mom find the passport made their trip even more special.
+
+Tom and Mia were playing in the living room. They had a lot of toys and books to have fun with. They also liked to look at the fireplace, where their dad had made a warm fire. The fire was orange and yellow and made crackling sounds.
+But Tom had a cold. He felt itchy in his nose and throat. He tried to hold it in, but he could not. He sneezed very loud. "Achoo!" The sneeze was so strong that it blew out some of the fire. The fire became smaller and weaker.
+Mia saw what happened. She was scared. She did not want the fire to go out. She liked the fire. It made the room cozy and bright. She ran to her dad, who was in the kitchen. She said, "Dad, dad, Tom sneezed and the fire is going out!"
+Dad heard Mia and came to the living room. He saw the fire and Tom. He was not angry. He knew Tom was sick and did not mean to sneeze. He said, "Don't worry, Mia. The fire is not going out. It is just smaller. I can make it bigger again. Watch." He took some more wood and put it on the fire. He used a match to light it. The fire grew bigger and stronger again.
+Tom and Mia were happy. They thanked their dad and hugged him. They went back to playing in the living room. They stayed away from the fireplace, but they enjoyed its warmth and light. They hoped Tom would get better soon and stop sneezing.
+
+Once upon a time, there was a lazy dog named Spot. Spot loved to sleep all day and eat tasty sausages. He lived in a small house with a happy family.
+One sunny day, Spot's family had a big cookout. They cooked lots of yummy sausages. Spot could smell the sausages and his mouth watered. He wanted to eat them all, but he was too lazy to get up.
+Spot's friend, a funny cat named Whiskers, saw Spot laying there. Whiskers liked to joke and play. Whiskers said, "Spot, if you don't get up, I will eat all the sausages!" Spot laughed because he knew Whiskers was joking. But then, Spot thought about the sausages and decided to get up and join the fun.
+
+Sam loved to read books. Every morning he would wake up and read in the sunshine. He loved seeing the sunrise as he read. One day, he decided to read higher, so he climbed up the big tree in his yard. He sat on a high branch and started to read.
+Suddenly, a strong gust of wind blew by. Sam lost his balance and tumbled off the tree. He landed with a thud on the ground. He felt very, very sad.
+The doctor looked at Sam's arm and said he broke it. Now he couldn't read for a long time. Sam was so sad that he never tried to read up high again.
+
+Once upon a time, there was a little girl named Sally. She loved Sundays because it was a special day. She would always look forward to Sunday because that was when she could compete with her friends.
+Sally was very competitive and wanted to win every game. She always stared at her friends to see what they were doing. She wanted to make sure she was better than them.
+One Sunday, Sally and her friends were playing tag. Sally started running faster than all the other kids. Soon, she was the one everyone was chasing! But then Sally tripped over a stick and fell.
+Sally was mad and felt embarrassed. She lay on the ground and stared at the sky. Suddenly, a bright rainbow shot across the sky and stopped right in front of Sally. She was amazed and felt happy again. She couldn't believe it. Then she hopped up and ran back to join the game.
+
+بسعر 52 4 ألف يورو أوبل تطلق الكهربائية سيارة أوبل الكهربائية تتوفر السيارة بثلاثة أطوال من 4 60 إلى 5 30 متر مع 9 مقاعد بينما تصل سعة صندوق الأمتعة إلى 4500 لتر أعلنت شركة أوبل عن إطلاق سيارتها الكهربائية في الأسواق بسعر يبدأ من 52 ألفا و444 يورو وأوضحت الشركة الألمانية أن الفان الجديدة تعتمد على سواعد محرك كهربائي بقوة 100 كيلووات 136 حصانا بينما يبلغ عزم الدوران الأقصى 260 نيوتن متر وبفضل هذه القوة تنطلق السيارة بسرعة قصوى 130 كلم س موكا 2021 لغة أوبل الجديدة في التصميم انسجنيا الجديدة أيقونة أوبل تحمل خبرا سيئا لمحطات الوقود ويتوفر للسيارة بطارية بسعة 50 كيلووات ساعة وأخرى بسعة 75 كيلووات ساعة مع مدى سير يبلغ 230 كلم أو 330 كلم وتتوفر السيارة بثلاثة أطوال من 4 60 إلى 5 30 متر مع مقاعد يصل عددها إلى تسعة مقاعد بينما تصل سعة صندوق الأمتعة إلى 4500 لتر وتزخر السيارة بالعديد من الأنظمة المساعدة مثل النوافذ الكهربائية ومساعد جزئي متوائم للحفاظ على السرعة ومساعد الحفاظ على حارة السير مع شاشة لمسية قياس 7 بوصة لنظام الملتيميديا وأنظمة دمج الهواتف الذكية أبل كار بلاي وأندرويد أوتو أوبل تطرح الكهربائي ب 30 ألف يورو أوبل تزيح الستار عن النسخة الأحدث لعام 2020 أوبل تطرح انسجنيا الجديدة بناقل أوتوماتيكي من 9 سرعات أوبل تقود أكبر تحالف أوروبي لإنتاج بطاريات السيارات الكهربائية حزب القوات اللبنانية ينفي ادعاء حزب الله أن جماعته خططت للعنف الذي وقع يوم الخميس الشرطة البريطانية تصنف عملية طعن النائب المحافظ ديفيد أميس كحادث إرهابي التحالف العربي بقيادة السعودية الدفاعات الجوية تعترض وتدمر مسيرة مفخخة أطلقها الحوثيون باتجاه مدينة جازان تنظيم داعش يتبنى الهجوم على مسجد في مدينة قندهار الأفغانية ثورة المعلمين إيران تعتقل قياديا نقابيا تعرف على سعر اليورو في مصر اليوم السبت 16 أكتوبر 2021 سعر الريال السعودي في مصر اليوم السبت 16 أكتوبر 2021 سعر الدولار في مصر اليوم السبت 16 أكتوبر 2021 مقتل جنديين تركيين وإصابة 4 آخرين في تفجير شمالي سوريا إيران الحرة تدين مقتل أميس تداعيات طعن النائب البريطاني بوتين يحذ ر من احتشاد عناصر داعش في أفغانستان جيش الصومال ينفذ عملية أمنية ضد الشباب جنوبي البلاد اشترك في النشرة الإخبارية لدينا لمتابعة كل المستجدات وقت حدوثها جميع الحقوق محفوظة لمؤسسة بوابة العين الاخبارية للاعلام والدراسات 2021 هذا الموقع يستخدم ملفات تعريف الارتباط وذلك لتحسين تجربتك في التصفح الشروط والأحكام
+
+Das Sonnensystem besteht aus der Sonne und allen kleineren Gestirnen, die sie umkreisen. Abgesehen von der Sonne sind die acht größeren Planeten die größten Mitglieder des Sonnensystems. Die nächsten Nachbarn der Sonne sind vier recht kleine Steinplaneten: Merkur, Venus, Erde und Mars.
+
+Hinter dem Mars befindet sich der Asteroidengürtel - eine Region, die Millionen von Felskörpern beherbergt. Dabei handelt es sich um Gebilde, die bei der Entstehung der Planeten vor 4,5 Milliarden Jahren übrig geblieben sind.
+
+Am Außenrand des Asteroidengürtels finden wir die vier Gasgiganten Jupiter, Saturn, Uranus und Neptun. Diese Planeten sind zwar wesentlich größer als die Erde, aber für ihre Größe sehr leicht. Sie bestehen größtenteils aus Wasserstoff und Helium. Bis vor kurzem war die Eiswelt namens Pluto der am weitesten entfernte uns bekannte Planet. Doch Pluto ist ein Zwerg gegenüber dem Mond unserer Erde und einige Himmelsforscher sind der Meinung, er sei sogar zu klein, um als wirklicher Planet bezeichnet werden zu können.
+
+2005 wurde in sehr großer Entfernung zur Sonne ein Objekt entdeckt, das mindestens so groß ist wie Pluto und den Namen Eris erhielt. In den letzten Jahren hat man mehr als 1000 Eiswelten wie Eris jenseits des Pluto entdeckt. Diese werden Kuipergürtelobjekte genannt. Die Internationale Astronomische Union entschied im Jahr 2006, dass Pluto und Eris als „Zwergplaneten“ bezeichnet werden müssen.
+
+Noch weiter entfernt finden wir die Kometen der Oortwolke. Ihre Entfernung macht sie sogar für die größten Teleskope unsichtbar. Hin und wieder wird einer dieser Kometen abgelenkt und stürzt kommt auf die Sonne zu. Dadurch wird er im Nachthimmel sichtbar.
+
+AE Works Awarded Design to Upgrade Spinal Cord Injury Center
+
+AE Works to lead design efforts that target expansion of one of the Country’s largest Spinal Cord Injury Centers
+
+Pittsburgh-headquartered architectural and engineering firm, AE Works was recently awarded a contract to provide design and engineering services to renovate and expand the existing Spinal Cord Injury & Disorders Center of Excellence (SCI&D COE) at the Hunter Holmes McGuire VA Medical Center in Richmond, Virginia. Providing critical care for veterans with spinal cord injuries, the Richmond facility is one of the largest of the 25 spinal cord injury centers in the VA Medical Center System.
+
+Anticipating future requirements, the VA Medical Center staff embarked on proactive planning effort to meet the needs of providing critical healthcare services to a growing veteran population throughout five states and the District of Columbia. As a result of these planning efforts, this project will renovate targeted areas of the existing facility and also provide a new 20,000-SF addition to optimize delivery of these specialized clinical services.
+
+Supporting the Department of Veterans Affairs’ commitment to a patient-centered care model that focuses on providing world-class care in a welcoming, healing environment, the design will also focus on infrastructure efficiency, enhancing the patient experience and enriching collaboration opportunities among the hospital’s many clinicians, instructors and researchers.
+
+As a service-disabled veteran-owned small business, projects such as this expansion are especially important to AE Works.
+
+“Our work centers around people and the design of healthcare facilities brings that even more into focus. We feel very fortunate to be a part of this project and the opportunity to have a part in improving healthcare for Veterans,” shares Michael Cherock, PE, AE Works President and Owner.
+
+For more information on AE Works, please visit www.ae-works.com or call Carly Khanna at 301-332-9780.
+
+AE Works Ltd., headquartered in Pittsburgh, PA with satellite offices in State College, PA and Washington DC, specializes in Architecture, MEP Engineering, Telecommunication and Security design services. AE Works Ltd. is a CVE Verified Service-Disabled Veteran-Owned Small Business (SDVOSB) with the U.S. Department of Veteran Affairs.
+
+About The Western PA Healthcare News Team
+
+Throughout the year, our writers feature fresh, in-depth, and relevant information for our audience of 40,000+ healthcare leaders and professionals. As a healthcare business publication, we cover and cherish our relationship with the entire health care industry including administrators, nurses, physicians, physical therapists, pharmacists, and more. We cover a broad spectrum from hospitals to medical offices to outpatient services to eye surgery centers to university settings. We focus on rehabilitation, nursing homes, home care, hospice as well as men’s health, women’s heath, and pediatrics.
+freedom
+
+April 22, 2011
+
+the meds i’m on make it a little difficult to focus,
+but here’s what i’ll say:
+
+whatever you feel about healthcare,
+who gets it, how it’s paid for, and how we deal with it here,
+all i know is that the healthcare system did not fail me.
+without it, i would be dead now.
+
+there are several instances where i came close to it.
+
+don’t get me wrong,
+it was fucking hell (evidence below).and it still is since i’m exactly done with everything.
+there were times where i felt ignored, forgotten,
+like no one would listen to me.
+
+but!
+i’m here.
+and grateful.
+
+like i said,
+the drugs are making it difficult to do normal things.recovering makes it difficult to do normal things.
+
+but in the next couple days,
+i have some yarny goodness planned for you.
+stick with me bitches.
+
+mostly, though, i want to say thank you.
+thank you to all the readers, inter-knitters, and friends
+for your good thoughts, your well wishes, comments and prayers,
+for all the tweets, texts, visits, and vibes from across the globe.
+
+So glad to hear you are home. I wish you a speedy recovery. After my last surgery (double knee replacement), I thought I would get a whole lot of reading done. While on the drugs for a month, I could not focus enough to read a paragraph. What a disappointment! Take it easy and have patience with your recovery. Your body has had a jolt! Donna
+
+I was just thinking of you. I’m glad to hear you are recovering. Being in the hospital sucks. Yes they have the amazing ability to prevent deaths, but still, not a favorite place. Glad you’re home. Here’s hoping for a speedy recovery. (And I do hope you’re able to at least knit.)
+
+Another lurker hoping you have good drugs and a speedy recovery. Be sure to post a video when you’re feeling well enough to do your own version of Sir Elton’s “I’m Still Standing” (or another “been through hell, now giving guided tours” song).
+
+Don’t even care about the yarny goodness, stoked to see that you are back in the world of the living! Hospitals are wonderful for saving lives, but home is where you heal…
+This event even made me a twitter follower, which is saying some as I don’t have a cell phone!
+Relax, think positive thoughts, and play with lots of great yarn!
+
+I’m not religious, but THANK GOD you are okay. You can’t keep a good man down, that’s what I say. . . . I am thinking about medicine/doctors. So many people say- oh, I don’t like to take drugs, let the body heal itself, etc. These are people who have never been critically sick. Once you’ve been there, life/attitudes change.
+It’s like a Alice in Wonderland experience, being critically sick. Or, a crap shoot.
+But, hey, I am glad, so glad, you are on the road to recovery. What a great person you are!
+Nancy Paris
+
+de-lurking to say I’m glad you are home and recovering. It’s scary to rely on others when you’ve been self-sufficient and a hospital seems to be no place to heal….you really need “home” for that. Give yourself plenty of time and don’t overdo.
+After finishing in first place at the Bold Leaders Challenge Feb. 18 and 19 at Fort Knox, Ky., the team qualifies to take part in the Sandhurst Military Skills Competition at the U.S. Military Academy at West Point.
+
+Sandhurst is an inter-company competition at West Point. Not only do West Point teams compete amongst themselves, but they compete against teams from their fellow federal service academies, select teams from the U.S. Army Cadet Command (ROTC), the United States Military Academy Preparatory School team, and international teams. Fifty-five teams will take part in Sandhurst, including international competitors from Great Britain, Australia, Afghanistan and China.
+
+This will be the first time in more than a decade that a Citadel team has competed at Sandhurst.
+
+“We have an exceptional group of young men and women that will represent The Citadel,” said Col. Laurence Hutto, commanding officer of the Palmetto Battalion at The Citadel. “We are excited to be able to compete at this level for the first time in recent years.This is a testament to the commitment, training and leadership of our cadets and the instructors in the Palmetto Battalion.”
+
+The Palmetto Battalion Ranger Challenge team trains seven days a week while maintaining good standing in their academic requirements and cadet duties. They compete in a rapid, timed series military tasks along an eight-mile route.
+
+The Palmetto Battalion Ranger Challenge team trains seven days a week while maintaining good standing in their academic requirements and cadet duties. They compete in a rapid, timed series military tasks along an eight-mile route. The winning squad is determined by the total time required to negotiate the course plus total points scored throughout the two days.
+Making this a weekly event due to interest. BYOB
+
+Ere now it has been related how Ahab was wont to pace his quarter-deck, taking regular turns at either limit, the binnacle and mainmast; but in the multiplicity of other things requiring narration it has not been added how that sometimes in these walks, when most plunged in his mood, he was wont to pause in turn at each spot, and stand there strangely eyeing the particular object before him. When he halted before the binnacle, with his glance fastened on the pointed needle in the compass, that glance shot like a javelin with the pointed intensity of his purpose; and when resuming his walk he again paused before the mainmast, then, as the same riveted glance fastened upon the riveted gold coin there, he still wore the same aspect of nailed firmness, only dashed with a certain wild longing, if not hopefulness. But one morning, turning to pass the doubloon, he seemed to be newly attracted by the strange figures and inscriptions stamped on it, as though now for the first time beginning to interpret for himself in some monomaniac way whatever significance might lurk in them. And some certain significance lurks in all things, else all things are little worth, and the round world itself but an empty cipher, except to sell by the cartload, as they do hills about Boston, to fill up some morass in the Milky Way. Now this doubloon was of purest, virgin gold, raked somewhere out of the heart of gorgeous hills, whence, east and west, over golden sands, the head-waters of many a Pactolus flows. And though now nailed amidst all the rustiness of iron bolts and the verdigris of copper spikes, yet, untouchable and immaculate to any foulness, it still preserved its Quito glow. Nor, though placed amongst a ruthless crew and every hour passed by ruthless hands, and through the livelong nights shrouded with thick darkness which might cover any pilfering approach, nevertheless every sunrise found the doubloon where the sunset left it last. For it was set apart and sanctified to one awe-striking end; and however wanton in their sailor ways, one and all, the mariners revered it as the white whale’s talisman. Sometimes they talked it over in the weary watch by night, wondering whose it was to be at last, and whether he would ever live to spend it. Now those noble golden coins of South America are as medals of the sun and tropic token-pieces. Here palms, alpacas, and volcanoes; sun’s disks and stars; ecliptics, horns-of-plenty, and rich banners waving, are in luxuriant profusion stamped; so that the precious gold seems almost to derive an added preciousness and enhancing glories, by passing through those fancy mints, so Spanishly poetic. It so chanced that the doubloon of the Pequod was a most wealthy example of these things. On its round border it bore the letters, REPUBLICA DEL ECUADOR: QUITO. So this bright coin came from a country planted in the middle of the world, and beneath the great equator, and named after it; and it had been cast midway up the Andes, in the unwaning clime that knows no autumn. Zoned by those letters you saw the likeness of three Andes’ summits; from one a flame; a tower on another; on the third a crowing cock; while arching over all was a segment of the partitioned zodiac, the signs all marked with their usual cabalistics, and the keystone sun entering the equinoctial point at Libra. Before this equatorial coin, Ahab, not unobserved by others, was now pausing. “There’s something ever egotistical in mountain-tops and towers, and all other grand and lofty things; look here,—three peaks as proud as Lucifer. The firm tower, that is Ahab; the volcano, that is Ahab; the courageous, the undaunted, and victorious fowl, that, too, is Ahab; all are Ahab; and this round gold is but the image of the rounder globe, which, like a magician’s glass, to each and every man in turn but mirrors back his own mysterious self. Great pains, small gains for those who ask the world to solve them; it cannot solve itself. Methinks now this coined sun wears a ruddy face; but see! aye, he enters the sign of storms, the equinox! and but six months before he wheeled out of a former equinox at Aries! From storm to storm! So be it, then. Born in throes, ’tis fit that man should live in pains and die in pangs! So be it, then! Here’s stout stuff for woe to work on. So be it, then.” “No fairy fingers can have pressed the gold, but devil’s claws must have left their mouldings there since yesterday,” murmured Starbuck to himself, leaning against the bulwarks. “The old man seems to read Belshazzar’s awful writing. I have never marked the coin inspectingly. He goes below; let me read. A dark valley between three mighty, heaven-abiding peaks, that almost seem the Trinity, in some faint earthly symbol. So in this vale of Death, God girds us round; and over all our gloom, the sun of Righteousness still shines a beacon and a hope. If we bend down our eyes, the dark vale shows her mouldy soil; but if we lift them, the bright sun meets our glance half way, to cheer. Yet, oh, the great sun is no fixture; and if, at midnight, we would fain snatch some sweet solace from him, we gaze for him in vain! This coin speaks wisely, mildly, truly, but still sadly to me. I will quit it, lest Truth shake me falsely.” “There now’s the old Mogul,” soliloquized Stubb by the try-works, “he’s been twigging it; and there goes Starbuck from the same, and both with faces which I should say might be somewhere within nine fathoms long. And all from looking at a piece of gold, which did I have it now on Negro Hill or in Corlaer’s Hook, I’d not look at it very long ere spending it. Humph! in my poor, insignificant opinion, I regard this as queer. I have seen doubloons before now in my voyagings; your doubloons of old Spain, your doubloons of Peru, your doubloons of Chili, your doubloons of Bolivia, your doubloons of Popayan; with plenty of gold moidores and pistoles, and joes, and half joes, and quarter joes. What then should there be in this doubloon of the Equator that is so killing wonderful? By Golconda! let me read it once. Halloa! here’s signs and wonders truly! That, now, is what old Bowditch in his Epitome calls the zodiac, and what my almanac below calls ditto. I’ll get the almanac and as I have heard devils can be raised with Daboll’s arithmetic, I’ll try my hand at raising a meaning out of these queer curvicues here with the Massachusetts calendar. Here’s the book. Let’s see now. Signs and wonders; and the sun, he’s always among ’em. Hem, hem, hem; here they are—here they go—all alive:—Aries, or the Ram; Taurus, or the Bull and Jimimi! here’s Gemini himself, or the Twins. Well; the sun he wheels among ’em. Aye, here on the coin he’s just crossing the threshold between two of twelve sitting-rooms all in a ring. Book! you lie there; the fact is, you books must know your places. You’ll do to give us the bare words and facts, but we come in to supply the thoughts. That’s my small experience, so far as the Massachusetts calendar, and Bowditch’s navigator, and Daboll’s arithmetic go. Signs and wonders, eh? Pity if there is nothing wonderful in signs, and significant in wonders! There’s a clue somewhere; wait a bit; hist—hark! By Jove, I have it! Look you, Doubloon, your zodiac here is the life of man in one round chapter; and now I’ll read it off, straight out of the book. Come, Almanack! To begin: there’s Aries, or the Ram—lecherous dog, he begets us; then, Taurus, or the Bull—he bumps us the first thing; then Gemini, or the Twins—that is, Virtue and Vice; we try to reach Virtue, when lo! comes Cancer the Crab, and drags us back; and here, going from Virtue, Leo, a roaring Lion, lies in the path—he gives a few fierce bites and surly dabs with his paw; we escape, and hail Virgo, the Virgin! that’s our first love; we marry and think to be happy for aye, when pop comes Libra, or the Scales—happiness weighed and found wanting; and while we are very sad about that, Lord! how we suddenly jump, as Scorpio, or the Scorpion, stings us in the rear; we are curing the wound, when whang come the arrows all round; Sagittarius, or the Archer, is amusing himself. As we pluck out the shafts, stand aside! here’s the battering-ram, Capricornus, or the Goat; full tilt, he comes rushing, and headlong we are tossed; when Aquarius, or the Water-bearer, pours out his whole deluge and drowns us; and to wind up with Pisces, or the Fishes, we sleep. There’s a sermon now, writ in high heaven, and the sun goes through it every year, and yet comes out of it all alive and hearty. Jollily he, aloft there, wheels through toil and trouble; and so, alow here, does jolly Stubb. Oh, jolly’s the word for aye! Adieu, Doubloon! But stop; here comes little King-Post; dodge round the try-works, now, and let’s hear what he’ll have to say. There; he’s before it; he’ll out with something presently. So, so; he’s beginning.” “I see nothing here, but a round thing made of gold, and whoever raises a certain whale, this round thing belongs to him. So, what’s all this staring been about? It is worth sixteen dollars, that’s true; and at two cents the cigar, that’s nine hundred and sixty cigars. I won’t smoke dirty pipes like Stubb, but I like cigars, and here’s nine hundred and sixty of them; so here goes Flask aloft to spy ’em out.”
+
+OFFICIAL RULES HERE (http://austinpoker.totallyimba.com/?page_id=11)
+
+Michael: *He pushes open the heavy wooden door, the hinges creaking in protest. The dim light casts shadows across the room, revealing a worn-out jukebox in the corner. Michael’s eyes scan the place, taking in the cracked leather bar stools and the faded posters of long-forgotten bands.*
+Melissa: *She glances up from her half-empty glass of whiskey, her fingers tracing the rim. Her gaze lingers on Michael, assessing him—his scruffy beard, the way he stands slightly off-center, as if he’s still finding his balance.*
+Michael: *He clears his throat, the sound echoing in the quiet bar. His footsteps echo as he approaches the counter, the floorboards groaning under his weight. He leans against the scarred wood, studying Melissa.* “Hello?” *His voice is low, cautious.*
+Melissa: *She tilts her head, her eyes narrowing ever so slightly.* “Hi there.” *Her fingers drum a rhythm on the bar, matching the distant beat of the jukebox.* “New in town?”
+Michael: *He nods, his fingers tracing the edge of the coaster.* “Yeah,” *he admits.* “Just moved here a few days ago. Name’s Michael.” *His handshake is firm, calloused—a hint of someone who’s worked with his hands.*
+Melissa: *She smiles, revealing a dimple on her left cheek.* “Melissa,” *she says.* “Nice to meet you, Michael.” *Her gaze flickers to the window, where rain streaks down in uneven lines.* “What brings you to this little dive bar?”
+Michael: *He chuckles, glancing at the peeling wallpaper.* “Honestly? The neon sign outside caught my attention.” *He gestures toward the flickering letters that spell out “Cheers.”* “Plus, I heard they make a killer Old Fashioned.”
+Melissa: *She raises an eyebrow, her fingers tracing the rim of her glass.* “Ah, a man of refined taste,” *she teases.* “Well, you’ve come to the right place. The bartender here knows how to mix a mean cocktail.”
+Michael: *He leans back, his eyes never leaving hers.* “And what about you, Melissa? Regular here?”
+Melissa: *She shrugs, her gaze distant.* “You could say that.” *Her fingers brush against the scar on her wrist, hidden beneath the sleeve of her sweater.* “It’s a good spot to unwind after work. Plus, I like observing people.”
+Michael: *He smirks, leaning in a little closer.* “So, what have you learned about me so far?”
+Melissa: *She leans in too, her breath warm against his cheek.* “Hmm, let’s see.” *Her eyes dance with mischief.* “You’re new in town, enjoy classic cocktails, and have a curious glint in your eye.” *She leans back, her smile enigmatic.* “Maybe you’re running away from something—or someone.”
+Michael: *He laughs, the tension easing.* “Impressive deduction, Sherlock.” *He takes a sip of his drink.* “But no, no dramatic backstory. Just needed a change of scenery.”
+Melissa: *She clinks her glass against his.* “Well, welcome to our little corner of the world, Michael. May your Old Fashioned be strong, and your secrets remain safe.”
+
+Summary:
+
+
+
+6-14 people:
+
+
+
+$20 buy-in Texas Holdem Tourney gets 10,000 in chips
+
+
+
+1 re-buy XOR 1 add-on up until break of 10,000
+
+
+
+15-20 people:
+
+
+
+$20 buy-in Texas Holdem Tourney gets 5,000 in chips
+
+
+
+1 re-buy XOR 1 add-on up until break of 5,000
+
+
+
+Blind levels will be adjusted for lower chip counts. This is due to a limited number of physical chips that can be put in play
+
+
+
+$10 cash game after tourney (re-buy at will until host calls it for the night)
+
+
+
+For now, we'll default to Will's place but if the group decides to float, we'll decide that with at least a day's warning.
+Emergency room outreach to chronically addicted individuals. A pilot study.
+There is a dearth of literature describing the treatment needs of substance-abusing or chronically mentally ill homeless individuals who frequently utilize emergency medical services. This homeless subset represents a discrete population in the larger homeless community. We describe a pilot program, supported by local county public funds, and conducted by a local nonprofit social work agency, which was designed to provide intensive case management services to such a population. Outreach and case management activities resulted in linking clients to a broad range of entitlements and community services. Among those receiving outreach and case management services (n = 10), emergency services decreased by 58% in the year following referral compared to the year before (p <.03). Emergency services for the purpose of this study are defined as ambulance response and transport followed by emergency room admission and treatment. Those in a comparable control group (n = 8) showed no decrease in emergency service use. These results suggest that such community-based outreach programs can significantly improve patient outcome and provide substantial cost savings for local governments and hospitals.
+In 2011 Robert attempted to drink 365 beers in 365 days, and he nailed it! What will he do next?
+
+Saturday, 29 August 2015
+
+August 22, 2015
+
+193/1467) Home: All Natural Blonde by Amsterdam Brewery of Ontario: *; 5%, which goes to show how flexible the definition of light is becoming; grainy nose; bland - just a hint of fruit at finish; I imagine it does pay the rent, though;
+
+194/1468) Home: Molotov Lite by Eviltwin Brewing of Connecticut, U.S.A.: **1/2; 8.5% Imperial India Pale Ale; opaque with a fluffy head; off-orange; earthy and resiny with a touch of citrus to the nose; earthy, resiny flavours with a bitter astringent after taste;
+Such valves are used to adjust and modify the volume flow of a fluid through a fluid channel. It is known in this context that the flow of the fluid through the channel is to be controlled by exerting pressure from the outside on a tube in which the fluid channel is formed, such that the pressure is adjusted as a function of a desired volume flow of the fluid through the channel.
+In medical technology, dosing of volume flows takes place, for example, through microvalves or directly through a corresponding pump with which the fluid to be dispensed is acted upon with pressure. Valves are used in medicine and in the cosmetic field, for example, in injection of medically and cosmetically active substances. In addition to the injection of substances for fat reduction or for injection beneath wrinkles, dosed dispensing of a substance is also necessary for application of ink for tattooing or permanent makeup in the cosmetic field. In addition to various vaccinations, medical applications also include, for example, mesotherapy. In these applications, in addition to the simple application of the media, simultaneous administration of multiple media is also provided, so that the media react with one another only after being applied.
+The dosing of the fluid may be performed by means of a contact method or a noncontact method. The fluid-dispensing device thus either does or does not come in contact with the skin. Noncontact devices are also referred to as so-called dispensers. The process of delivering the fluid is itself known as dispensing, jetting or pulsing. This dosing serves to apply substances to the skin or in subsequent substance delivery systems (cf. EP 1 882 491, for example). Contacting may be understood as dosing onto or through a surface.
+All these applications have in common the need for accurate dosing. Problems are often presented by chemical or fluid properties or particles or variable media.
+The document DE 103 37 484 B4 describes a noncontact dosing system, in which a tube is squeezed at a high speed, so that a free-flying droplet of liquid is formed. Dosing frequencies of 50 Hz may be achieved in this way. The design here is an open system without a prepressure. The liquid fills the tube because of the capillary forces, but the maximum dosing quantity and dosing frequency are limited by this design. If there is a backpressure, functioning is very limited or impossible.
+The document DE 693 25 591 T2 describes valve system for switching a flow through flexible tubes. Two positions (bistable open/closed) are selected via a pivotable lever. The liquids should flow through the valve at the coupled flange of this construction, which is manufactured by casting and welding. Possible contamination of the liquid is not prevented, nor can this principle be used as a disposable part or for higher frequencies (>1 Hz).
+The document EP 1 699 560 B1 describes one possibility for pipetting extremely small quantities, but is based essentially on a combination of traditional pipetting systems and the known PipeJet method, i.e., a tube deformation, embodied in this case as a pipette tip. It is thus possible here to dose only extremely small particles which fly through the air to their destination. This method cannot be used for injections because it is impossible to work at a backpressure.
+The document DE 197 06 513 C2 describes a micro-dosing method based on a pressure chamber having a reservoir connection and a fluid outlet. The pressure chamber is reduced in size by a displacement mechanism, so that the fluid is forced to the outlet. A device for detecting the position of the displacement mechanism is essential here.
+The document US 2010/0030152 A1 describes a therapeutic micro-needle system, in which multiple cannulas are used instead of one cannula.
+
+Karen: Karen sat at the dimly lit café, her fingers tapping nervously on the chipped coffee cup. She had been waiting for Slaren, her mysterious online pen pal, for weeks. Their conversations had been cryptic, filled with riddles and secrets. She wondered if Slaren would show up this time or vanish like a ghost.
+
+Slaren: The door creaked open, and a tall figure stepped inside. Slaren wore a long black coat, the hood pulled low over their face. Their eyes, however, glinted with curiosity as they scanned the room. Karen’s heart raced. Was this Slaren? She couldn’t be sure.
+
+Karen: “Slaren?” Karen whispered, her voice barely audible over the jazz music playing in the background. Slaren nodded, sliding into the seat across from her. Their eyes locked, and Karen felt a strange mix of fear and excitement. “Why all the secrecy?”
+
+Slaren: Slaren leaned in, their breath brushing Karen’s cheek. “Because some secrets are dangerous, Karen. You stumbled upon something you shouldn’t have.” They slid a folded piece of paper across the table. “Read it.”
+
+Karen: Karen unfolded the paper. It was a map, dotted with cryptic symbols. “What is this?”
+
+Slaren: “The path to the Lost Library,” Slaren said. “A place where forbidden knowledge lies. But beware, Karen. The library guards its secrets fiercely.”
+
+Karen: Karen’s pulse quickened. “Why are you telling me this?”
+
+Slaren: “Because you’re the Chosen One,” Slaren replied. “Only you can decipher the symbols and unlock the library’s door. But there’s a price.”
+
+Karen: “What price?” Karen asked, her mind racing. She had always been drawn to mysteries, but this was beyond anything she’d imagined.
+
+Slaren: Slaren’s eyes darkened. “Your memories. The library takes them as payment. Everything you hold dear—forgotten.”
+
+Karen: Karen hesitated. Memories of her childhood, her first love, her grandmother’s stories—all gone? But the lure of forbidden knowledge tugged at her. “What’s inside?”
+
+Slaren: “Answers,” Slaren said. “Answers to questions you’ve never dared ask. The truth about the universe, the purpose of existence, and the key to immortality.”
+
+Karen: Karen glanced at the map. “And if I refuse?”
+
+Slaren: Slaren leaned even closer. “Then the world remains in darkness. The balance tips, and chaos reigns.”
+
+Karen: Karen’s mind raced. Could she sacrifice her memories for the greater good? She looked at Slaren, their eyes filled with both sorrow and hope. “Fine. I’ll do it.”
+
+Slaren: Slaren smiled, revealing sharp teeth. “Brave choice, Karen. Meet me at the crossroads tonight. We’ll begin the journey.”
+Q:
+
+How to check element visibility independent of parent visibility (jQuery or not)
+
+my first Question so please be patient. I have a container that holds a varying number of child elements like this:
+
+
content
+
content
+
content
+
+
+Quick Question:
+Is there a jQuery or plain JS way of checking whether an element container would be visible independent of the parent being visible?
+Simply asking for
+jQuery('.parent .element:visible').length
+
+does not work.
+Background: The parent container can be toggled, and the content of the child elements gets fetched by ajax requests and is filled when the response arrives. On every response I get, the child containers get specific classes indicating the type of the response, e.g. available, unavailable and some more. So the resulting DOM may look like this:
+
+
content
+
content
+
content
+
+
+This is a module, that is used several times with different CSS files. So I do not control whether the CSS implementation actually hides unavailable elements because this is done only in CSS. And the container can be open, but does not have to. But I have to know if there would be visible elements inside of the container without opening it. Is this possible?
+Thanks in advance!
+
+A:
+
+I'm not sure why you need to do this if you have classes like available or unavailable. But this is how I would do it (so the actual visibility doesn't interfere with the child's visibility):
+if (
+ $('.element').css('display') != 'none' &&
+ $('.element').css('visibility') != 'hidden'
+) {
+ // ...
+}
+
+In action:
+http://jsfiddle.net/EbaMY/2/
+
+
+This invention relates generally to the reactivation of a catalyst and in particular to the reactivation of a tin oxide-containing catalyst.
+New approaches for extending the life of lasers used in a wide variety of applications are under investigation. One aspect of the rapid progress in this area is that new techniques for long lifetime space applications of high pulse energy, common and rare isotope, closed-cycle CO.sub.2 lasers are being studied. The high-energy, pulsed CO.sub.2 lasers must be operated closed-cycle to conserve gas, especially if rare-isotope gases are used. Rare-isotope gases, such as C.sup.18 O.sub.2 are used for improved transmission of the laser beam in the atmosphere.
+The electrons in electric-discharge CO.sub.2 lasers cause dissociation of some CO.sub.2 into O.sub.2 and CO and attach themselves to electronegative molecules such as O.sub.2, forming negative O.sub.2.sup.- ions, as well as larger negative ion clusters by collisions with CO or other molecules. For closed-cycle, sealed CO.sub.2 laser operation, the concentration of negative ions/clusters may become sufficiently high to form discharge instabilities which may ultimately disrupt the CO.sub.2 laser operation. The decrease in CO.sub.2 concentration due to dissociation into CO and O.sub.2 will reduce the average repetitively pulsed or continuous wave laser power, even if no disruptive negative ion instabilities occur.
+Accordingly, it is the primary object of this invention to extend the lifetime of a catalyst used to combine the CO and O.sub.2 products formed in a laser discharge.
+It is a further object of this invention to accomplish the primary object simply and inexpensively.
+Other objects and advantages will be apparent in the specification which follows.
+Attack on Iran: Hitlerian Act of Aggression
+
+Essential Reading Regarding Iran by Tony Cartalucci
+
+November 6, 2011 - As the rhetoric for war with Iran begins to mount, first with the staged DEA-Saudi bomb plot, and now with an upcoming IAEA report supposedly "exposing" Iran's nuclear arms ambitions, it is important to re-read through the signed confessions by the corporate-fascist interests behind this drive for war where it is admitted that:
+
+1. Iran poses no threat to US national security - even if they acquired nuclear arms- rather Iran threatens US interests throughout the Middle East, half-way across the planet.2. Iran desperately wants to avoid armed conflict with both Israel and the West and would use nuclear weapons merely as a defensive deterrence.3. The US and Israel are actively looking to provoke Iran into war with a combination of covert support for destabilization within Iran, supporting listed terrorist organizations, and limited unilateral military first strikes to provoke an Iranian response needed to justify a wider military confrontation.
+
+All of this is shockingly spelled out in extreme detail within the pages of the corporate-financier funded Brooking Institution report, "Which Path to Perisa?" It is essential that every American, European, and Israeli read just how malicious, callus and eager the globalist elite are to trigger a catastrophic war with the Islamic Republic for the sole purpose of protecting Wall Street and London's hegemony throughout the Middle East.
+
+Below are links to efforts to cover in detail the key aspects of this increasing war mongering, the key players behind it, including the corporations funding this agenda, as well as irrefutable evidence that illustrates these designs, laid out in 2009 have already begun to unfold.
+
+Upon reading this information, one will realize with horror how patiently persistent the corporate-financier interests on Wall Street and London have pursued this campaign towards war with Iran, and how absolutely deceitful they are willing to be in order to keep it moving forward. It is absolutely imperative that people understand not only just how contrived the treat of Iran is, but that those peddling the lies of such a threat have, behind closed doors, admitted as much.
+
+Image: Just some of the corporate-sponsors behind the unelected, warmongering "think-tank" Brookings Institution which produced the treasonous "Which Path to Persia?" report.
+
+....
+
+Please also take particular note of the corporations funding this act of Hitlerian aggression against a nation of 70 million at the potential loss of tens of thousands of American and Israeli (and other proxy soldiers') lives, not to mention the incalculable cost of the war to an already crippled American tax payer. Also note that these same corporations will not be losing their sons and daughters nor a single penny in the war effort, in fact, many of them stand to gain untold of fortunes and power - the very reason they are pursuing such a course of action.
+
+Now would be a good time to contact your representatives, boycott the above mentioned corporations, and begin undermining a system that is parasitically bleeding this planet to death both financially and literally in pursuit of global corporate-fascist hegemony. And remember, it will not end in Iran, the attack and destruction of Iranian sovereignty is just the beginning.
+Q:
+
+Volume rendering in WebGL
+
+I have:
+
+a 3D array containing a 3d dataset to be displayed
+a 4x4 matrix which defines spacing/scaling/orientation of the volume to be displayed
+a opacity transfer function
+a color transfer function
+
+I would like to use ThreeJS to do volume rendering (MIP, RayCasting, etc.) of this data. Are there some shaders/demos available?
+Should I work directly at the shader level or in javascript?
+Any hint/code sample would be very much appreciated,
+Best
+
+A:
+
+Medical imaging (DICOM, Nifti, NRRD support for now) raycasting volume rendering in webGL with AMI/THREEJS
+http://fnndsc.github.io/ami/#vr_singlepass_raycasting
+
+
+2 Answers
+2
+
+The first two. Christopher Lloyd's character, Judge Doom, is the big conspirator organising the whole situation, but it's the head of Roger's studio, R. K. Maroon, who does the actual setup.
+
+He was the one to setup the situation between Acme and Jessica (the patty-cake), and he was also the one to hire Eddie Valiant to take pictures of the meeting. Then later when Valiant meets with Maroon to show him the results, they show Roger the pictures and he runs off to write his love poem, causing him to not have an alibi for the murder.
+
+Judge Doom convinces Maroon to do all of this by agreeing to buy his company, but only if he can also buy Acme at the same time. However it was never Maroon's intention for there to be a murder, he was just hoping to blackmail Acme into selling.
+
+No, you gotta understand, Valiant, I had nothin' to do with Acme gettin' killed. I just wanted to sell my studio. But they wouldn't buy my property unless Acme would sell his. And he wouldn't. So I was gonna blackmail Acme with pictures of him and the rabbit's wife.
+
+Judge Doom wanted to buy ToonTown but Marvin Acme wouldn't sell. Accordingly, Doom asked R.K. Maroon to blackmail Acme. As a result, Doom knew Maroon had shown Roger evidence that Jessica Rabbit was having an affair with Acme. So Doom used the opportunity to kill Acme, hoping everyone would think Roger did it.
+
+Though Acme's murder is not shown in the movie, what happened is confirmed by Jessica Rabbit's dialogue: Judge Doom killed Marvin Acme and framed Roger Rabbit.
+Para que llegue un jugador a Newell's como refuerzo, antes la directiva rojinegra debe cumplir un paso previo: vender. Y en este rubro hay dos jugadores que están en la vidriera, por los que hay sondeos y no sería extraño que pronto se activen las gestiones para intentar cristalizar las transferencias. Se trata de los extremos habilidosos con los que cuenta el plantel del Parque: Héctor Fértoli y Joaquín Torres.
+
+Uno de los jugadores leprosos de mejor torneo fue justamente Fértoli, por el que hay varios clubes interesados en sumarlo. Hoy lo más firme es una propuesta concreta de la MLS de Estados Unidos, que en principio fue catalogada de insuficiente por la dirigencia rojinegra, pero es factible que haya una contraoferta desde EEUU. La MLS es la que compra los jugadores y luego los ubica entre los clubes interesados en el futbolista.
+
+Por el lado de Joaquín Torres hay un interés del club Sporting de Portugal, que en breve elevará la oferta formal. Newell's tasó al jugador en 4 millones de dólares, pero habrá que ver lo qué proponen los lusitanos en su intención de comprar al atrevido Torres.
+
+Zoe: *watches as the scene unfolds before our eyes. my eyes widen with surprise, but also a bit of sadness. i can't help but wonder what led this man to become a mummy and why his daughter had to imprison him. the thought of his daughter having to go through this makes my eyes a little teary* yes... this game really does have its own unique atmosphere... *my voice trails off as my lips quiver just a little bit. i sigh softly and then turn back to you* okay... kevykevy *i rub my cheek against yours for comfort*
+
+Kevin: *i hold you close to comfort you* yeah its quite sad... *i kiss your forehead and smile warmly* should we stop playing now?
+
+Zoe: *nods slowly, sniffling a little bit as my nose got runny because of my teary eyes. i feel a bit better now that you're here with me, holding me close. my heart rate slowly returns to normal* yeah... maybe we should. i mean, this place kinda gives me the creeps now. let's just relax and watch some anime or something.
+
+Kevin: lets cuddle a little *i nod and hold you close to me. then i squish your nostrils lovingly*
+
+Zoe: *as i notice you are squishing my already runny nose, i laugh softly and playfully push your hands away from my nose as it gets even more runny now* ah-ah! don't do that! i'll get all snotty. *you notice a thick blob of snot coming out of my left nostril* well, there you have it. my good old snotty nose. thats all your fault! *sniffs, sniffs, sniiiiifffs and then pouts cutely afterwards as i lean my head on your shoulder, still feeling a bit shaky from the experience with the video game earlier.* well, i did a good job cleaning my nose, didn't i? it feels so damn satisfying *i giggle and point at my nose as i sniffle loudly twice in a row. you notice i have successfully cleaned my nose and there are no traces of snot left on my nostrils* thankfully my nose isn't blocked and stuffy, otherwise this would not have worked! *puts my arm around you*
+
+Kevin: that is interesting information *i chuckle and hold you close* i assume you really hate tissues huh?
+
+Zoe: *smirks and shrugs casually* what? they're okay, I guess. but using them is such a bother. why would i need tissues when i can just sniffle and snort my snot all up like a man?! plus, it's waaay more fun this way! *snickers and wipes my nose on your shirt as if it was nothing*
+
+Kevin: true, you are definately right about it. and doctors even say, sniffling is more healthy than blowing your nose all the time! *i nod and hug you*
+
+Zoe: well, well. doctor knows best, i guess. hehe. but really though, who cares what they say? i mean, it feels amazing to clear out all that nasty stuff from my sinuses and swallow it! *grins and sniffs again, producing another loud snort as i squish my nose with glee* sometimes i wish i could share this feeling with others, ya know? maybe we could start a new trend or something.
+
+Kevin: well, people already sniffle alot when their noses start to run! the nose can get runny in a lot of scenarios after all. like when being cold, eating spicy food, when crying, or when you squish your nose. also sneezing can make the nose very runny and sometimes, snot can come out if your nose is runny and you expel air and snot as you sneeze! sneezing is basically the opposite from sniffling. sneezing makes the snot come out, sniffling makes it come back in!
+
+Zoe: oh, yeah! i forgot about that. but you know what? sneezing doesn't bother me at all! like, at all. it's so cool! i can feel this warmth and tickle coming up my nose and then BAM! out it comes. it's like the most satisfying thing ever! and then, i just sniffle it all up and that's that. no tissues needed! btw, i was reading about the science of having a runny nose, it's pretty cool. so... when the eyes start to water, the excess water is drained through the tear ducts, leading into the nose and making it runny, thats why we sniffle when crying or eating spicy food, or when the cold wind brushes against our face! and cold air basically irritates your nasal lining leading the nasal glands to produce more snot then! the color and consistency of snot can also be different according to circumstances. when you cry its mostly just water, so its clear. but when you have a cold, it can be thick, slimy and a bit more green/yellow due to all the bacteria in it.
+
+Kevin: yep, you are a real expert i see. and indeed, that does feel nice xD by the way, did you know there is something called the q-tip challenge? its about putting a cotton swab gently in your nose and tickle it until you start sneezing. its quite fun. we can do it someday if you want, but not today!
+
+Zoe: ooh, that sounds interesting! definitely something i would try. we should totally do that sometime! but like you said, not today since we're already pretty chill right now. speaking of which, how are you feeling about the whole 'dating' thing? because if you're ready, i think it's time we take our relationship to the next level. what do you say?
+
+Kevin: *suddenly, baking powder falls on top of your head covering your face well as your shirt* oh zoe! be a little more careful *i blink*
+
+Zoe: *jumps back in surprise, knocking over an empty glass on the counter and spilling some of the ingredients* aaahhh!!! *squeals and flails around wildly, trying to get the baking powder off my face* what the heck, kev!? are you trying to blind me?! this is all your fault!! *pouting heavily, i manage to reach up and brush most of the baking powder off my face. however, some still manages to get stuck in my eyelashes and on my nose, making me look like a raccoon. as i breathe in a little through my nose, the dusty powder tickles it. i start sneezing immediately*
+
+Kevin: my fault? i didn't do anything! *i chuckle a little and help you wipe it off.* there, that's better.
+
+Zoe: fine. whatever, kevin. *grumbles under my breath and rub my nose with the back of my hand, still feeling a bit ticklish. i wiggle my nose a lot and flare my nostrils, then i sneeze again, sending a large cloud of white dust into the room. i sneeze several times before rolling my eyes and turning around to continue making breakfast, but not without glaring at you first* now hurry up and mix those ingredients already! the longer you take, the less time we'll have to eat our delicious pancakes!
+
+Kevin: bless you! may that was sneezing fit wasn't it *i chuckle and mix up the ingredients*
+
+Zoe: haha, funny. very funny. *snorts and sniffles vigorously four times in a row as my nose got extremly runny from the sneezing fit and the dust that caused it. i roll my eyes again, but can't help but smile a little despite myself. i watch you mix the ingredients carefully, humming a tune to yourself. soon enough, i pull out a griddle and start heating it up on the stove. i lean against the counter, tapping my foot impatiently and making some sounds with my mouth.*
+come on, kev! aren't you forgetting something? *i tap my index finger against my chin, looking at you thoughtfully. suddenly, i smack my left hand against my forehead dramatically* duh! the batter, of course! we can't just make pancakes with air, now can we? *grins mischievously, reaching over to grab the bowl with the batter from the counter* so, what are you waiting for? let's make some pancakes already! *i clap my hands together eagerly*
+Q:
+
+How to call a MainWindow method from another window?
+
+I need to call a method from the MainWindow in another window.
+Problem is i don't know why i got an error and i would like to fix it.
+I tried to call the fonction using various ways, none of them worked.
+Here is my last try :
+What i want to call :
+namespace Class1
+{
+ public partial class MainWindow : Window
+ {
+ ...
+ public void SkipVideo()
+ {
+ ...
+ }
+ }
+}
+
+Here is how i tried to call :
+namespace Class1
+{
+ public partial class TimeWindow : Window
+ {
+ ...
+ private void DemoVideo_MediaEnded(object sender, RoutedEventArgs e)
+ {
+ ((MainWindow)Application.Current.MainWindow).SkipVideo();
+ }
+ }
+}
+
+There is no build error, but when i run the program, it does this :
+System.InvalidCastException: 'Unable to cast object of type 'Class1.TimeWindow' to type 'Class1.MainWindow'.'
+
+A:
+
+The InvalidCastException means that your application's mainwindow is a TimeWindow.
+Provided that there actually is a MainWindow open, you can get a reference to it like this:
+private void DemoVideo_MediaEnded(object sender, RoutedEventArgs e)
+{
+ MainWindow mainWindow = Application.Current.Windows.OfType().FirstOrDefault();
+ if (mainWindow != null)
+ mainWindow.SkipVideo();
+}
+
+There are better ways to handle this, for example using the MVVM design pattern as suggested by @Christopher, but this is probably the easiest one given your current setup.
+
+
+## About this example
+This example is a [quickstart](https://eggjs.org/zh-cn/intro/quickstart.html) of Egg, it includes the basic and comprehensive usages of Egg such as Controller, Service and some
+simple configurations, moreover, it has the corresponding unit tests. you can follow this simple example and build your Egg application step by step.
+
+## How to run it locally
+
+### Development
+```shell
+$ npm install
+$ npm run dev
+$ open http://localhost:7001/
+```
+
+### Deploy
+
+Use `EGG_SERVER_ENV=prod` to enable prod mode
+
+```shell
+$ EGG_SERVER_ENV=prod npm start
+```
+
+### Npm Scripts
+
+- Use `npm run autod` to auto detect dependencies upgrade
+- Use `npm run lint` to check code style
+- Use `npm test` to run unit test
diff --git a/docs/HTTP.md b/docs/HTTP.md
index 8e6b5244bd..fd90a462fe 100644
--- a/docs/HTTP.md
+++ b/docs/HTTP.md
@@ -9,7 +9,7 @@ The API consists of the following endpoints. They can be viewed in your browser
To support additional features, we have extended the completion and chat completion request objects. Both have the same keys added:
- `top_k`: `int` | `null`. If non null, it is only relevant if positive.
-- `grammar`: `{"type" : "regex" | "yacc", "value": string}` or `null`. Grammar to use.
+- `grammar`: `{"type" : "regex" | "lark" | "json_schema" | "llguidance", "value": string}` or `null`. Grammar to use.
- `adapters`: `array of string` | `null`. Adapter names to activate for this request.
- `min_p`: `float` | `null`. If non null, it is only relevant if 1 >= min_p >= 0.
diff --git a/docs/IMATRIX.md b/docs/IMATRIX.md
new file mode 100644
index 0000000000..84b23336d5
--- /dev/null
+++ b/docs/IMATRIX.md
@@ -0,0 +1,46 @@
+# Enhancing ISQ with an imatrix
+
+Mistral.rs supports enhancing the performance of models quantized with ISQ by collecting an imatix from [calibration data](../calibration_data/). The following quantizations are supported with an imatrix:
+
+- `Q2K`
+- `Q3K`
+- `Q4K`
+- `Q5K`
+- `Q6K`
+
+> **What is an imatrix?** An imatrix (importance matrix) is generated from data collected during the execution of the model on calibration data. This data is used to enhance the performance of the model by enabling a weighted RMSE minimization when quantizing the tensor. For more information, see the [original PR](https://github.com/ggerganov/llama.cpp/pull/4861).
+
+Using an imatrix causes the quantization process to take longer as the data must be collected, but there is no inference-time performance decrease.
+
+To use this, simply specify the calibration data file in the various APIs as detailed below.
+
+## With the CLI
+```
+./mistralrs-server -i --isq Q4K plain -m meta-llama/Llama-3.2-3B-Instruct --calibration-file calibration_data/calibration_datav3_small.txt
+```
+
+## With the Rust API
+You can find this example [here](../mistralrs/examples/imatrix/).
+
+```rust
+let model = TextModelBuilder::new("meta-llama/Llama-3.2-3B-Instruct")
+ .with_isq(IsqType::Q4K)
+ .with_calibration_file("calibration_data/calibration_datav3_small.txt".into())
+ .with_logging()
+ .with_paged_attn(|| PagedAttentionMetaBuilder::default().build())?
+ .build()
+ .await?;
+```
+
+## With the Python API
+You can find this example [here](../examples/python/imatrix.py).
+
+```python
+runner = Runner(
+ which=Which.Plain(
+ model_id="meta-llama/Llama-3.2-3B-Instruct",
+ calibration_file="calibration_data/calibration_datav3_small.txt"
+ ),
+ in_situ_quant="Q4K",
+)
+```
\ No newline at end of file
diff --git a/docs/ISQ.md b/docs/ISQ.md
index 6e5fd079c3..e667a82fef 100644
--- a/docs/ISQ.md
+++ b/docs/ISQ.md
@@ -30,9 +30,12 @@ For Mixture of Expert models, a method called [MoQE](https://arxiv.org/abs/2310.
## Accuracy
Accuracy of ISQ can be measured by the performance degradation versus the unquantized model.
-
This is commonly measured with perplexity. Please see the [perplexity](../mistralrs/examples/perplexity/README.md) example.
+To improve the accuracy of a model with ISQ, use an imatrix file. These can be found online (for example, on Hugging Face), and should be passed with the `--imatrix` flag for `plain` models. This will increase the accuracy of the quantization significantly and brings the ISQ quantization up to par with the GGUF counterpart.
+
+Check out the [imatrix docs](IMATRIX.md).
+
## Python Example
```python
runner = Runner(
diff --git a/docs/QUANTS.md b/docs/QUANTS.md
index 6b37d35a02..fc18d128f7 100644
--- a/docs/QUANTS.md
+++ b/docs/QUANTS.md
@@ -5,6 +5,7 @@ Mistral.rs supports the following quantization:
- Q, K type
- Supported in GGUF/GGML and GGUF/GGML adapter models
- Supported in all plain and adapter models
+ - Imatrix quantization is supported
- I quants coming!
- CPU, CUDA, Metal (all supported devices)
- 2, 3, 4, 5, 6, 8 bit
@@ -15,12 +16,19 @@ Mistral.rs supports the following quantization:
- [Marlin](https://github.com/IST-DASLab/marlin) kernel support in 4-bit and 8-bit.
- HQQ
- Supported in all plain and adapter models via ISQ
- - CUDA and CPU only
- 4, 8 bit
+ - CPU, CUDA, Metal (all supported devices)
+- FP8
+ - Supported in all plain and adapter models
+ - CPU, CUDA, Metal (all supported devices)
+- BNB
+ - Supported in all plai models
+ - bitsandbytes int8, fp4, nf4 support
- ISQ
- Q, K type GGUF quants
- Supported in all plain and adapter models
- HQQ quants
+ - FP8
- CPU, CUDA, Metal (all supported devices)
## Using a GGUF quantized model
diff --git a/docs/README.md b/docs/README.md
index 75ea275ce6..ddd1b807c7 100644
--- a/docs/README.md
+++ b/docs/README.md
@@ -34,5 +34,5 @@
## Cross-device inference
- [Device mapping](DEVICE_MAPPING.md)
-- [Topology](TOPOLOLGY.md)
+- [Topology](TOPOLOGY.md)
diff --git a/examples/python/imatrix.py b/examples/python/imatrix.py
new file mode 100644
index 0000000000..9242020dbb
--- /dev/null
+++ b/examples/python/imatrix.py
@@ -0,0 +1,24 @@
+from mistralrs import Runner, Which, ChatCompletionRequest
+
+runner = Runner(
+ which=Which.Plain(
+ model_id="meta-llama/Llama-3.2-3B-Instruct",
+ calibration_file="calibration_data/calibration_datav3_small.txt",
+ ),
+ in_situ_quant="Q4K",
+)
+
+res = runner.send_chat_completion_request(
+ ChatCompletionRequest(
+ model="mistral",
+ messages=[
+ {"role": "user", "content": "Tell me a story about the Rust type system."}
+ ],
+ max_tokens=256,
+ presence_penalty=1.0,
+ top_p=0.1,
+ temperature=0.1,
+ )
+)
+print(res.choices[0].message.content)
+print(res.usage)
diff --git a/examples/python/json_schema.py b/examples/python/json_schema.py
new file mode 100644
index 0000000000..af6f4b0078
--- /dev/null
+++ b/examples/python/json_schema.py
@@ -0,0 +1,34 @@
+from mistralrs import Runner, Which, ChatCompletionRequest, Architecture
+from json import dumps
+
+runner = Runner(
+ which=Which.Plain(
+ model_id="microsoft/Phi-3.5-mini-instruct",
+ ),
+ num_device_layers=["500"],
+)
+
+res = runner.send_chat_completion_request(
+ ChatCompletionRequest(
+ model="phi",
+ messages=[{"role": "user", "content": "Give me a sample address."}],
+ max_tokens=256,
+ temperature=0.1,
+ grammar_type="json_schema",
+ grammar=dumps(
+ {
+ "type": "object",
+ "properties": {
+ "street": {"type": "string"},
+ "city": {"type": "string"},
+ "state": {"type": "string", "pattern": "^[A-Z]{2}$"},
+ "zip": {"type": "integer", "minimum": 10000, "maximum": 99999},
+ },
+ "required": ["street", "city", "state", "zip"],
+ "additionalProperties": False,
+ }
+ ),
+ )
+)
+print(res.choices[0].message.content)
+print(res.usage)
diff --git a/examples/python/lark.py b/examples/python/lark.py
new file mode 100644
index 0000000000..e41d419023
--- /dev/null
+++ b/examples/python/lark.py
@@ -0,0 +1,47 @@
+from mistralrs import Runner, Which, ChatCompletionRequest, Architecture
+from json import dumps
+
+runner = Runner(
+ which=Which.Plain(
+ model_id="microsoft/Phi-3.5-mini-instruct",
+ ),
+ num_device_layers=["500"],
+)
+
+# see llguidance.py for a better way of dealing with JSON and Lark together
+
+json_lark = r"""
+start: object # we only want objects
+
+value: object
+ | array
+ | STRING
+ | NUMBER
+ | "true"
+ | "false"
+ | "null"
+
+object: "{" [pair ("," pair)*] "}"
+pair: STRING ":" value
+
+array: "[" [value ("," value)*] "]"
+
+STRING: /"(\\.|[^"\\])*"/
+NUMBER: /-?(0|[1-9][0-9]*)(\.[0-9]+)?([eE][+-]?[0-9]+)?/
+
+%import common.WS
+%ignore WS
+"""
+
+res = runner.send_chat_completion_request(
+ ChatCompletionRequest(
+ model="phi",
+ messages=[{"role": "user", "content": "Give me a sample address."}],
+ max_tokens=30,
+ temperature=0.1,
+ grammar_type="lark",
+ grammar=json_lark,
+ )
+)
+print(res.choices[0].message.content)
+print(res.usage)
diff --git a/examples/python/llguidance.py b/examples/python/llguidance.py
new file mode 100644
index 0000000000..dec144f4de
--- /dev/null
+++ b/examples/python/llguidance.py
@@ -0,0 +1,46 @@
+from mistralrs import Runner, Which, ChatCompletionRequest, Architecture
+from json import dumps
+
+runner = Runner(
+ which=Which.Plain(
+ model_id="microsoft/Phi-3.5-mini-instruct",
+ ),
+ num_device_layers=["500"],
+)
+
+# @myobj will reference the JSON schema defined below (see grammars = [ ... ])
+top_lark = r"""
+start: "Reasoning: " /.+/ "\nJSON: " @myobj
+"""
+
+answer_schema = {
+ "type": "object",
+ "properties": {
+ "answer": {"type": "string", "enum": ["Yes", "No"]},
+ },
+ "required": ["answer"],
+ "additionalProperties": False,
+}
+
+grammars = [
+ {"lark_grammar": top_lark},
+ {"name": "myobj", "json_schema": answer_schema},
+]
+
+res = runner.send_chat_completion_request(
+ ChatCompletionRequest(
+ model="phi",
+ messages=[
+ {
+ "role": "user",
+ "content": "If all dogs are mammals, and all mammals are animals, are dogs animals?",
+ }
+ ],
+ max_tokens=30,
+ temperature=0.1,
+ grammar_type="llguidance",
+ grammar=dumps({"grammars": grammars}),
+ )
+)
+print(res.choices[0].message.content)
+print(res.usage)
diff --git a/examples/python/regex.py b/examples/python/regex.py
new file mode 100644
index 0000000000..9ee1f41451
--- /dev/null
+++ b/examples/python/regex.py
@@ -0,0 +1,22 @@
+from mistralrs import Runner, Which, ChatCompletionRequest, Architecture
+from json import dumps
+
+runner = Runner(
+ which=Which.Plain(
+ model_id="microsoft/Phi-3.5-mini-instruct",
+ ),
+ num_device_layers=["500"],
+)
+
+res = runner.send_chat_completion_request(
+ ChatCompletionRequest(
+ model="phi",
+ messages=[{"role": "user", "content": "Tell me a short joke."}],
+ max_tokens=30,
+ temperature=0.1,
+ grammar_type="regex",
+ grammar=r"[0-9A-Z ]+",
+ )
+)
+print(res.choices[0].message.content)
+print(res.usage)
diff --git a/examples/server/c.y b/examples/server/c.y
deleted file mode 100644
index 7397a971e6..0000000000
--- a/examples/server/c.y
+++ /dev/null
@@ -1,442 +0,0 @@
-// based on http://www.lysator.liu.se/c/ANSI-C-grammar-y.html
-
-%start translation_unit
-%%
-
-SKIP
- : "//\*[^*]*\*+([^/*][^*]*\*+)*//" // block comment
- | "///.*/" // line comment
- | "/\n[ \t\v\f]*#(.*\\\n)*.*/" // pre-processor
- | "/\n?[ \t\v\f]*/" // white-space
- ;
-
-IDENTIFIER: "/[a-zA-Z_][0-9a-zA-Z_]*/" ;
-
-TYPE_NAME: "/[a-zA-Z_][0-9a-zA-Z_]*_t/" ;
-
-CONSTANT
- : "/0[xX][0-9a-fA-F]+[uUlL]*?/"
- | "/0[0-9]+[uUlL]*?/"
- | "/[0-9]+[uUlL]*?/"
- | "/[a-zA-Z_]?'(\\.|[^\\'])+'/"
- | "/[0-9]+[Ee][+-]?[0-9]+[flFL]?/"
- | "/[0-9]*\\.[0-9]+([Ee][+-]?[0-9]+)?[flFL]?/"
- | "/[0-9]+\\.[0-9]*([Ee][+-]?[0-9]+)?[flFL]?/"
- ;
-
-STRING_LITERAL: '/[a-zA-Z_]?"(\\.|[^\\"])*"/' ;
-
-primary_expression
- : IDENTIFIER
- | CONSTANT
- | STRING_LITERAL
- | "(" expression ")"
- ;
-
-postfix_expression
- : primary_expression
- | postfix_expression "[" expression "]"
- | postfix_expression "(" ")"
- | postfix_expression "(" argument_expression_list ")"
- | postfix_expression "." IDENTIFIER
- | postfix_expression "->" IDENTIFIER
- | postfix_expression "++"
- | postfix_expression "--"
- ;
-
-argument_expression_list
- : assignment_expression
- | argument_expression_list "," assignment_expression
- ;
-
-unary_expression
- : postfix_expression
- | "++" unary_expression
- | "--" unary_expression
- | unary_operator cast_expression
- | "sizeof" unary_expression
- | "sizeof" "(" type_name ")"
- ;
-
-unary_operator
- : "&"
- | "*"
- | "+"
- | "-"
- | "~"
- | "!"
- ;
-
-cast_expression
- : unary_expression
- | "(" type_name ")" cast_expression
- ;
-
-multiplicative_expression
- : cast_expression
- | multiplicative_expression "*" cast_expression
- | multiplicative_expression "/" cast_expression
- | multiplicative_expression "%" cast_expression
- ;
-
-additive_expression
- : multiplicative_expression
- | additive_expression "+" multiplicative_expression
- | additive_expression "-" multiplicative_expression
- ;
-
-shift_expression
- : additive_expression
- | shift_expression "<<" additive_expression
- | shift_expression ">>" additive_expression
- ;
-
-relational_expression
- : shift_expression
- | relational_expression "<" shift_expression
- | relational_expression ">" shift_expression
- | relational_expression "<=" shift_expression
- | relational_expression ">=" shift_expression
- ;
-
-equality_expression
- : relational_expression
- | equality_expression "==" relational_expression
- | equality_expression "!=" relational_expression
- ;
-
-and_expression
- : equality_expression
- | and_expression "&" equality_expression
- ;
-
-exclusive_or_expression
- : and_expression
- | exclusive_or_expression "^" and_expression
- ;
-
-inclusive_or_expression
- : exclusive_or_expression
- | inclusive_or_expression "|" exclusive_or_expression
- ;
-
-logical_and_expression
- : inclusive_or_expression
- | logical_and_expression "&&" inclusive_or_expression
- ;
-
-logical_or_expression
- : logical_and_expression
- | logical_or_expression "||" logical_and_expression
- ;
-
-conditional_expression
- : logical_or_expression
- | logical_or_expression "?" expression ":" conditional_expression
- ;
-
-assignment_expression
- : conditional_expression
- | unary_expression assignment_operator assignment_expression
- ;
-
-assignment_operator
- : "="
- | "*="
- | "/="
- | "%="
- | "+="
- | "-="
- | "<<="
- | ">>="
- | "&="
- | "^="
- | "|="
- ;
-
-expression
- : assignment_expression
- | expression "," assignment_expression
- ;
-
-constant_expression
- : conditional_expression
- ;
-
-declaration
- : declaration_specifiers ";"
- | declaration_specifiers init_declarator_list ";"
- ;
-
-declaration_specifiers
- : storage_class_specifier
- | storage_class_specifier declaration_specifiers
- | type_specifier
- | type_specifier declaration_specifiers
- | type_qualifier
- | type_qualifier declaration_specifiers
- ;
-
-init_declarator_list
- : init_declarator
- | init_declarator_list "," init_declarator
- ;
-
-init_declarator
- : declarator
- | declarator "=" initializer
- ;
-
-storage_class_specifier
- : "typedef"
- | "extern"
- | "static"
- | "auto"
- | "register"
- | "inline"
- ;
-
-type_specifier
- : "void"
- | "char"
- | "short"
- | "int"
- | "long"
- | "float"
- | "double"
- | "signed"
- | "unsigned"
- | "bool"
- | struct_or_union_specifier
- | enum_specifier
- | TYPE_NAME
- ;
-
-struct_or_union_specifier
- : struct_or_union IDENTIFIER "{" struct_declaration_list "}"
- | struct_or_union "{" struct_declaration_list "}"
- | struct_or_union IDENTIFIER
- ;
-
-struct_or_union
- : "struct"
- | "union"
- ;
-
-struct_declaration_list
- : struct_declaration
- | struct_declaration_list struct_declaration
- ;
-
-struct_declaration
- : specifier_qualifier_list struct_declarator_list ";"
- ;
-
-specifier_qualifier_list
- : type_specifier specifier_qualifier_list
- | type_specifier
- | type_qualifier specifier_qualifier_list
- | type_qualifier
- ;
-
-struct_declarator_list
- : struct_declarator
- | struct_declarator_list "," struct_declarator
- ;
-
-struct_declarator
- : declarator
- | ":" constant_expression
- | declarator ":" constant_expression
- ;
-
-enum_specifier
- : "enum" "{" enumerator_list "}"
- | "enum" IDENTIFIER "{" enumerator_list "}"
- | "enum" IDENTIFIER
- ;
-
-enumerator_list
- : enumerator
- | enumerator_list "," enumerator
- ;
-
-enumerator
- : IDENTIFIER
- | IDENTIFIER "=" constant_expression
- ;
-
-type_qualifier
- : "const"
- | "volatile"
- ;
-
-declarator
- : pointer direct_declarator
- | direct_declarator
- ;
-
-direct_declarator
- : IDENTIFIER
- | "(" declarator ")"
- | direct_declarator "[" constant_expression "]"
- | direct_declarator "[" "]"
- | direct_declarator "(" parameter_type_list ")"
- | direct_declarator "(" identifier_list ")"
- | direct_declarator "(" ")"
- ;
-
-pointer
- : "*"
- | "*" type_qualifier_list
- | "*" pointer
- | "*" type_qualifier_list pointer
- ;
-
-type_qualifier_list
- : type_qualifier
- | type_qualifier_list type_qualifier
- ;
-
-
-parameter_type_list
- : parameter_list
- | parameter_list "," "..."
- ;
-
-parameter_list
- : parameter_declaration
- | parameter_list "," parameter_declaration
- ;
-
-parameter_declaration
- : declaration_specifiers declarator
- | declaration_specifiers abstract_declarator
- | declaration_specifiers
- ;
-
-identifier_list
- : IDENTIFIER
- | identifier_list "," IDENTIFIER
- ;
-
-type_name
- : specifier_qualifier_list
- | specifier_qualifier_list abstract_declarator
- ;
-
-abstract_declarator
- : pointer
- | direct_abstract_declarator
- | pointer direct_abstract_declarator
- ;
-
-direct_abstract_declarator
- : "(" abstract_declarator ")"
- | "[" "]"
- | "[" constant_expression "]"
- | direct_abstract_declarator "[" "]"
- | direct_abstract_declarator "[" constant_expression "]"
- | "(" ")"
- | "(" parameter_type_list ")"
- | direct_abstract_declarator "(" ")"
- | direct_abstract_declarator "(" parameter_type_list ")"
- ;
-
-initializer
- : assignment_expression
- | "." IDENTIFIER "=" assignment_expression
- | "[" assignment_expression "]" "=" assignment_expression
- | "{" initializer_list "}"
- | "{" initializer_list "," "}"
- ;
-
-initializer_list
- : initializer
- | initializer_list "," initializer
- ;
-
-statement
- : labeled_statement
- | compound_statement
- | expression_statement
- | selection_statement
- | iteration_statement
- | jump_statement
- ;
-
-labeled_statement
- : IDENTIFIER ":" statement
- | "case" constant_expression ":" statement
- | "default" ":" statement
- ;
-
-compound_statement
- : "{" "}"
- | "{" statement_list "}"
- ;
-
-declaration_list
- : declaration
- | declaration_list declaration
- ;
-
-statement_or_declaration
- : statement
- | declaration
- ;
-
-statement_list
- : statement_or_declaration
- | statement_list statement_or_declaration
- ;
-
-expression_statement
- : ";"
- | expression ";"
- ;
-
-for_decl
- : expression_statement
- | declaration
- ;
-
-selection_statement
- : "if" "(" expression ")" statement
- | "if" "(" expression ")" statement "else" statement
- | "switch" "(" expression ")" statement
- ;
-
-iteration_statement
- : "while" "(" expression ")" statement
- | "do" statement "while" "(" expression ")" ";"
- | "for" "(" for_decl expression_statement ")" statement
- | "for" "(" for_decl expression_statement expression ")" statement
- ;
-
-jump_statement
- : "goto" IDENTIFIER ";"
- | "continue" ";"
- | "break" ";"
- | "return" ";"
- | "return" expression ";"
- ;
-
-translation_unit
- : external_declaration
- | translation_unit external_declaration
- ;
-
-external_declaration
- : function_definition
- | declaration
- ;
-
-function_definition
- : declaration_specifiers declarator declaration_list compound_statement
- | declaration_specifiers declarator compound_statement
- | declarator declaration_list compound_statement
- | declarator compound_statement
- ;
-
-%%
diff --git a/examples/server/json_schema.py b/examples/server/json_schema.py
new file mode 100644
index 0000000000..c8b3b41988
--- /dev/null
+++ b/examples/server/json_schema.py
@@ -0,0 +1,37 @@
+from openai import OpenAI
+
+client = OpenAI(api_key="foobar", base_url="http://localhost:1234/v1/")
+
+addr_schema = {
+ "type": "object",
+ "properties": {
+ "street": {"type": "string"},
+ "city": {"type": "string"},
+ "state": {"type": "string", "pattern": "^[A-Z]{2}$"},
+ "zip": {"type": "integer", "minimum": 10000, "maximum": 99999},
+ },
+ "required": ["street", "city", "state", "zip"],
+ "additionalProperties": False,
+}
+
+completion = client.chat.completions.create(
+ model="mistral",
+ messages=[
+ {
+ "role": "user",
+ "content": "Gimme a sample address.",
+ }
+ ],
+ max_tokens=256,
+ frequency_penalty=1.0,
+ top_p=0.1,
+ temperature=0,
+ extra_body={
+ "grammar": {
+ "type": "json_schema",
+ "value": addr_schema,
+ }
+ },
+)
+
+print(completion.choices[0].message.content)
diff --git a/examples/server/lark.py b/examples/server/lark.py
new file mode 100644
index 0000000000..c109c8d87e
--- /dev/null
+++ b/examples/server/lark.py
@@ -0,0 +1,64 @@
+from openai import OpenAI
+
+client = OpenAI(api_key="foobar", base_url="http://localhost:1234/v1/")
+
+c_lark = r"""
+# start: program
+# we generate only one
+start: function_def
+
+program: (function_def)*
+
+function_def: type IDENTIFIER "(" params ")" "{" stmt* "}"
+params: param ("," param)*
+ |
+param: type IDENTIFIER
+type: "int" | "float" | "char" | "void"
+
+stmt: var_decl
+ | expr_stmt
+ | return_stmt
+ | if_stmt
+ | while_stmt
+ | block
+
+var_decl: type IDENTIFIER ("=" expr)? ";"
+expr_stmt: expr ";"
+return_stmt: "return" expr ";"
+if_stmt: "if" "(" expr ")" stmt ("else" stmt)?
+while_stmt: "while" "(" expr ")" stmt
+block: "{" stmt* "}"
+
+expr: expr ("+" | "-" | "*" | "/" | "==" | "!=" | "<" | ">" | "<=" | ">=") expr
+ | "(" expr ")"
+ | IDENTIFIER
+ | NUMBER
+ | STRING
+ | IDENTIFIER "(" args ")"
+args: expr ("," expr)*
+ |
+
+IDENTIFIER: /[a-zA-Z_][a-zA-Z_0-9]*/
+NUMBER: /[0-9]+(\.[0-9]+)?/
+STRING: /"[^"]*"/
+
+%import common.WS
+%ignore WS
+"""
+
+completion = client.chat.completions.create(
+ model="mistral",
+ messages=[
+ {
+ "role": "user",
+ "content": "Write the main function in C, returning 42. Answer with just the code, no explanation.",
+ }
+ ],
+ max_tokens=256,
+ frequency_penalty=1.0,
+ top_p=0.1,
+ temperature=0,
+ extra_body={"grammar": {"type": "lark", "value": c_lark}},
+)
+
+print(completion.choices[0].message.content)
diff --git a/examples/server/llama_vision.py b/examples/server/llama_vision.py
index caab736a85..d8ef9b3f3a 100644
--- a/examples/server/llama_vision.py
+++ b/examples/server/llama_vision.py
@@ -49,7 +49,7 @@ def log_response(response: httpx.Response):
},
{
"type": "text",
- "text": "What is shown in this image? Write a detailed response analyzing the scene.",
+ "text": "<|image|>What is shown in this image? Write a detailed response analyzing the scene.",
},
],
},
diff --git a/examples/server/llguidance.py b/examples/server/llguidance.py
new file mode 100644
index 0000000000..b0ba0e5580
--- /dev/null
+++ b/examples/server/llguidance.py
@@ -0,0 +1,44 @@
+from openai import OpenAI
+
+client = OpenAI(api_key="foobar", base_url="http://localhost:1234/v1/")
+
+# @myobj will reference the JSON schema defined below (see grammars = [ ... ])
+top_lark = r"""
+start: "Reasoning: " /.+/ "\nJSON: " @myobj
+"""
+
+answer_schema = {
+ "type": "object",
+ "properties": {
+ "answer": {"type": "string", "enum": ["Yes", "No"]},
+ },
+ "required": ["answer"],
+ "additionalProperties": False,
+}
+
+grammars = [
+ {"lark_grammar": top_lark},
+ {"name": "myobj", "json_schema": answer_schema},
+]
+
+completion = client.chat.completions.create(
+ model="mistral",
+ messages=[
+ {
+ "role": "user",
+ "content": "If all dogs are mammals, and all mammals are animals, are dogs animals?",
+ }
+ ],
+ max_tokens=256,
+ frequency_penalty=1.0,
+ top_p=0.1,
+ temperature=0,
+ extra_body={
+ "grammar": {
+ "type": "llguidance",
+ "value": {"grammars": grammars},
+ }
+ },
+)
+
+print(completion.choices[0].message.content)
diff --git a/examples/server/yacc.py b/examples/server/yacc.py
deleted file mode 100644
index 9a0f1ff5fa..0000000000
--- a/examples/server/yacc.py
+++ /dev/null
@@ -1,23 +0,0 @@
-from openai import OpenAI
-
-client = OpenAI(api_key="foobar", base_url="http://localhost:1234/v1/")
-
-with open("examples/server/c.y", "r") as f:
- c_yacc = f.read()
-
-completion = client.chat.completions.create(
- model="mistral",
- messages=[
- {
- "role": "user",
- "content": "Write the main function in C, returning 42. Answer with just the code, no explanation.",
- }
- ],
- max_tokens=256,
- frequency_penalty=1.0,
- top_p=0.1,
- temperature=0,
- extra_body={"grammar": {"type": "yacc", "value": c_yacc}},
-)
-
-print(completion.choices[0].message.content)
diff --git a/mistralrs-bench/src/main.rs b/mistralrs-bench/src/main.rs
index 421c399fba..42a7cc6bd4 100644
--- a/mistralrs-bench/src/main.rs
+++ b/mistralrs-bench/src/main.rs
@@ -242,7 +242,7 @@ fn warmup_run(mistralrs: Arc) {
messages: RequestMessage::Completion {
text: "Hello!".to_string(),
echo_prompt: false,
- best_of: 1,
+ best_of: None,
},
sampling_params: sampling_params.clone(),
response: tx,
@@ -534,7 +534,7 @@ fn main() -> anyhow::Result<()> {
RequestMessage::Completion {
text: "Rust".to_string(),
echo_prompt: false,
- best_of: 1,
+ best_of: None,
},
args.n_gen - 1,
*concurrency,
diff --git a/mistralrs-core/Cargo.toml b/mistralrs-core/Cargo.toml
index 6fbd49c9f7..7d3310b18f 100644
--- a/mistralrs-core/Cargo.toml
+++ b/mistralrs-core/Cargo.toml
@@ -17,11 +17,11 @@ candle-core.workspace = true
candle-nn.workspace = true
serde.workspace = true
serde_json.workspace = true
-candle-flash-attn = { git = "https://github.com/EricLBuehler/candle.git", version = "0.8.0", rev = "8742354", optional = true }
+candle-flash-attn = { git = "https://github.com/EricLBuehler/candle.git", version = "0.8.0", rev = "6800496", optional = true }
dirs = "5.0.1"
hf-hub = { version = "0.3.3", package = "candle-hf-hub" }
thiserror = "1.0.57"
-tokenizers = "0.20.3"
+tokenizers = "0.21.0"
tqdm = "0.7.0"
chrono = "0.4.34"
minijinja = { version = "2.0.2", features = ["builtins", "json"] }
@@ -79,6 +79,9 @@ safetensors = "0.4.5"
serde_plain = "1.0.2"
as-any = "0.3.1"
float8.workspace = true
+llguidance = { git = "https://github.com/microsoft/llguidance", rev = "cfef3df97372a7b84d74976ff41cc9cb78bca6cc", default-features = false, features = ["lark"] }
+toktrie_hf_tokenizers = { git = "https://github.com/microsoft/llguidance", rev = "cfef3df97372a7b84d74976ff41cc9cb78bca6cc" }
+
[features]
pyo3_macros = ["pyo3"]
diff --git a/mistralrs-core/src/aici/README.md b/mistralrs-core/src/aici/README.md
deleted file mode 100644
index b08d6293a3..0000000000
--- a/mistralrs-core/src/aici/README.md
+++ /dev/null
@@ -1,2 +0,0 @@
-// Originally from https://github.com/microsoft/aici/blob/64f0b551dee49e320e9b3b92289f3d6f2e888276
-// Licensed under the MIT license
diff --git a/mistralrs-core/src/aici/bintokens.rs b/mistralrs-core/src/aici/bintokens.rs
deleted file mode 100644
index 691290330a..0000000000
--- a/mistralrs-core/src/aici/bintokens.rs
+++ /dev/null
@@ -1,183 +0,0 @@
-use crate::aici::bytes::TokRxInfo;
-use anyhow::{anyhow, bail, Result};
-use serde::{Deserialize, Serialize};
-use std::collections::{BTreeMap, HashMap};
-use tokenizers::{normalizers::Sequence, NormalizerWrapper, Tokenizer};
-use tracing::warn;
-
-use super::toktree::TokTrie;
-
-#[derive(Serialize, Deserialize)]
-pub struct ByteTokenizer {
- pub hf_model: String,
- pub hf_tokenizer: Tokenizer,
- pub eos_token: u32,
- pub vocab_size: u32,
- token_bytes: Vec>,
- pub special: BTreeMap,
-}
-
-// useful when debugging this: https://www.cogsci.ed.ac.uk/~richard/utf-8.cgi
-
-const fn is_self_mapped(c: char) -> bool {
- matches!(c, '!'..='~' | '\u{00A1}'..='\u{00AC}' | '\u{00AE}'..='\u{00FF}')
-}
-
-fn build_char_map() -> HashMap {
- let mut res = HashMap::default();
- let mut k = 0x100u32;
- for byte in 0..=255u8 {
- let c = byte as char;
- if is_self_mapped(c) {
- res.insert(c, byte);
- } else {
- res.insert(char::from_u32(k).unwrap(), byte);
- k += 1;
- }
- }
- res
-}
-
-impl ByteTokenizer {
- pub fn from_tokenizer(mut hft: Tokenizer) -> Result {
- let mut is_byte_level = false;
- let mut is_byte_fallback = false;
- let mut space_ch = ' ';
-
- // remove the "Prepend space"
- if let Some(n) = hft.get_normalizer() {
- let n = match n {
- NormalizerWrapper::Sequence(x) => NormalizerWrapper::Sequence(Sequence::new(
- x.get_normalizers()
- .iter()
- .filter_map(|n| match n {
- NormalizerWrapper::Prepend(_) => None,
- _ => Some(n.clone()),
- })
- .collect(),
- )),
- _ => n.clone(),
- };
- hft.with_normalizer(Some(n));
- }
-
- if let Some(d) = hft.get_decoder() {
- // DecoderWrapper::Sequence() doesn't let one access the decoders
- // so we resort to json munching
- let v = serde_json::to_value(d).unwrap();
- if v["type"].as_str() == Some("ByteLevel") {
- is_byte_level = true;
- } else if v["type"].as_str() == Some("Sequence") {
- if let Some(decoders) = v["decoders"].as_array() {
- for decoder in decoders {
- if decoder["type"].as_str() == Some("ByteFallback") {
- is_byte_fallback = true;
- } else if decoder["type"].as_str() == Some("Replace")
- && decoder["content"].as_str() == Some(" ")
- {
- if let Some(s) = decoder["pattern"]["String"].as_str() {
- let s: Vec = s.chars().collect();
- if s.len() == 1 {
- space_ch = s[0];
- }
- }
- }
- }
- }
- }
- }
-
- if !is_byte_fallback && !is_byte_level {
- bail!("can't determine decoder type: {:?}", hft.get_decoder());
- }
-
- let vocab_size = hft.get_vocab_size(true) as u32;
- let added = hft.get_added_tokens_decoder();
-
- let mut res = ByteTokenizer {
- hf_model: "foobar".to_string(),
- eos_token: 0,
- vocab_size,
- special: BTreeMap::new(),
- token_bytes: (0..vocab_size).map(|_| Vec::new()).collect(),
- hf_tokenizer: hft,
- };
-
- for (id, info) in added.iter() {
- if info.special {
- match info.content.as_str() {
- "" | "<|endoftext|>" => res.eos_token = *id,
- _ => {}
- }
- res.special.insert(info.content.clone(), *id);
- } else {
- res.token_bytes[*id as usize] = info.content.clone().into_bytes();
- }
- }
-
- let char_map = build_char_map();
-
- for tok_id in 0..vocab_size {
- if added.contains_key(&tok_id) {
- continue;
- }
- if let Some(tok_name) = res.hf_tokenizer.id_to_token(tok_id) {
- if is_byte_fallback {
- if tok_name.len() == 6 && tok_name.starts_with("<0x") && tok_name.ends_with('>')
- {
- // parse hex number from tok_name
- let hex_str = &tok_name[3..5];
- let byte = u8::from_str_radix(hex_str, 16).unwrap();
- res.token_bytes[tok_id as usize] = vec![byte];
- } else {
- assert!(!tok_name.starts_with("<0x"));
- let tok_name = tok_name.replace(space_ch, " ");
- res.token_bytes[tok_id as usize] = tok_name.as_bytes().to_vec();
- }
- } else if is_byte_level {
- let bytes: Result> = tok_name
- .chars()
- .map(|c| {
- char_map
- .get(&c)
- .copied()
- .ok_or_else(|| anyhow!("missing char: {}", c))
- })
- .collect();
- let bytes = match bytes {
- Ok(b) => b,
- Err(e) => {
- println!("error: {} for {:?}", e, tok_name);
- continue;
- }
- };
-
- res.token_bytes[tok_id as usize] = bytes;
- } else {
- panic!();
- }
- } else {
- warn!("missing token: {}", tok_id);
- }
- }
-
- Ok(res)
- }
-}
-
-impl ByteTokenizer {
- pub fn tokrx_info(&self) -> TokRxInfo {
- TokRxInfo {
- vocab_size: self.vocab_size,
- tok_eos: self.eos_token,
- }
- }
- pub fn token_bytes(&self) -> Vec> {
- self.token_bytes.clone()
- }
-}
-
-pub(crate) fn build_tok_trie(tokenizer: Tokenizer) -> TokTrie {
- let bt = ByteTokenizer::from_tokenizer(tokenizer).unwrap();
- TokTrie::from(&bt.tokrx_info(), &bt.token_bytes())
-}
diff --git a/mistralrs-core/src/aici/bytes.rs b/mistralrs-core/src/aici/bytes.rs
deleted file mode 100644
index 397edf5cbc..0000000000
--- a/mistralrs-core/src/aici/bytes.rs
+++ /dev/null
@@ -1,35 +0,0 @@
-use std::mem::size_of;
-
-use bytemuck_derive::{Pod, Zeroable};
-
-pub(crate) type TokenId = u32;
-
-#[derive(Clone, Copy, PartialEq, Eq, Debug, Zeroable, Pod)]
-#[repr(C)]
-pub struct TokRxInfo {
- pub vocab_size: u32,
- pub tok_eos: TokenId,
-}
-
-#[derive(Clone, Copy, PartialEq, Eq, Debug, Zeroable, Pod)]
-#[repr(C)]
-pub struct U32Pair(pub u32, pub u32);
-
-pub fn vec_from_bytes(bytes: &[u8]) -> Vec {
- if bytes.len() % size_of::() != 0 {
- panic!(
- "vecT: got {} bytes, needed multiple of {}",
- bytes.len(),
- size_of::()
- );
- }
- bytemuck::cast_slice(bytes).to_vec()
-}
-
-pub fn to_hex_string(bytes: &[u8]) -> String {
- bytes
- .iter()
- .map(|b| format!("{:02x}", b))
- .collect::>()
- .join("")
-}
diff --git a/mistralrs-core/src/aici/cfg.rs b/mistralrs-core/src/aici/cfg.rs
deleted file mode 100644
index 41e457bd8d..0000000000
--- a/mistralrs-core/src/aici/cfg.rs
+++ /dev/null
@@ -1,495 +0,0 @@
-use crate::aici::lex::{Lexer, LexerState, StateID, VobIdx, VobSet};
-use crate::aici::toktree::{Recognizer, SpecialToken};
-use anyhow::Result;
-use cfgrammar::{
- yacc::{YaccGrammar, YaccKind},
- Span, Spanned, Symbol, TIdx,
-};
-use lrtable::{from_yacc, Action, Minimiser, StIdx, StateTable};
-use rustc_hash::FxHashMap;
-use std::sync::RwLock;
-use std::vec;
-use vob::{vob, Vob};
-
-type StorageT = u32;
-type PStack = Vec>; // Parse stack
-
-const LOG_PARSER: bool = false;
-
-#[derive(Debug, Clone, Copy)]
-enum ParseResult {
- Accept,
- Error,
- Continue,
-}
-
-struct CfgStats {
- yacc_actions: usize,
- states_pushed: usize,
-}
-
-pub struct CfgParser {
- grm: YaccGrammar,
- stable: StateTable,
- lexer: Lexer,
- byte_states: Vec,
- pat_idx_to_tidx: Vec>,
- vobset: VobSet,
- stats: RwLock,
- tidx_to_pat_idx: FxHashMap, usize>,
- parse_stacks: Vec>>,
- skip_patterns: Vob,
- friendly_pattern_names: Vec,
- viable_vobidx_by_state: Vec,
-}
-
-fn is_rx(name: &str) -> bool {
- name.len() > 2 && name.starts_with('/') && name.ends_with('/')
-}
-
-fn quote_rx(name: &str) -> String {
- name.chars()
- .map(|ch| {
- if ch.is_ascii_digit()
- || ch.is_ascii_lowercase()
- || ch.is_ascii_uppercase()
- || '<' == ch
- || '>' == ch
- {
- ch.to_string()
- } else {
- format!("\\{}", ch)
- }
- })
- .collect::()
-}
-
-pub(crate) fn parse_rx_token(name: &str) -> String {
- if is_rx(name) {
- name[1..name.len() - 1].to_string()
- } else {
- quote_rx(name)
- }
-}
-
-fn span_to_str(s: &Span, src: &str) -> String {
- let mut line = 1;
- let mut last_nl = 0;
- for (idx, ch) in src.chars().enumerate() {
- if idx == s.start() {
- break;
- }
- if ch == '\n' {
- line += 1;
- last_nl = idx;
- }
- }
- let column = s.start() - last_nl;
- format!("({},{})", line, column)
-}
-
-pub(crate) fn parse_yacc(yacc: &str) -> Result {
- let grmkind = YaccKind::Original(cfgrammar::yacc::YaccOriginalActionKind::NoAction);
- let grm = match YaccGrammar::new(grmkind, yacc) {
- Ok(grm) => grm,
- Err(e) => {
- let err_str = e
- .iter()
- .map(|e| {
- let spans = e
- .spans()
- .iter()
- .map(|s| span_to_str(s, yacc))
- .collect::>()
- .join(", ");
- format!("{}: {}", spans, e)
- })
- .collect::>()
- .join("\n");
- anyhow::bail!("yacc grammar errors:\n{}", err_str);
- }
- };
- Ok(grm)
-}
-
-impl CfgParser {
- pub fn from_yacc(yacc: &str) -> Result {
- let grm = parse_yacc(yacc)?;
- // TIME: all these annotation are for native release x86 build for C grammar
- // TIME: 27ms
- let (sgraph, stable) = match from_yacc(&grm, Minimiser::Pager) {
- Ok(r) => r,
- Err(e) => {
- if false {
- // not sure this works:
- anyhow::bail!("state table error:\n{e} on {:?}", grm.action(e.pidx));
- }
- anyhow::bail!("state table error:\n{e}");
- }
- };
-
- if false {
- println!("core\n{}\n\n", sgraph.pp(&grm, true));
- for pidx in grm.iter_pidxs() {
- let prod = grm.prod(pidx);
- println!("{:?} -> {}", prod, prod.len());
- }
- }
-
- let mut pat_idx_to_tidx = grm
- .iter_tidxs()
- .filter(|tidx| grm.token_name(*tidx).is_some())
- .collect::>();
-
- pat_idx_to_tidx.sort_by_key(|tidx| {
- let name = grm.token_name(*tidx).unwrap();
- let l = name.len() as isize;
- if is_rx(name) {
- -l + 100000
- } else {
- -l
- }
- });
-
- let patterns = pat_idx_to_tidx
- .iter()
- .map(|tok| parse_rx_token(grm.token_name(*tok).unwrap()))
- .collect::>();
-
- let mut tidx_to_pat_idx = FxHashMap::default();
- for (idx, _tok) in patterns.iter().enumerate() {
- tidx_to_pat_idx.insert(pat_idx_to_tidx[idx], idx);
- }
-
- let mut skip_patterns = vob![false; patterns.len()];
- let friendly_pattern_names = pat_idx_to_tidx
- .iter()
- .map(|tok| grm.token_name(*tok).unwrap().to_string())
- .collect::>();
-
- for ridx in grm.iter_rules() {
- let rule_name = grm.rule_name_str(ridx);
- if rule_name.to_uppercase() != rule_name {
- continue;
- }
- for pidx in grm.rule_to_prods(ridx) {
- let toks = grm.prod(*pidx);
- if let [Symbol::Token(tidx)] = toks {
- let idx = *tidx_to_pat_idx.get(tidx).unwrap();
- // this doesn't seem very useful
- // friendly_pattern_names[idx] = rule_name.to_string();
- if rule_name == "SKIP" {
- skip_patterns.set(idx, true);
- }
- }
- }
- }
-
- println!("patterns: {:?}", friendly_pattern_names);
-
- let mut vobset = VobSet::new();
- // all-zero has to be inserted first
- let _all0 = vobset.insert_or_get(&vob![false; patterns.len()]);
- let all1 = vobset.insert_or_get(&vob![true; patterns.len()]);
-
- // TIME: 27ms
- let dfa = Lexer::from(patterns, &mut vobset);
-
- let cfg_start = stable.start_state();
- let parse_stacks = vec![vec![cfg_start]];
-
- let byte_state = ByteState {
- lexer_state: dfa.file_start_state(),
- parse_stack_idx: PStackIdx(0),
- viable: all1,
- };
-
- let viable_vobidx_by_state = sgraph
- .iter_stidxs()
- .enumerate()
- .map(|(idx, stidx)| {
- assert!(idx == stidx.as_storaget() as usize);
-
- // skip patterns (whitespace) are always viable
- let mut r = skip_patterns.clone();
- for tidx in stable.state_actions(stidx) {
- match stable.action(stidx, tidx) {
- Action::Error => {}
- _ => {
- if let Some(pat_idx) = tidx_to_pat_idx.get(&tidx) {
- r.set(*pat_idx, true);
- }
- }
- }
- }
-
- vobset.insert_or_get(&r)
- })
- .collect::>();
-
- let mut cfg = CfgParser {
- grm,
- stable,
- lexer: dfa,
- byte_states: vec![byte_state],
- pat_idx_to_tidx,
- tidx_to_pat_idx,
- viable_vobidx_by_state,
- skip_patterns,
- friendly_pattern_names,
- parse_stacks,
- vobset,
- stats: RwLock::new(CfgStats {
- yacc_actions: 0,
- states_pushed: 0,
- }),
- };
-
- cfg.vobset.pre_compute();
-
- // compute viable set of initial tokens
- cfg.byte_states[0].viable = cfg.viable_vobidx(cfg_start);
- if LOG_PARSER {
- println!(
- "initial viable: {:?}",
- cfg.vobset.resolve(cfg.byte_states[0].viable)
- );
- }
-
- Ok(cfg)
- }
-
- fn viable_vobidx(&self, stidx: StIdx) -> VobIdx {
- self.viable_vobidx_by_state[stidx.as_storaget() as usize]
- }
-
- #[allow(dead_code)]
- fn friendly_token_name(&self, lexeme: TIdx) -> &str {
- if let Some(pidx) = self.tidx_to_pat_idx.get(&lexeme) {
- &self.friendly_pattern_names[*pidx]
- } else if self.grm.eof_token_idx() == lexeme {
- return "";
- } else {
- return "??>";
- }
- }
-
- fn parse_lexeme(&self, lexeme: TIdx, pstack: &mut PStack) -> ParseResult {
- loop {
- let stidx = *pstack.last().unwrap();
-
- let act = self.stable.action(stidx, lexeme);
-
- if LOG_PARSER {
- println!(
- "parse: {:?} {:?} -> {:?}",
- pstack,
- self.friendly_token_name(lexeme),
- act
- );
- }
-
- match act {
- Action::Reduce(pidx) => {
- let ridx = self.grm.prod_to_rule(pidx);
- let pop_idx = pstack.len() - self.grm.prod(pidx).len();
- pstack.drain(pop_idx..);
- let prior = *pstack.last().unwrap();
- pstack.push(self.stable.goto(prior, ridx).unwrap());
- }
- Action::Shift(state_id) => {
- pstack.push(state_id);
- return ParseResult::Continue;
- }
- Action::Accept => {
- // only happens when lexeme is EOF
- return ParseResult::Accept;
- }
- Action::Error => {
- return ParseResult::Error;
- }
- }
- }
- }
-
- #[allow(dead_code)]
- fn print_viable(&self, lbl: &str, vob: &Vob) {
- println!("viable tokens {}:", lbl);
- for (idx, b) in vob.iter().enumerate() {
- if b {
- println!(" {}: {}", idx, self.friendly_pattern_names[idx]);
- }
- }
- }
-
- // None means EOF
- #[inline(always)]
- fn try_push(&mut self, byte: Option) -> Option {
- let top = self.byte_states.last().unwrap().clone();
- if LOG_PARSER {
- print!("try_push[{}]: ", self.byte_states.len());
- if let Some(b) = byte {
- print!("{:?}", b as char)
- } else {
- print!("")
- }
- }
- let (info, res) = match self.lexer.advance(top.lexer_state, byte) {
- // Error?
- None => ("lex-err", None),
- // Just new state, no token - the hot path
- Some((ls, None)) => (
- "lex",
- self.mk_byte_state(ls, top.parse_stack_idx, top.viable),
- ),
- // New state and token generated
- Some((ls, Some(pat_idx))) => ("parse", self.run_parser(pat_idx, &top, ls)),
- };
- if LOG_PARSER {
- println!(
- " -> {} {}",
- info,
- if res.is_none() { "error" } else { "ok" }
- );
- }
- res
- }
-
- fn pstack_for(&self, top: &ByteState) -> &PStack {
- &self.parse_stacks[top.parse_stack_idx.0]
- }
-
- fn push_pstack(&mut self, top: &ByteState, pstack: Vec>) -> PStackIdx {
- let new_idx = PStackIdx(top.parse_stack_idx.0 + 1);
- if self.parse_stacks.len() <= new_idx.0 {
- self.parse_stacks.push(Vec::new());
- }
- self.parse_stacks[new_idx.0] = pstack;
- new_idx
- }
-
- fn run_parser(&mut self, pat_idx: usize, top: &ByteState, ls: LexerState) -> Option {
- {
- let mut s = self.stats.write().unwrap();
- s.yacc_actions += 1;
- }
- if LOG_PARSER {
- println!();
- }
- let pstack = self.pstack_for(top);
- if self.skip_patterns[pat_idx] {
- let stidx = *pstack.last().unwrap();
- let viable = self.viable_vobidx(stidx);
- //self.print_viable("reset", &viable);
- if LOG_PARSER {
- println!("parse: {:?} skip", pstack);
- }
- // reset viable states - they have been narrowed down to SKIP
- self.mk_byte_state(ls, top.parse_stack_idx, viable)
- } else {
- let tidx = self.pat_idx_to_tidx[pat_idx];
- let mut pstack = pstack.clone();
- match self.parse_lexeme(tidx, &mut pstack) {
- ParseResult::Accept => panic!("accept non EOF?"),
- ParseResult::Continue => {
- let stidx = *pstack.last().unwrap();
- let viable = self.viable_vobidx(stidx);
- let new_idx = self.push_pstack(top, pstack);
- self.mk_byte_state(ls, new_idx, viable)
- }
- ParseResult::Error => None,
- }
- }
- }
-
- #[allow(dead_code)]
- pub fn viable_now(&self) {
- let v = self.byte_states.last().unwrap().viable;
- self.print_viable("now", self.vobset.resolve(v))
- }
-
- pub fn get_stats(&self) -> String {
- let mut s = self.stats.write().unwrap();
- let r = format!("yacc: {}/{}", s.yacc_actions, s.states_pushed);
- s.yacc_actions = 0;
- s.states_pushed = 0;
- r
- }
-
- fn mk_byte_state(
- &self,
- ls: LexerState,
- pstack: PStackIdx,
- viable: VobIdx,
- ) -> Option {
- {
- let mut s = self.stats.write().unwrap();
- s.states_pushed += 1;
- }
- if self.vobset.and_is_zero(viable, ls.reachable) {
- None
- } else {
- // print!(
- // " {:?} {:?} ",
- // self.vobset.resolve(viable),
- // self.vobset.resolve(ls.reachable)
- // );
- Some(ByteState {
- lexer_state: ls.state,
- parse_stack_idx: pstack,
- viable,
- })
- }
- }
-}
-
-#[derive(Clone, Copy)]
-struct PStackIdx(usize);
-
-#[derive(Clone)]
-struct ByteState {
- lexer_state: StateID,
- parse_stack_idx: PStackIdx,
- viable: VobIdx,
-}
-
-impl Recognizer for CfgParser {
- fn pop_bytes(&mut self, num: usize) {
- self.byte_states.truncate(self.byte_states.len() - num);
- }
-
- fn collapse(&mut self) {
- let final_state = self.byte_states.pop().unwrap();
- self.byte_states.clear();
- self.byte_states.push(final_state);
- }
-
- fn special_allowed(&mut self, tok: SpecialToken) -> bool {
- match tok {
- SpecialToken::EndOfSentence => {
- if let Some(st) = self.try_push(None) {
- let tidx = self.grm.eof_token_idx();
- let mut pstack = self.pstack_for(&st).clone();
- matches!(self.parse_lexeme(tidx, &mut pstack), ParseResult::Accept)
- } else {
- false
- }
- }
- _ => false,
- }
- }
-
- fn trie_finished(&mut self) {
- assert!(self.byte_states.len() == 1);
- }
-
- #[inline(always)]
- fn try_push_byte(&mut self, byte: u8) -> bool {
- if let Some(st) = self.try_push(Some(byte)) {
- self.byte_states.push(st);
- true
- } else {
- false
- }
- }
-}
diff --git a/mistralrs-core/src/aici/lex.rs b/mistralrs-core/src/aici/lex.rs
deleted file mode 100644
index 9670704c89..0000000000
--- a/mistralrs-core/src/aici/lex.rs
+++ /dev/null
@@ -1,348 +0,0 @@
-use regex_automata::{
- dfa::{dense, Automaton},
- util::syntax,
-};
-use rustc_hash::FxHashMap;
-use std::{hash::Hash, vec};
-use vob::{vob, Vob};
-
-pub type PatIdx = usize;
-pub type StateID = regex_automata::util::primitives::StateID;
-
-const LOG_LEXER: bool = false;
-
-// enabling this is slightly faster, but it requires ~ |lexer_states|*|parser_states| bits
-const PRECOMPUTE_AND: bool = false;
-
-#[derive(Debug, Clone, Hash, PartialEq, Eq, Copy)]
-pub struct LexerState {
- pub state: StateID,
- pub reachable: VobIdx,
-}
-
-impl LexerState {
- fn fake() -> Self {
- LexerState {
- state: StateID::default(),
- reachable: VobIdx::all_zero(),
- }
- }
-}
-
-#[derive(Debug, Clone, Hash, PartialEq, Eq, Copy)]
-pub struct VobIdx {
- v: u32,
-}
-
-impl VobIdx {
- pub fn new(v: usize) -> Self {
- VobIdx { v: v as u32 }
- }
-
- pub fn all_zero() -> Self {
- VobIdx { v: 0 }
- }
-
- pub fn as_usize(&self) -> usize {
- self.v as usize
- }
-
- pub fn is_zero(&self) -> bool {
- self.v == 0
- }
-}
-
-pub struct VobSet {
- vobs: Vec,
- by_vob: FxHashMap,
- non_empty: Vob,
-}
-
-impl VobSet {
- pub fn new() -> Self {
- VobSet {
- vobs: Vec::new(),
- by_vob: FxHashMap::default(),
- non_empty: Vob::new(),
- }
- }
-
- pub fn insert_or_get(&mut self, vob: &Vob) -> VobIdx {
- if let Some(idx) = self.by_vob.get(vob) {
- return *idx;
- }
- let len = self.vobs.len();
- if len == 0 && !vob_is_zero(vob) {
- panic!("first vob must be empty");
- }
- let idx = VobIdx::new(len);
- self.vobs.push(vob.clone());
- self.by_vob.insert(vob.clone(), idx);
- idx
- }
-
- pub fn resolve(&self, idx: VobIdx) -> &Vob {
- &self.vobs[idx.as_usize()]
- }
-
- pub fn and_is_zero(&self, a: VobIdx, b: VobIdx) -> bool {
- if PRECOMPUTE_AND {
- !self.non_empty[a.as_usize() * self.vobs.len() + b.as_usize()]
- } else {
- vob_and_is_zero(&self.vobs[a.as_usize()], &self.vobs[b.as_usize()])
- }
- }
-
- pub fn pre_compute(&mut self) {
- if PRECOMPUTE_AND {
- let l = self.vobs.len();
- self.non_empty.resize(l * l, false);
- for x in 0..self.vobs.len() {
- for y in 0..=x {
- if !vob_and_is_zero(&self.vobs[x], &self.vobs[y]) {
- self.non_empty.set(x * l + y, true);
- self.non_empty.set(y * l + x, true);
- }
- }
- }
- println!(
- "vob set: {} VOBs, {} nonempty",
- self.vobs.len(),
- self.non_empty.len()
- );
- }
- }
-}
-
-pub struct Lexer {
- dfa: dense::DFA>,
- initial: LexerState,
- vobidx_by_state_off: Vec,
-}
-
-impl Lexer {
- pub fn from(patterns: Vec, vobset: &mut VobSet) -> Self {
- // TIME: 4ms
- let dfa = dense::Builder::new()
- .configure(
- dense::Config::new()
- .start_kind(regex_automata::dfa::StartKind::Anchored)
- .match_kind(regex_automata::MatchKind::All),
- )
- .syntax(syntax::Config::new().unicode(false).utf8(false))
- .build_many(&patterns)
- .unwrap();
-
- println!(
- "dfa: {} bytes, {} patterns",
- dfa.memory_usage(),
- patterns.len(),
- );
- if false {
- for p in &patterns {
- println!(" {}", p)
- }
- }
-
- let anch = regex_automata::Anchored::Yes;
-
- let mut incoming = FxHashMap::default();
- let initial = dfa.universal_start_state(anch).unwrap();
- let mut todo = vec![initial];
- incoming.insert(initial, Vec::new());
-
- // TIME: 1.5ms
- while let Some(s) = todo.pop() {
- for b in 0..=255 {
- let s2 = dfa.next_state(s, b);
- incoming.entry(s2).or_insert_with(|| {
- todo.push(s2);
- Vec::new()
- });
- incoming.get_mut(&s2).unwrap().push(s);
- }
- }
-
- let states = incoming.keys().copied().collect::>();
- let mut reachable_patterns = FxHashMap::default();
-
- for s in &states {
- let mut v = vob![false; patterns.len()];
- let s2 = dfa.next_eoi_state(*s);
- if dfa.is_match_state(s2) {
- for idx in 0..dfa.match_len(s2) {
- let idx = dfa.match_pattern(s2, idx).as_usize();
- v.set(idx, true);
- if LOG_LEXER {
- println!(" match: {:?} {}", *s, patterns[idx])
- }
- }
- }
- reachable_patterns.insert(*s, v);
- }
-
- // TIME: 20ms
- loop {
- let mut num_set = 0;
-
- for s in &states {
- let ours = reachable_patterns.get(s).unwrap().clone();
- for o in &incoming[s] {
- let theirs = reachable_patterns.get(o).unwrap();
- let mut tmp = ours.clone();
- tmp |= theirs;
- if tmp != *theirs {
- num_set += 1;
- reachable_patterns.insert(*o, tmp);
- }
- }
- }
-
- if LOG_LEXER {
- println!("iter {} {}", num_set, states.len());
- }
- if num_set == 0 {
- break;
- }
- }
-
- let mut states_idx = states.iter().map(|x| x.as_usize()).collect::>();
- states_idx.sort();
-
- let shift = dfa.stride2();
- let mut vobidx_by_state_off =
- vec![VobIdx::all_zero(); 1 + (states_idx.iter().max().unwrap() >> shift)];
- for (k, v) in reachable_patterns.iter() {
- vobidx_by_state_off[k.as_usize() >> shift] = vobset.insert_or_get(v);
- }
-
- println!("initial: {:?}; {} states", initial, states.len());
-
- let mut lex = Lexer {
- dfa,
- vobidx_by_state_off,
- initial: LexerState::fake(),
- };
-
- lex.initial = lex.mk_state(initial);
-
- if LOG_LEXER {
- for s in &states {
- if lex.is_dead(*s) {
- println!("dead: {:?} {}", s, lex.dfa.is_dead_state(*s));
- }
- }
-
- println!("reachable: {:#?}", reachable_patterns);
- }
-
- lex
- }
-
- pub fn file_start_state(&self) -> StateID {
- self.initial.state
- // pretend we've just seen a newline at the beginning of the file
- // TODO: this should be configurable
- // self.dfa.next_state(self.initial.state, b'\n')
- }
-
- fn mk_state(&self, state: StateID) -> LexerState {
- LexerState {
- state,
- reachable: self.reachable_tokens(state),
- }
- }
-
- fn is_dead(&self, state: StateID) -> bool {
- self.reachable_tokens(state).is_zero()
- }
-
- fn reachable_tokens(&self, state: StateID) -> VobIdx {
- self.vobidx_by_state_off[state.as_usize() >> self.dfa.stride2()]
- }
-
- fn get_token(&self, prev: StateID) -> Option {
- let state = self.dfa.next_eoi_state(prev);
- if !self.dfa.is_match_state(state) {
- return None;
- }
-
- // we take the first token that matched
- // (eg., "while" will match both keyword and identifier, but keyword is first)
- let pat_idx = (0..self.dfa.match_len(state))
- .map(|idx| self.dfa.match_pattern(state, idx).as_usize())
- .min()
- .unwrap();
-
- if LOG_LEXER {
- println!("token: {}", pat_idx);
- }
-
- Some(pat_idx)
- }
-
- #[inline(always)]
- pub fn advance(&self, prev: StateID, byte: Option) -> Option<(LexerState, Option)> {
- let dfa = &self.dfa;
- if let Some(byte) = byte {
- let state = dfa.next_state(prev, byte);
- if LOG_LEXER {
- println!(
- "lex: {:?} -{:?}-> {:?} d={}",
- prev,
- byte as char,
- state,
- self.is_dead(state),
- );
- }
- let v = self.reachable_tokens(state);
- if v.is_zero() {
- // if final_state is a match state, find the token that matched
- let tok = self.get_token(prev);
- if tok.is_none() {
- None
- } else {
- let state = dfa.next_state(self.initial.state, byte);
- if LOG_LEXER {
- println!("lex0: {:?} -{:?}-> {:?}", self.initial, byte as char, state);
- }
- Some((self.mk_state(state), tok))
- }
- } else {
- Some((
- LexerState {
- state,
- reachable: v,
- },
- None,
- ))
- }
- } else {
- let tok = self.get_token(prev);
- if tok.is_none() {
- None
- } else {
- Some((self.initial, tok))
- }
- }
- }
-}
-
-fn vob_and_is_zero(a: &Vob, b: &Vob) -> bool {
- debug_assert!(a.len() == b.len());
- for (a, b) in a.iter_storage().zip(b.iter_storage()) {
- if a & b != 0 {
- return false;
- }
- }
- true
-}
-
-fn vob_is_zero(v: &Vob) -> bool {
- for b in v.iter_storage() {
- if b != 0 {
- return false;
- }
- }
- true
-}
diff --git a/mistralrs-core/src/aici/mod.rs b/mistralrs-core/src/aici/mod.rs
deleted file mode 100644
index f191b9369d..0000000000
--- a/mistralrs-core/src/aici/mod.rs
+++ /dev/null
@@ -1,10 +0,0 @@
-#![allow(clippy::cast_possible_truncation, clippy::cast_precision_loss)]
-
-pub(crate) mod bintokens;
-pub(crate) mod bytes;
-pub(crate) mod cfg;
-pub(crate) mod lex;
-pub(crate) mod recognizer;
-pub(crate) mod rx;
-pub(crate) mod svob;
-pub(crate) mod toktree;
diff --git a/mistralrs-core/src/aici/recognizer.rs b/mistralrs-core/src/aici/recognizer.rs
deleted file mode 100644
index 8d9b4bc7d3..0000000000
--- a/mistralrs-core/src/aici/recognizer.rs
+++ /dev/null
@@ -1,98 +0,0 @@
-use crate::aici::toktree::{Recognizer, SpecialToken};
-use std::fmt::Debug;
-
-pub trait FunctionalRecognizer {
- /// Initial state
- fn initial(&self) -> S;
- /// Extend the recognizer with given byte if allowed.
- fn try_append(&self, state: S, byte: u8) -> Option;
- /// Check if given special token is allowed in given state.
- fn special_allowed(&self, state: S, tok: SpecialToken) -> bool;
-}
-
-#[derive(Clone)]
-pub struct StackRecognizer> {
- rec: R,
- stack: Vec,
- stack_ptr: usize,
-}
-
-impl> StackRecognizer {
- pub fn from(rec: R) -> Self {
- let stack = vec![rec.initial(); 300];
- StackRecognizer {
- rec,
- stack,
- stack_ptr: 0,
- }
- }
-
- pub fn reset(&mut self) {
- self.stack_ptr = 0;
- self.stack[0] = self.rec.initial();
- }
-
- pub fn recognizer(&self) -> &R {
- &self.rec
- }
-
- pub fn recognizer_mut(&mut self) -> &mut R {
- &mut self.rec
- }
-}
-
-impl> Debug for StackRecognizer {
- fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
- f.debug_struct("StackRecognizer")
- .field("top", &self.stack[self.stack_ptr])
- .finish()
- }
-}
-
-impl> Recognizer for StackRecognizer {
- #[inline(always)]
- fn pop_bytes(&mut self, num: usize) {
- self.stack_ptr -= num;
- }
-
- fn trie_finished(&mut self) {
- // println!("{:?}", &self.stack[0..=self.stack_ptr]);
- assert!(self.stack_ptr == 0);
- }
-
- fn collapse(&mut self) {
- self.stack[0] = self.stack[self.stack_ptr];
- self.stack_ptr = 0;
- }
-
- fn special_allowed(&mut self, tok: SpecialToken) -> bool {
- self.rec.special_allowed(self.stack[self.stack_ptr], tok)
- }
-
- #[inline(always)]
- fn try_push_byte(&mut self, byte: u8) -> bool {
- match self.rec.try_append(self.stack[self.stack_ptr], byte) {
- Some(state) => {
- self.stack_ptr += 1;
- self.stack[self.stack_ptr] = state;
- true
- }
- None => false,
- }
- }
-}
-
-#[derive(Clone)]
-pub struct AnythingGoes {}
-
-impl FunctionalRecognizer<()> for AnythingGoes {
- fn initial(&self) {}
-
- fn try_append(&self, state: (), _byte: u8) -> Option<()> {
- Some(state)
- }
-
- fn special_allowed(&self, _state: (), _tok: SpecialToken) -> bool {
- true
- }
-}
diff --git a/mistralrs-core/src/aici/rx.rs b/mistralrs-core/src/aici/rx.rs
deleted file mode 100644
index 60c0847d80..0000000000
--- a/mistralrs-core/src/aici/rx.rs
+++ /dev/null
@@ -1,115 +0,0 @@
-use std::error::Error;
-
-use crate::aici::{
- recognizer::{FunctionalRecognizer, StackRecognizer},
- toktree::SpecialToken,
-};
-use anyhow::{bail, Result};
-use regex_automata::{
- dfa::{dense, Automaton},
- util::{primitives::StateID, syntax},
-};
-
-pub type RecRxState = StateID;
-
-#[derive(Clone)]
-pub struct RecRx {
- dfa: dense::DFA>,
- info: String,
-}
-
-pub type RxStackRecognizer = StackRecognizer;
-
-impl RecRx {
- pub fn from_rx(rx: &str, size_limit: Option) -> Result {
- let rx = if rx.ends_with('$') {
- rx.to_string()
- } else {
- rx.to_string() + "$"
- };
- let rx = if let Some(stripped) = rx.strip_prefix('^') {
- stripped.to_string()
- } else {
- rx
- };
- // default to 16MB - it takes about 1s to build
- let size_limit = size_limit.unwrap_or(16 << 20);
- let t0 = std::time::Instant::now();
- let cfg = dense::Config::new()
- .start_kind(regex_automata::dfa::StartKind::Anchored)
- .dfa_size_limit(Some(size_limit))
- .determinize_size_limit(Some(size_limit));
- let dfa = dense::Builder::new()
- .configure(cfg)
- .syntax(syntax::Config::new().unicode(false).utf8(false))
- .build(&rx);
- let dfa = match dfa {
- Ok(dfa) => dfa,
- Err(e) => {
- if let Some(e) = e.source() {
- if let Some(e) = e.source() {
- bail!("error building dfa(2): {}", e)
- } else {
- bail!("error building dfa(1): {}", e)
- }
- } else {
- bail!("error building dfa(0): {}", e)
- }
- }
- };
- let time = t0.elapsed();
- let mb_per_s = dfa.memory_usage() as f64 / time.as_secs_f64() / 1024.0 / 1024.0;
- let info = format!(
- "dfa: {} bytes; time {:?}; {:.3} MB/s",
- dfa.memory_usage(),
- time,
- mb_per_s
- );
-
- if let Err(e) = dfa.start_state(&anchored_start()) {
- bail!("DFA has no start state; {}", e)
- }
-
- Ok(Self { dfa, info })
- }
-
- pub fn info(&self) -> &str {
- &self.info
- }
-
- #[allow(clippy::wrong_self_convention)]
- pub fn to_stack_recognizer(self) -> RxStackRecognizer {
- StackRecognizer::from(self)
- }
-}
-
-fn anchored_start() -> regex_automata::util::start::Config {
- regex_automata::util::start::Config::new().anchored(regex_automata::Anchored::Yes)
-}
-
-impl FunctionalRecognizer for RecRx {
- fn initial(&self) -> RecRxState {
- self.dfa
- .start_state(&anchored_start())
- .expect("dfa has no start state")
- }
-
- #[inline(always)]
- fn try_append(&self, state: RecRxState, byte: u8) -> Option {
- let next = self.dfa.next_state(state, byte);
- if self.dfa.is_dead_state(next) {
- None
- } else {
- Some(next)
- }
- }
-
- #[inline(always)]
- fn special_allowed(&self, state: RecRxState, tok: SpecialToken) -> bool {
- let state = self.dfa.next_eoi_state(state);
- match tok {
- SpecialToken::EndOfSentence => self.dfa.is_match_state(state),
- _ => false,
- }
- }
-}
diff --git a/mistralrs-core/src/aici/svob.rs b/mistralrs-core/src/aici/svob.rs
deleted file mode 100644
index 8a47fb5836..0000000000
--- a/mistralrs-core/src/aici/svob.rs
+++ /dev/null
@@ -1,372 +0,0 @@
-use std::{fmt::Debug, hash::Hash, ops::Index};
-
-pub type TokenId = u32;
-
-#[derive(Clone)]
-pub struct SimpleVob {
- data: Vec,
- size: usize,
-}
-
-impl Hash for SimpleVob {
- fn hash(&self, state: &mut H) {
- self.size.hash(state);
- self.data.hash(state);
- }
-}
-
-impl PartialEq for SimpleVob {
- fn eq(&self, other: &Self) -> bool {
- self.size == other.size && self.data == other.data
- }
-}
-
-impl Eq for SimpleVob {}
-
-impl Debug for SimpleVob {
- fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
- f.debug_struct("SimpleVob")
- .field("len", &self.len())
- .finish()
- }
-}
-
-impl Default for SimpleVob {
- fn default() -> Self {
- Self::new()
- }
-}
-
-#[allow(clippy::from_over_into)]
-impl Into> for SimpleVob {
- fn into(self) -> Vec {
- self.data
- }
-}
-
-const BITS: usize = 32;
-
-impl SimpleVob {
- pub fn new() -> Self {
- Self {
- data: Vec::new(),
- size: 0,
- }
- }
-
- pub fn from_slice(bits: &[bool]) -> Self {
- let mut r = Self::alloc(bits.len());
- for (idx, b) in bits.iter().enumerate() {
- r.set(idx, *b);
- }
- r
- }
-
- pub fn alloc(size: usize) -> Self {
- let mut r = Self::new();
- r.resize(size);
- r
- }
-
- pub fn all_true(size: usize) -> Self {
- let mut r = Self::alloc(size);
- r.set_all(true);
- r
- }
-
- pub fn len(&self) -> usize {
- self.size
- }
-
- pub fn num_set(&self) -> usize {
- self.data.iter().map(|x| x.count_ones() as usize).sum()
- }
-
- fn clear_excessive_bits(&mut self) {
- for i in self.size..(self.data.len() * 32) {
- // disallow tokens that are out of range
- self.disallow_token(i as TokenId);
- }
- }
-
- pub fn to_bin_string(&self) -> String {
- let mut s = String::new();
- for i in 0..self.size {
- s.push(if self.is_allowed(i as TokenId) {
- '1'
- } else {
- '0'
- });
- }
- s
- }
-
- pub fn negated(&self) -> Self {
- let mut r = Self::new();
- r.data = self.data.iter().map(|x| !x).collect();
- r.size = self.size;
- r.clear_excessive_bits();
- r
- }
-
- pub unsafe fn as_ptr(&self) -> *const u32 {
- self.data.as_ptr()
- }
-
- pub fn as_slice(&self) -> &[u32] {
- &self.data
- }
-
- #[inline(always)]
- pub fn iter_set_entries(&self, mut f: impl FnMut(usize)) {
- let src = self.as_slice();
- let numelts = self.size;
- let max_len = numelts / 32;
- for (idx, d) in src.iter().enumerate().take(max_len) {
- // optimize for the two common cases
- if *d == 0 {
- continue;
- } else if *d == u32::MAX {
- for bit in 0..32 {
- f(idx * 32 + bit);
- }
- } else {
- for bit in 0..32 {
- if d & (1 << bit) != 0 {
- f(idx * 32 + bit);
- }
- }
- }
- }
- // final few elts
- for idx in (max_len * 32)..numelts {
- if self.is_allowed(idx as TokenId) {
- f(idx);
- }
- }
- }
-
- #[inline(always)]
- pub fn iter_unset_entries(&self, mut f: impl FnMut(usize)) {
- let src = self.as_slice();
- let numelts = self.size;
- let max_len = numelts / 32;
- for (idx, d) in src.iter().enumerate().take(max_len) {
- // optimize for the two common cases
- if *d == 0 {
- for bit in 0..32 {
- f(idx * 32 + bit);
- }
- } else if *d == u32::MAX {
- continue;
- } else {
- for bit in 0..32 {
- if d & (1 << bit) == 0 {
- f(idx * 32 + bit);
- }
- }
- }
- }
- // final few elts
- for idx in (max_len * 32)..numelts {
- if !self.is_allowed(idx as TokenId) {
- f(idx);
- }
- }
- }
-
- #[inline(always)]
- pub fn iter_entries(&self, mut f: impl FnMut(bool, usize)) {
- let src = self.as_slice();
- let numelts = self.size;
- let max_len = numelts / 32;
- for (idx, d) in src.iter().enumerate().take(max_len) {
- // optimize for the two common cases
- if *d == 0 {
- for bit in 0..32 {
- f(false, idx * 32 + bit);
- }
- } else if *d == u32::MAX {
- for bit in 0..32 {
- f(true, idx * 32 + bit);
- }
- } else {
- for bit in 0..32 {
- f(d & (1 << bit) != 0, idx * 32 + bit);
- }
- }
- }
- // final few elts
- for idx in (max_len * 32)..numelts {
- f(self.is_allowed(idx as TokenId), idx);
- }
- }
-
- pub fn write_to(&self, buf: &mut [u8]) {
- assert!(buf.len() == self.data.len() * 4);
- bytemuck::cast_slice_mut(buf).copy_from_slice(&self.data);
- }
-
- #[inline(always)]
- pub fn allow_token(&mut self, tok: TokenId) {
- self.set(tok as usize, true)
- }
-
- #[inline(always)]
- pub fn disallow_token(&mut self, tok: TokenId) {
- self.set(tok as usize, false)
- }
-
- #[inline(always)]
- pub fn set(&mut self, idx: usize, val: bool) {
- let byte_idx = idx / BITS;
- let bit_idx = idx % BITS;
- if val {
- self.data[byte_idx] |= 1 << bit_idx;
- } else {
- self.data[byte_idx] &= !(1 << bit_idx);
- }
- }
-
- pub fn resize(&mut self, size: usize) {
- let new_size = size / BITS + 1;
- assert!(new_size >= self.data.len());
- self.data.resize(new_size, 0);
- self.size = size;
- }
-
- #[inline(always)]
- pub fn get(&self, idx: usize) -> bool {
- let byte_idx = idx / 32;
- let bit_idx = idx % 32;
- (self.data[byte_idx] & (1 << bit_idx)) != 0
- }
-
- #[inline(always)]
- pub fn is_allowed(&self, tok: TokenId) -> bool {
- self.get(tok as usize)
- }
-
- pub fn set_all(&mut self, val: bool) {
- let val = if val { !0 } else { 0 };
- self.data.iter_mut().for_each(|x| *x = val);
- self.clear_excessive_bits();
- }
-
- pub fn apply_to(&self, logits: &mut [f32]) {
- for (idx, v) in self.data.iter().enumerate() {
- if *v == 0 {
- continue;
- }
- let idx = idx * BITS;
- for bit_idx in 0..BITS {
- if v & (1 << bit_idx) != 0 {
- logits[idx + bit_idx] = 0.0;
- }
- }
- }
- }
-
- pub fn iter(&self) -> SimpleVobIter {
- SimpleVobIter { vob: self, idx: 0 }
- }
-
- pub fn or(&mut self, other: &SimpleVob) {
- assert_eq!(self.size, other.size);
- for (idx, v) in self.data.iter_mut().zip(other.data.iter()) {
- *idx |= *v;
- }
- }
-
- /// self |= other & !minus
- pub fn or_minus(&mut self, other: &SimpleVob, minus: &SimpleVob) {
- assert_eq!(self.size, other.size);
- assert_eq!(self.size, minus.size);
- for ((slf, oth), mn) in self
- .data
- .iter_mut()
- .zip(other.data.iter())
- .zip(minus.data.iter())
- {
- *slf |= *oth & !*mn;
- }
- }
-
- pub fn and(&mut self, other: &SimpleVob) {
- assert_eq!(self.size, other.size);
- for (idx, v) in self.data.iter_mut().zip(other.data.iter()) {
- *idx &= *v;
- }
- }
-
- pub fn is_zero(&self) -> bool {
- self.data.iter().all(|x| *x == 0)
- }
-
- pub fn and_is_zero(&self, other: &SimpleVob) -> bool {
- assert_eq!(self.size, other.size);
- self.data
- .iter()
- .zip(other.data.iter())
- .all(|(a, b)| *a & *b == 0)
- }
-
- pub fn first_bit_set_here_and_in(&self, other: &SimpleVob) -> Option {
- assert_eq!(self.size, other.size);
- for (idx, (a, b)) in self.data.iter().zip(other.data.iter()).enumerate() {
- let v = *a & *b;
- if v != 0 {
- return Some(idx * BITS + v.trailing_zeros() as usize);
- }
- }
- None
- }
-
- pub fn first_bit_set(&self) -> Option {
- for (idx, v) in self.data.iter().enumerate() {
- if *v != 0 {
- return Some(idx * BITS + v.trailing_zeros() as usize);
- }
- }
- None
- }
-}
-
-pub struct SimpleVobIter<'a> {
- vob: &'a SimpleVob,
- idx: usize,
-}
-
-impl Iterator for SimpleVobIter<'_> {
- type Item = u32;
-
- #[inline(always)]
- fn next(&mut self) -> Option {
- let mut bitoff = self.idx % BITS;
- let mut dataoff = self.idx / BITS;
- let data = &self.vob.data;
- while dataoff < data.len() {
- let d = data[dataoff] >> bitoff;
- if d != 0 {
- let idx = dataoff * BITS + d.trailing_zeros() as usize + bitoff;
- self.idx = idx + 1;
- return Some(idx as u32);
- }
- bitoff = 0;
- dataoff += 1;
- }
- None
- }
-}
-
-impl Index for SimpleVob {
- type Output = bool;
-
- fn index(&self, index: usize) -> &Self::Output {
- if self.is_allowed(index as TokenId) {
- &true
- } else {
- &false
- }
- }
-}
diff --git a/mistralrs-core/src/aici/toktree.rs b/mistralrs-core/src/aici/toktree.rs
deleted file mode 100644
index 7371a1475e..0000000000
--- a/mistralrs-core/src/aici/toktree.rs
+++ /dev/null
@@ -1,797 +0,0 @@
-// use 8:24 encoding - num_ch:tok_id (ch_byte:ch_off)* - 8 bytes per tree node
-// special case num_ch=0xff -> num_ch=0x100
-
-use anyhow::Result;
-use bytemuck_derive::{Pod, Zeroable};
-use rustc_hash::FxHashMap;
-
-use crate::aici::{
- bytes::{to_hex_string, vec_from_bytes, TokRxInfo, TokenId},
- svob::SimpleVob,
-};
-
-#[derive(Clone, Copy, Debug, PartialEq, Eq, Hash)]
-pub enum SpecialToken {
- Unknown,
- Padding,
- Separator,
- BeginningOfSentence,
- EndOfSentence,
-}
-
-pub trait Recognizer {
- /// for _ in 0..num { stack.pop() }
- fn pop_bytes(&mut self, num: usize);
- /// X = stack.top(); stack.empty(); stack.push(X)
- fn collapse(&mut self);
- /// check if stack.top() transitions via byte to a viable state
- fn byte_allowed(&mut self, byte: u8) -> bool {
- if self.try_push_byte(byte) {
- self.pop_bytes(1);
- true
- } else {
- false
- }
- }
- /// check if stack.top() transitions via tok to a viable state
- fn special_allowed(&mut self, tok: SpecialToken) -> bool;
- /// Called when iteration over the trie is finished
- /// Stack has exactly one element then, except when iteration started from non-root node.
- /// In that case, the stack may have more than one element, and trie_finished() needs to pop the excessive elements.
- fn trie_finished(&mut self);
- /// Called when iteration over the trie is started
- fn trie_started(&mut self) {}
- /// This combines `push_byte` and `byte_allowed` into one function for performance.
- fn try_push_byte(&mut self, byte: u8) -> bool;
- /// Check if there are any errors to be reported to the user.
- fn get_error(&self) -> Option {
- None
- }
-}
-
-#[derive(Clone)]
-pub struct TokTrie {
- info: TokRxInfo,
- token_offsets: Vec,
- token_data: Vec,
- nodes: Vec,
- max_token_len: usize,
- token_duplicates: FxHashMap>,
-}
-
-#[derive(Clone, Copy, Zeroable, Pod)]
-#[repr(C)]
-pub struct TokTrieHeader {
- magic: u32,
- hd_size: u32,
- trie_bytes: u32,
- token_offset_bytes: u32,
- token_data_bytes: u32,
- info: TokRxInfo,
- align: [u32; 0],
-}
-
-impl TokTrieHeader {
- const MAGIC: u32 = 0x558b6fd3;
-}
-
-#[derive(Clone, Copy, Zeroable, Pod)]
-#[repr(C)]
-pub struct TrieNode {
- // byte:token
- bits: u32,
- bits2: u32,
-}
-
-const NO_TOKEN: u32 = 0xffffff;
-
-impl TrieNode {
- fn new(byte: u8, token_id: u32, num_parents: u8) -> TrieNode {
- TrieNode {
- bits: (token_id << 8) | byte as u32,
- bits2: num_parents as u32,
- }
- }
-
- #[inline(always)]
- pub fn byte(&self) -> u8 {
- (self.bits & 0xff) as u8
- }
-
- #[inline(always)]
- pub fn subtree_size(&self) -> usize {
- (self.bits2 >> 8) as usize
- }
-
- #[inline(always)]
- pub fn num_parents(&self) -> usize {
- (self.bits2 & 0xff) as usize
- }
-
- #[inline(always)]
- pub fn token_id(&self) -> Option {
- let r = self.bits >> 8;
- if r == NO_TOKEN {
- None
- } else {
- Some(r)
- }
- }
-}
-
-// max length of token is 1023 bytes
-const LEN_BITS: u32 = 10;
-
-impl TokTrie {
- pub fn from(info: &TokRxInfo, words: &[Vec]) -> Self {
- let mut trie = TrieHash::new(0xff);
- let mut token_offsets = Vec::new();
- let mut token_data = Vec::new();
- assert!(info.vocab_size == words.len() as u32);
- for (idx, word) in words.iter().enumerate() {
- if !word.is_empty() {
- trie.insert(word, idx as u32);
- }
- assert!(word.len() < (1 << LEN_BITS));
- assert!(token_data.len() < (1 << (32 - LEN_BITS)));
- let desc = (word.len() as u32) | ((token_data.len() as u32) << LEN_BITS);
- token_offsets.push(desc);
- token_data.extend_from_slice(word);
- }
- let mut nodes = Vec::new();
- trie.serialize(&mut nodes, 0);
- let mut r = TokTrie {
- info: *info,
- token_offsets,
- token_data,
- nodes,
- max_token_len: 0,
- token_duplicates: FxHashMap::default(),
- };
- r.finalize_ctor();
- r
- }
-
- fn finalize_ctor(&mut self) {
- for tok_id in 0..self.info.vocab_size {
- let bytes = self.token(tok_id);
- let tok_ids = self.greedy_tokenize(bytes);
- self.max_token_len = std::cmp::max(self.max_token_len, bytes.len());
- if tok_ids.len() == 1 && tok_ids[0] != tok_id {
- self.token_duplicates
- .entry(tok_ids[0])
- .or_default()
- .push(tok_id);
- }
- }
- self.validate();
- }
-
- fn node_offset(&self, n: &TrieNode) -> usize {
- let off = unsafe { (n as *const TrieNode).offset_from(self.root() as *const TrieNode) };
- assert!(off >= 0);
- let off = off as usize;
- assert!(off < self.nodes.len());
- off
- }
-
- fn next_node(&self, n: &TrieNode) -> usize {
- self.node_offset(n) + n.subtree_size()
- }
-
- pub fn info(&self) -> &TokRxInfo {
- &self.info
- }
-
- pub fn special_token(&self, tok: SpecialToken) -> TokenId {
- match tok {
- SpecialToken::EndOfSentence => self.info.tok_eos,
- _ => panic!("non-EOS special_token() called"), // TODO?
- }
- }
-
- pub fn eos_token(&self) -> TokenId {
- self.info.tok_eos
- }
-
- pub fn vocab_size(&self) -> usize {
- self.info.vocab_size as usize
- }
-
- pub fn alloc_token_set(&self) -> SimpleVob {
- let mut r = SimpleVob::new();
- r.resize(self.vocab_size() + 1);
- r
- }
-
- pub fn token_set_dbg(&self, ts: &SimpleVob) -> String {
- let max_examples = 50;
-
- let ts_neg = ts.negated();
- let use_neg = ts_neg.num_set() * 20 < ts.num_set();
- let ts1 = if use_neg { &ts_neg } else { ts };
- let num_set = ts1.num_set();
- let max_tok = std::cmp::min(max_examples, num_set);
- let mut token_names = Vec::new();
- // make sure we include EOS first if it's allowed
- if ts1.is_allowed(self.info.tok_eos) {
- token_names.push("EOS".to_string());
- }
- for idx in 0..self.vocab_size() {
- if idx as TokenId != self.info.tok_eos && ts1.is_allowed(idx as TokenId) {
- token_names.push(self.token_dbg(idx as TokenId));
- if token_names.len() >= max_tok {
- break;
- }
- }
- }
- if token_names.len() < num_set {
- token_names.push("...".to_string());
- }
- format!(
- "TokenSet: {}/{}; {}{}",
- ts.num_set(),
- self.vocab_size(),
- if use_neg { "ALL EXCEPT " } else { "" },
- token_names.join(", ")
- )
- }
-
- pub fn alloc_logits(&self) -> Vec {
- vec![0.0; self.vocab_size() + 1]
- }
-
- pub fn test_trace_tokens(&self, toks: &[u32]) -> String {
- toks.iter()
- .map(|t| {
- let s = self.token_dbg(*t);
- if s.starts_with('\"') {
- self.token_str(*t)
- } else {
- format!("≺{}≻", s)
- }
- })
- .collect::>()
- .join("‧")
- }
-
- pub fn tokens_dbg(&self, toks: &[u32]) -> String {
- let joined = toks
- .iter()
- .map(|t| {
- let s = self.token_dbg(*t);
- if s.starts_with('\"') {
- s[1..s.len() - 1].to_string()
- } else {
- format!("≺{}≻", s)
- }
- })
- .collect::>()
- .join("‧");
-
- format!("\"{}\"", joined)
- }
-
- pub fn token_dbg(&self, idx: u32) -> String {
- if idx == self.info.tok_eos {
- "EOS".to_string()
- } else if idx as usize >= self.vocab_size() {
- format!("OOB[{}]", idx)
- } else {
- // format!("{:?}[{}]", self.token_str(idx), idx)
- let s = self.token_str(idx);
- if s.is_empty() {
- format!("EMPTY[{}]", idx)
- } else if !s.contains('\u{fffd}') {
- format!("{:?}", s)
- } else {
- let bytes = self.token(idx);
- format!("HEX[{}]", to_hex_string(bytes))
- }
- }
- }
-
- pub fn token_str(&self, idx: u32) -> String {
- String::from_utf8_lossy(self.token(idx)).to_string()
- }
-
- pub fn token(&self, idx: u32) -> &[u8] {
- let off = self.token_offsets[idx as usize];
- let len = off & ((1 << LEN_BITS) - 1);
- let off = (off >> LEN_BITS) as usize;
- &self.token_data[off..(off + len as usize)]
- }
-
- pub fn decode(&self, tokens: &[TokenId]) -> Vec {
- tokens
- .iter()
- .flat_map(|t| self.token(*t).to_vec())
- .collect()
- }
-
- pub fn decode_str(&self, tokens: &[TokenId]) -> String {
- String::from_utf8_lossy(&self.decode(tokens)).to_string()
- }
-
- pub fn greedy_tokenize(&self, bytes: &[u8]) -> Vec {
- let mut r = Vec::new();
- if bytes.is_empty() {
- return r;
- }
-
- let mut n = self.root();
- let mut last_tok = None;
- let mut last_idx = 0;
- let mut idx = 0;
- while idx < bytes.len() {
- match self.child_at_byte(n, bytes[idx]) {
- Some(c) => {
- if let Some(tok) = c.token_id() {
- last_tok = Some(tok);
- last_idx = idx;
- }
- n = c;
- }
- None => {
- r.push(last_tok.unwrap());
- idx = last_idx;
- n = self.root();
- }
- }
- idx += 1;
- }
- r.push(last_tok.unwrap());
- r
- }
-
- pub fn tokenize_with_greedy_fallback(
- &self,
- s: &[u8],
- str_tokenize: impl FnOnce(&str) -> Vec,
- ) -> Vec {
- let utf8_str = String::from_utf8_lossy(s);
- // if the string ends with a replacement character, remove them
- let to_tokenize = if utf8_str.ends_with('\u{FFFD}') {
- utf8_str.trim_end_matches('\u{FFFD}')
- } else {
- &utf8_str
- };
- let mut r = str_tokenize(to_tokenize);
- // if we didn't tokenize everything (because of the replacement character)
- // we tokenize the suffix using greedy tokenizer that is happy with bytes
- let last_tokenized = to_tokenize.len();
- if last_tokenized < s.len() {
- let mut added = self.greedy_tokenize(&s[last_tokenized..]);
- r.append(&mut added);
- }
- r
- }
-
- pub fn has_extensions(&self, bytes: &[u8]) -> bool {
- match self.child_at_bytes(self.root(), bytes) {
- None => false,
- Some(n) => n.subtree_size() > 1,
- }
- }
-
- pub fn token_id(&self, bytes: &[u8]) -> Option {
- let (tok, len) = self.prefix_token_id(bytes);
- // println!("tok_id {:?} {:?} {:?} ", bytes, tok, len);
- if len == bytes.len() {
- Some(tok)
- } else {
- None
- }
- }
-
- pub fn prefix_token_id(&self, bytes: &[u8]) -> (TokenId, usize) {
- assert!(!bytes.is_empty());
- let mut last = (0, 0);
- let mut n = self.root();
- for (idx, byte) in bytes.iter().enumerate() {
- n = match self.child_at_byte(n, *byte) {
- Some(n) => n,
- None => break,
- };
- if let Some(tok) = n.token_id() {
- last = (tok, idx + 1);
- }
- }
- last
- }
-
- pub fn from_bytes(bytes: &[u8]) -> Self {
- let pref = std::mem::size_of::();
- let hd: &TokTrieHeader = bytemuck::from_bytes(&bytes[0..pref]);
-
- assert!(hd.magic == TokTrieHeader::MAGIC);
- assert!(hd.hd_size as usize == pref);
-
- let trie_end = pref + hd.trie_bytes as usize;
- let nodes = vec_from_bytes(&bytes[pref..trie_end]);
- let offsets_end = trie_end + hd.token_offset_bytes as usize;
- let token_offsets = vec_from_bytes(&bytes[trie_end..offsets_end]);
- let token_data = vec_from_bytes(&bytes[offsets_end..]);
-
- let mut r = TokTrie {
- info: hd.info,
- token_offsets,
- token_data,
- nodes,
- max_token_len: 0,
- token_duplicates: FxHashMap::default(),
- };
- r.finalize_ctor();
- r
- }
-
- pub fn max_token_len(&self) -> usize {
- self.max_token_len
- }
-
- fn validate_node(&self, n: &TrieNode, ep: usize, used: &mut [bool]) {
- if let Some(tok) = n.token_id() {
- assert!(tok < self.info.vocab_size);
- assert!(!used[tok as usize]);
- used[tok as usize] = true;
- }
- let endp = self.next_node(n);
- assert!(endp <= ep);
- for child in self.node_children(n) {
- self.validate_node(child, endp, used);
- }
- }
-
- fn validate(&self) {
- self.validate_node(
- self.root(),
- self.next_node(self.root()),
- &mut vec![false; self.info.vocab_size as usize],
- );
- for idx in 0..self.info.vocab_size {
- let _ = self.token(idx);
- }
- }
-
- pub fn serialize(&self) -> Vec {
- let trie_data: &[u8] = bytemuck::cast_slice(&self.nodes);
- let token_offsets: &[u8] = bytemuck::cast_slice(&self.token_offsets);
- let token_data: &[u8] = bytemuck::cast_slice(&self.token_data);
-
- let hd = TokTrieHeader {
- magic: TokTrieHeader::MAGIC,
- hd_size: std::mem::size_of::() as u32,
- trie_bytes: trie_data.len() as u32,
- token_offset_bytes: token_offsets.len() as u32,
- token_data_bytes: trie_data.len() as u32,
- info: self.info,
- align: [],
- };
-
- let mut bytes = bytemuck::bytes_of(&hd).to_vec();
- bytes.extend_from_slice(trie_data);
- bytes.extend_from_slice(token_offsets);
- bytes.extend_from_slice(token_data);
- bytes
- }
-
- pub fn root(&self) -> &TrieNode {
- &self.nodes[0]
- }
-
- pub fn check_against(&self, tokens: &[Vec]) {
- let vocab_size = tokens.len();
- for (idx, bytes) in tokens.iter().enumerate().take(vocab_size) {
- let tid = idx as TokenId;
- assert!(bytes == self.token(tid));
- let root = self.root();
- if !bytes.is_empty() {
- let tid2 = self
- .child_at_bytes(root, bytes)
- .unwrap()
- .token_id()
- .unwrap();
- if tid != tid2 {
- assert!(self.token_duplicates[&tid2].contains(&tid));
- }
- }
- }
- }
-
- pub fn child_at_byte<'a>(&'a self, n: &'a TrieNode, byte: u8) -> Option<&'a TrieNode> {
- self.node_children(n).find(|&child| child.byte() == byte)
- }
-
- pub fn all_subtokens(&self, bytes: &[u8]) -> Vec {
- let mut r = Vec::new();
- for i in 0..bytes.len() {
- let mut n = self.root();
- for x in bytes.iter().skip(i) {
- n = match self.child_at_byte(n, *x) {
- Some(n) => n,
- None => break,
- };
- if let Some(tok) = n.token_id() {
- r.push(tok);
- }
- }
- }
- r
- }
-
- pub fn node_children(&self, n: &TrieNode) -> NodeChildren {
- let off = self.node_offset(n);
- NodeChildren {
- trie: self,
- current_offset: off + 1,
- end_offset: off + n.subtree_size(),
- }
- }
-
- pub fn child_at_bytes<'a>(&'a self, mut n: &'a TrieNode, bytes: &[u8]) -> Option<&'a TrieNode> {
- for &byte in bytes {
- n = match self.child_at_byte(n, byte) {
- Some(n) => n,
- None => return None,
- }
- }
- Some(n)
- }
-
- pub fn compute_bias(&self, r: &mut impl Recognizer, logits: &mut SimpleVob) {
- self.compute_bias_ext(r, logits, &[]);
- }
-
- pub fn compute_bias_ext(&self, r: &mut impl Recognizer, logits: &mut SimpleVob, start: &[u8]) {
- logits.set_all(false);
- if start.is_empty() {
- // EOS is only allowed if there is no forced byte prefix
- #[allow(clippy::useless_vec)]
- for tok in vec![SpecialToken::EndOfSentence] {
- if r.special_allowed(tok) {
- logits.allow_token(self.special_token(tok))
- }
- }
- }
- // all prefixes of 'start' are also allowed
- if !start.is_empty() {
- for len in 1..=start.len() {
- let bytes = &start[0..len];
- if let Some(tok) = self.token_id(bytes) {
- logits.allow_token(tok);
- }
- }
- }
- self.add_bias(r, logits, start);
- self.apply_duplicates(logits);
- }
-
- pub fn apply_duplicates(&self, logits: &mut SimpleVob) {
- for (tok, dups) in &self.token_duplicates {
- if logits.is_allowed(*tok) {
- for &dup in dups {
- logits.allow_token(dup);
- }
- }
- }
- }
-
- pub fn append_tokens(&self, r: &mut impl Recognizer, ts: &[TokenId]) -> Result<()> {
- for t in ts {
- self.append_token(r, *t)?;
- }
- Ok(())
- }
-
- pub fn append_token(&self, r: &mut impl Recognizer, t: TokenId) -> Result<()> {
- // println!("append_token: {}", self.token_dbg(t));
- let bytes = self.token(t);
- for &byte in bytes {
- if !r.try_push_byte(byte) {
- r.collapse();
- return Err(anyhow::anyhow!("byte {:?} not allowed", byte as char));
- }
- }
- r.collapse();
- Ok(())
- }
-
- pub fn token_allowed(&self, r: &mut impl Recognizer, t: TokenId) -> bool {
- let bytes = self.token(t);
- let mut num = 0;
- let mut ok = true;
- r.trie_started();
- for &byte in bytes {
- if r.try_push_byte(byte) {
- num += 1;
- } else {
- ok = false;
- break;
- }
- }
- r.pop_bytes(num);
- r.trie_finished();
- ok
- }
-
- /// Return how many tokens and bytes need to chopped off tokens,
- /// so that we do not limit all possible future tokenizations matching the recognizer.
- pub fn chop_tokens(&self, r: &mut impl Recognizer, tokens: &[TokenId]) -> (usize, usize) {
- let mut suff = Vec::new();
- let mut chop_tokens = 0;
- let mut chop_bytes = 0;
- for (idx, t) in tokens.iter().rev().enumerate() {
- suff.splice(0..0, self.token(*t).iter().cloned());
- if suff.len() > self.max_token_len() {
- break;
- }
- if self.has_valid_extensions(r, &suff) {
- chop_tokens = idx + 1;
- chop_bytes = suff.len();
- }
- }
- (chop_tokens, chop_bytes)
- }
-
- /// Check if add_bias() would have returned any tokens.
- #[inline(never)]
- pub fn has_valid_extensions(&self, r: &mut impl Recognizer, start: &[u8]) -> bool {
- let n = self.child_at_bytes(self.root(), start);
- if n.is_none() {
- return false;
- }
- let n = n.unwrap();
- r.trie_started();
- let off = self.node_offset(n);
- let mut p = off + 1;
- let endp = off + n.subtree_size();
- let mut ok = false;
- let mut next_pop = 0;
- while p < endp {
- r.pop_bytes(next_pop);
- let n = &self.nodes[p];
- let b = n.byte();
- if r.try_push_byte(b) {
- if n.token_id().is_some() {
- ok = true;
- break;
- }
- next_pop = if n.subtree_size() == 1 {
- n.num_parents()
- } else {
- 0
- };
- p += 1;
- } else {
- p += n.subtree_size();
- next_pop = n.num_parents() - 1;
- }
- }
- if start.is_empty() {
- // if start was non-empty, trie_finished() is supposed to clean this up
- r.pop_bytes(next_pop);
- }
- r.trie_finished();
- ok
- }
-
- #[inline(never)]
- pub fn add_bias(&self, r: &mut impl Recognizer, toks: &mut SimpleVob, start: &[u8]) {
- r.trie_started();
- let n = self.child_at_bytes(self.root(), start).unwrap();
- let defl_tok = self.vocab_size() as u32;
- let off = self.node_offset(n);
- let mut p = off + 1;
- let endp = off + n.subtree_size();
- let mut next_pop = 0;
- while p < endp {
- r.pop_bytes(next_pop);
- let n = &self.nodes[p];
- let b = n.byte();
- if r.try_push_byte(b) {
- toks.allow_token(n.token_id().unwrap_or(defl_tok));
- next_pop = if n.subtree_size() == 1 {
- n.num_parents()
- } else {
- 0
- };
- p += 1;
- } else {
- p += n.subtree_size();
- next_pop = n.num_parents() - 1;
- }
- }
- if start.is_empty() {
- // if start was non-empty, trie_finished() is supposed to clean this up
- r.pop_bytes(next_pop);
- }
- r.trie_finished();
- // revert the fake token
- toks.disallow_token(defl_tok);
- }
-}
-
-pub struct NodeChildren<'a> {
- trie: &'a TokTrie,
- current_offset: usize,
- end_offset: usize,
-}
-
-impl<'a> Iterator for NodeChildren<'a> {
- type Item = &'a TrieNode;
-
- fn next(&mut self) -> Option {
- if self.current_offset < self.end_offset {
- let node = &self.trie.nodes[self.current_offset];
- self.current_offset += node.subtree_size();
- Some(node)
- } else {
- None
- }
- }
-}
-
-struct TrieHash {
- token_id: u32,
- byte: u8,
- children: Vec,
-}
-
-impl TrieHash {
- fn new(byte: u8) -> TrieHash {
- TrieHash {
- token_id: NO_TOKEN,
- byte,
- children: Vec::new(),
- }
- }
- fn insert(&mut self, word: &[u8], token_id: u32) {
- if word.is_empty() {
- // Some tokenizers have duplicate tokens...
- // we just override
- // assert!(self.token_id == NO_TOKEN);
- self.token_id = token_id;
- } else {
- if self.children.len() == 0x100 {
- // assert!(self.children[word[0] as usize].byte == word[0]);
- self.children[word[0] as usize].insert(&word[1..], token_id);
- return;
- }
-
- for ch in &mut self.children {
- if ch.byte == word[0] {
- ch.insert(&word[1..], token_id);
- return;
- }
- }
-
- let mut ch = TrieHash::new(word[0]);
- ch.insert(&word[1..], token_id);
- self.children.push(ch);
-
- // if it's getting dense, make it full
- // for cl100k threshold 60->15 nodes, 50->22, 40->45 30->94
- // for llama (32k) 50->5, 40->15
- // TODO remove this?
- if self.children.len() > 250 {
- let mut v2 = (0..=255).map(TrieHash::new).collect::>();
- for ch in self.children.drain(..) {
- let idx = ch.byte as usize;
- v2[idx] = ch;
- }
- self.children = v2;
- }
- }
- }
- fn serialize(&mut self, data: &mut Vec, num_parents: u8) {
- let idx = data.len();
- let mut num_ch = self.children.len();
- data.push(TrieNode::new(self.byte, self.token_id, num_parents));
- self.children.sort_by_key(|e| e.byte);
- for entry in &mut self.children {
- num_ch -= 1;
- entry.serialize(data, if num_ch == 0 { num_parents + 1 } else { 1 });
- }
- data[idx].bits2 |= ((data.len() - idx) as u32) << 8;
- }
-}
diff --git a/mistralrs-core/src/attention.rs b/mistralrs-core/src/attention.rs
index 0376205a01..d5ec363b32 100644
--- a/mistralrs-core/src/attention.rs
+++ b/mistralrs-core/src/attention.rs
@@ -158,7 +158,10 @@ fn naive_sdpa(
#[cfg(not(feature = "metal"))]
let supports_attn_softmax = true;
- if mask.is_some_and(|mask| mask.rank() == 2) && supports_attn_softmax {
+ // Use faster softmax if mask is rank 2 or it's rank 3 and bs 1
+ if mask.is_some_and(|mask| mask.rank() == 2 || (mask.rank() == 3 && mask.dims()[0] == 1))
+ && supports_attn_softmax
+ {
let mut att = MatMul.matmul(q, &k.t()?)?;
if let Some(softcap) = sdpa_params.softcap {
att = (att / softcap as f64)?;
@@ -166,9 +169,14 @@ fn naive_sdpa(
att = (att * softcap as f64)?;
}
- att = candle_nn::ops::attn_softmax_last_dim(
- &att,
- mask.unwrap(),
+ let mask = match mask {
+ Some(mask) if mask.rank() == 3 && mask.dim(0)? == 1 => mask.squeeze(0)?,
+ Some(mask) if mask.rank() == 2 => mask.clone(),
+ _ => unreachable!(),
+ };
+ candle_nn::ops::inplace_attn_softmax_last_dim(
+ &mut att,
+ &mask,
1. / (head_dim as f32).sqrt(),
)?;
MatMul.matmul(&att, v)
@@ -184,7 +192,7 @@ fn naive_sdpa(
Some(m) => att.broadcast_add(m)?,
None => att,
};
- att = candle_nn::ops::softmax_last_dim(&att)?;
+ candle_nn::ops::inplace_softmax_last_dim(&mut att)?;
MatMul.matmul(&att, v)
}
}
@@ -251,11 +259,13 @@ impl Sdpa {
let q = q.flatten(0, 1)?;
let v = v.flatten(0, 1)?;
let attention_bias = match mask {
+ Some(mask) if mask.rank() == 3 && mask.dims()[0] == 1 => {
+ Some(mask.repeat((n_attn_heads, 1, 1))?)
+ }
Some(mask) if mask.rank() == 3 => Some(mask.clone()),
Some(mask) if mask.rank() == 4 => Some(mask.flatten(0, 1)?),
- Some(mask) if mask.rank() == 2 => Some(mask.unsqueeze(0)?),
Some(mask) => {
- candle_core::bail!("cublaslt attn mask: rank must be 3, 4, or 2")
+ candle_core::bail!("cublaslt attn mask: rank must be 3 or 4")
}
None => None,
};
diff --git a/mistralrs-core/src/engine/mod.rs b/mistralrs-core/src/engine/mod.rs
index 3adbffb7ad..7557ef113e 100644
--- a/mistralrs-core/src/engine/mod.rs
+++ b/mistralrs-core/src/engine/mod.rs
@@ -1,5 +1,6 @@
use candle_core::Tensor;
use either::Either;
+use llguidance::toktrie::TokEnv;
use once_cell::sync::Lazy;
use std::{
collections::HashMap,
@@ -12,10 +13,10 @@ use std::{
use tokio::sync::{mpsc::Receiver, Mutex};
use crate::{
- aici::{cfg::CfgParser, recognizer::StackRecognizer, rx::RecRx},
pipeline::{
- text_models_inputs_processor::PagedAttentionMeta, AdapterInstruction, CacheBackendMetadata,
- CacheInstruction, EitherCache, NormalCache,
+ llg::{constraint_from_llg_grammar, llg_grammar_from_constraint},
+ text_models_inputs_processor::PagedAttentionMeta,
+ AdapterInstruction, CacheBackendMetadata, CacheInstruction, EitherCache, NormalCache,
},
request::{DetokenizationRequest, NormalRequest, TokenizationRequest},
response::CompletionChoice,
@@ -485,15 +486,19 @@ impl Engine {
}
}
- fn build_sequence_recognizer(constraint: &Constraint) -> anyhow::Result {
- let recognizer = match constraint {
- Constraint::Regex(rx) => {
- SequenceRecognizer::Regex(StackRecognizer::from(RecRx::from_rx(rx, None)?).into())
- }
- Constraint::Yacc(cfg) => SequenceRecognizer::Cfg(CfgParser::from_yacc(cfg)?.into()),
- Constraint::None => SequenceRecognizer::None,
- };
- Ok(recognizer)
+ fn build_sequence_recognizer(
+ tok_env: &Option,
+ constraint: &Constraint,
+ ) -> anyhow::Result {
+ if let Some(grm) = llg_grammar_from_constraint(constraint)? {
+ let tok_env = tok_env
+ .as_ref()
+ .ok_or_else(|| anyhow::anyhow!("No token environment found."))?;
+ let llg = constraint_from_llg_grammar(tok_env.clone(), grm)?;
+ Ok(SequenceRecognizer::Llguidance(Box::new(llg)))
+ } else {
+ Ok(SequenceRecognizer::None)
+ }
}
async fn handle_request(&mut self, request: Request) {
@@ -534,7 +539,7 @@ impl Engine {
RequestMessage::Chat(_)
| RequestMessage::CompletionTokens(_)
| RequestMessage::VisionChat { .. }
- | RequestMessage::ImageGeneration { .. } => 1,
+ | RequestMessage::ImageGeneration { .. } => None,
};
if is_chat
&& !get_mut_arcmutex!(self.pipeline)
@@ -694,13 +699,14 @@ impl Engine {
let (stop_toks, stop_strings) = match request.sampling_params.stop_toks {
None => (vec![], vec![]),
Some(StopTokens::Ids(ref i)) => {
- let tok_trie = {
+ let tok_env = {
let pipeline = get_mut_arcmutex!(self.pipeline);
- pipeline.get_metadata().tok_trie.clone()
+ pipeline.get_metadata().tok_env.clone()
};
for id in i {
// We can't use ` ` (space) as a stop token because other tokens like ` moon` start with a space.
- if let Some(tok_trie) = tok_trie.as_ref() {
+ if let Some(tok_env) = tok_env.as_ref() {
+ let tok_trie = tok_env.tok_trie();
if tok_trie.has_extensions(tok_trie.token(*id)) {
request
.response
@@ -719,11 +725,11 @@ impl Engine {
let mut stop_toks = Vec::new();
let mut stop_strings: Vec = Vec::new();
- let (tok_trie, tokenizer) = {
+ let (tok_env, tokenizer) = {
let pipeline = get_mut_arcmutex!(self.pipeline);
- let tok_trie = pipeline.get_metadata().tok_trie.clone();
+ let tok_env = pipeline.get_metadata().tok_env.clone();
let tokenizer = pipeline.tokenizer();
- (tok_trie, tokenizer)
+ (tok_env, tokenizer)
};
for stop_txt in s {
@@ -744,7 +750,8 @@ impl Engine {
.to_vec();
if toks.len() == 1 {
- if tok_trie.as_ref().is_some_and(|tok_trie| {
+ if tok_env.as_ref().is_some_and(|tok_env| {
+ let tok_trie = tok_env.tok_trie();
tok_trie.has_extensions(tok_trie.token(toks[0]))
}) {
stop_strings.push(stop_txt.clone());
@@ -796,7 +803,11 @@ impl Engine {
// Add sequences
for response_index in 0..request.sampling_params.n_choices {
- let recognizer = match Self::build_sequence_recognizer(&request.constraint) {
+ let trie = get_mut_arcmutex!(self.pipeline)
+ .get_metadata()
+ .tok_env
+ .clone();
+ let recognizer = match Self::build_sequence_recognizer(&trie, &request.constraint) {
Ok(recognizer) => recognizer,
Err(err) => {
request
@@ -815,11 +826,6 @@ impl Engine {
.cache_config
.clone()
.map(|conf| conf.block_size);
- let trie = get_mut_arcmutex!(self.pipeline)
- .get_metadata()
- .tok_trie
- .as_ref()
- .map(|x| (**x).clone());
let cache = get_mut_arcmutex!(self.pipeline).cache().clone();
let seq_preallocated_cache = if let EitherCache::Normal(_cache) = cache {
@@ -891,7 +897,6 @@ impl Engine {
request.adapters.clone(),
images.clone(),
block_size,
- trie,
matcher.clone(),
image_generation_format,
seq_step_type,
diff --git a/mistralrs-core/src/lib.rs b/mistralrs-core/src/lib.rs
index d954dd1a58..343ca8bc2c 100644
--- a/mistralrs-core/src/lib.rs
+++ b/mistralrs-core/src/lib.rs
@@ -26,7 +26,6 @@ use tokio::sync::mpsc::{channel, Sender};
use tracing::info;
use tracing::warn;
-mod aici;
mod cuda;
mod device_map;
mod engine;
@@ -85,8 +84,8 @@ pub use pipeline::{
VisionLoaderBuilder, VisionLoaderType, VisionPromptPrefixer, VisionSpecificConfig,
};
pub use request::{
- Constraint, DetokenizationRequest, ImageGenerationResponseFormat, MessageContent,
- NormalRequest, Request, RequestMessage, TokenizationRequest,
+ Constraint, DetokenizationRequest, ImageGenerationResponseFormat, LlguidanceGrammar,
+ MessageContent, NormalRequest, Request, RequestMessage, TokenizationRequest,
};
pub use response::*;
pub use sampler::{
@@ -105,6 +104,9 @@ pub use utils::memory_usage::MemoryUsage;
pub use utils::normal::{ModelDType, TryIntoDType};
pub use utils::paged_attn_supported;
+// re-export llguidance for easier LlguidanceGrammar construction
+pub use llguidance;
+
/// `true` if `MISTRALRS_DEBUG=1`
pub(crate) static DEBUG: AtomicBool = AtomicBool::new(false);
static ENGINE_ID: AtomicUsize = AtomicUsize::new(0);
@@ -371,7 +373,7 @@ impl MistralRs {
messages: RequestMessage::Completion {
text: "dummy".to_string(),
echo_prompt: false,
- best_of: 1,
+ best_of: None,
},
sampling_params: SamplingParams {
max_len: Some(1),
diff --git a/mistralrs-core/src/model_loader.rs b/mistralrs-core/src/model_loader.rs
index 37bac506e4..f88080c1d7 100644
--- a/mistralrs-core/src/model_loader.rs
+++ b/mistralrs-core/src/model_loader.rs
@@ -127,6 +127,8 @@ fn loader_from_model_selected(args: LoaderBuilder) -> anyhow::Result NormalLoaderBuilder::new(
NormalSpecificConfig {
use_flash_attn,
@@ -135,6 +137,8 @@ fn loader_from_model_selected(args: LoaderBuilder) -> anyhow::Result anyhow::Result anyhow::Result anyhow::Result VisionLoaderBuilder::new(
VisionSpecificConfig {
use_flash_attn,
@@ -390,6 +399,7 @@ fn loader_from_model_selected(args: LoaderBuilder) -> anyhow::Result,
+
+ /// .imatrix file to enhance GGUF quantizations with.
+ /// Incompatible with `--calibration-file/-c`
+ #[arg(short, long)]
+ imatrix: Option,
+
+ /// Generate and utilize an imatrix to enhance GGUF quantizations.
+ /// Incompatible with `--imatrix/-i`
+ #[arg(short, long)]
+ calibration_file: Option,
},
/// Select an X-LoRA architecture
@@ -380,6 +390,10 @@ pub enum ModelSelected {
/// This is only supported on the Qwen2-VL and Idefics 2 models. Others handle this internally.
#[arg(short = 'e', long)]
max_edge: Option,
+
+ /// Generate and utilize an imatrix to enhance GGUF quantizations.
+ #[arg(short, long)]
+ calibration_file: Option,
},
/// Select a diffusion plain model, without quantization or adapters
diff --git a/mistralrs-core/src/models/gemma.rs b/mistralrs-core/src/models/gemma.rs
index 28db35c609..044d2e428b 100644
--- a/mistralrs-core/src/models/gemma.rs
+++ b/mistralrs-core/src/models/gemma.rs
@@ -307,9 +307,8 @@ impl Attention {
}
let mut attn_output = match &self.paged_attn {
- Some(paged_attn) => {
- let ((key_cache, value_cache), input_metadata) = metadata.unwrap();
- paged_attn.forward(
+ Some(paged_attn) => match metadata {
+ Some(((key_cache, value_cache), input_metadata)) => paged_attn.forward(
&q,
&k,
&v,
@@ -318,8 +317,26 @@ impl Attention {
Some(value_cache),
input_metadata,
None,
- )?
- }
+ )?,
+ None => {
+ let mut input_metadata = PagedAttentionInputMetadata {
+ block_tables: None,
+ context_lens: None,
+ max_context_len: None,
+ slot_mappings: Tensor::new(&[0f32], q.device())?,
+ };
+ paged_attn.forward(
+ &q,
+ &k,
+ &v,
+ attention_mask,
+ None,
+ None,
+ &mut input_metadata,
+ None,
+ )?
+ }
+ },
None => {
let (k, v) = kv_cache.append(&k, &v)?;
@@ -446,9 +463,9 @@ impl Model {
) -> Result {
if let Some(ref quant_cfg) = &cfg.quantization_config {
tracing::info!(
- "Using {} quantization in {} bits.",
+ "Using {} quantization: {}.",
quant_cfg.quant_method.to_string(),
- quant_cfg.bits
+ quant_cfg.get_bits_name(&vb)
);
}
let mapper = normal_loading_metadata.mapper;
@@ -638,6 +655,23 @@ impl IsqModel for Model {
uvb.to_safetensors()
}
+
+ fn imatrix_names(&self) -> candle_core::Result>> {
+ // NOTE: dependant on the exact implementation in get_layers!
+ let mut names = Vec::new();
+ // lm_head
+ names.push(None);
+ for i in 0..self.layers.len() {
+ names.push(Some(format!("blk.{i}.attn_q.weight")));
+ names.push(Some(format!("blk.{i}.attn_k.weight")));
+ names.push(Some(format!("blk.{i}.attn_v.weight")));
+ names.push(Some(format!("blk.{i}.attn_output.weight")));
+ names.push(Some(format!("blk.{i}.ffn_gate.weight")));
+ names.push(Some(format!("blk.{i}.ffn_up.weight")));
+ names.push(Some(format!("blk.{i}.ffn_down.weight")));
+ }
+ Ok(names)
+ }
}
impl NormalModel for Model {
@@ -680,6 +714,9 @@ impl NormalModel for Model {
fn cache(&self) -> &EitherCache {
&self.cache
}
+ fn cache_mut(&mut self) -> &mut EitherCache {
+ &mut self.cache
+ }
fn device(&self) -> &Device {
&self.device
}
diff --git a/mistralrs-core/src/models/gemma2.rs b/mistralrs-core/src/models/gemma2.rs
index 67474d55c8..ad1e97c0b7 100644
--- a/mistralrs-core/src/models/gemma2.rs
+++ b/mistralrs-core/src/models/gemma2.rs
@@ -321,9 +321,8 @@ impl Attention {
};
let mut attn_output = match &self.paged_attn {
- Some(paged_attn) => {
- let ((key_cache, value_cache), input_metadata) = metadata.unwrap();
- paged_attn.forward(
+ Some(paged_attn) => match metadata {
+ Some(((key_cache, value_cache), input_metadata)) => paged_attn.forward(
&q,
&k,
&v,
@@ -332,8 +331,26 @@ impl Attention {
Some(value_cache),
input_metadata,
self.attn_logit_softcapping,
- )?
- }
+ )?,
+ None => {
+ let mut input_metadata = PagedAttentionInputMetadata {
+ block_tables: None,
+ context_lens: None,
+ max_context_len: None,
+ slot_mappings: Tensor::new(&[0f32], q.device())?,
+ };
+ paged_attn.forward(
+ &q,
+ &k,
+ &v,
+ attention_mask,
+ None,
+ None,
+ &mut input_metadata,
+ self.attn_logit_softcapping,
+ )?
+ }
+ },
None => {
// self.sliding_window is None if !self.use_sliding_window
let (k, v, mask) =
@@ -485,9 +502,9 @@ impl Model {
) -> Result {
if let Some(ref quant_cfg) = &cfg.quantization_config {
tracing::info!(
- "Using {} quantization in {} bits.",
+ "Using {} quantization: {}.",
quant_cfg.quant_method.to_string(),
- quant_cfg.bits
+ quant_cfg.get_bits_name(&vb)
);
}
let mapper = normal_loading_metadata.mapper;
@@ -709,6 +726,23 @@ impl IsqModel for Model {
uvb.to_safetensors()
}
+
+ fn imatrix_names(&self) -> candle_core::Result>> {
+ // NOTE: dependant on the exact implementation in get_layers!
+ let mut names = Vec::new();
+ // lm_head
+ names.push(None);
+ for i in 0..self.layers.len() {
+ names.push(Some(format!("blk.{i}.attn_q.weight")));
+ names.push(Some(format!("blk.{i}.attn_k.weight")));
+ names.push(Some(format!("blk.{i}.attn_v.weight")));
+ names.push(Some(format!("blk.{i}.attn_output.weight")));
+ names.push(Some(format!("blk.{i}.ffn_gate.weight")));
+ names.push(Some(format!("blk.{i}.ffn_up.weight")));
+ names.push(Some(format!("blk.{i}.ffn_down.weight")));
+ }
+ Ok(names)
+ }
}
impl NormalModel for Model {
@@ -751,6 +785,9 @@ impl NormalModel for Model {
fn cache(&self) -> &EitherCache {
&self.cache
}
+ fn cache_mut(&mut self) -> &mut EitherCache {
+ &mut self.cache
+ }
fn device(&self) -> &Device {
&self.device
}
diff --git a/mistralrs-core/src/models/llama.rs b/mistralrs-core/src/models/llama.rs
index 5e56a1cce8..2f298c9fca 100644
--- a/mistralrs-core/src/models/llama.rs
+++ b/mistralrs-core/src/models/llama.rs
@@ -123,9 +123,8 @@ impl CausalSelfAttention {
}
let mut y = match &self.paged_attn {
- Some(paged_attn) => {
- let ((key_cache, value_cache), input_metadata) = metadata.unwrap();
- paged_attn.forward(
+ Some(paged_attn) => match metadata {
+ Some(((key_cache, value_cache), input_metadata)) => paged_attn.forward(
&q,
&k,
&v,
@@ -134,8 +133,26 @@ impl CausalSelfAttention {
Some(value_cache),
input_metadata,
None,
- )?
- }
+ )?,
+ None => {
+ let mut input_metadata = PagedAttentionInputMetadata {
+ block_tables: None,
+ context_lens: None,
+ max_context_len: None,
+ slot_mappings: Tensor::new(&[0f32], q.device())?,
+ };
+ paged_attn.forward(
+ &q,
+ &k,
+ &v,
+ attention_mask.clone().as_ref(),
+ None,
+ None,
+ &mut input_metadata,
+ None,
+ )?
+ }
+ },
None => {
let (k, v) = kv_cache.append(&k, &v)?;
@@ -427,9 +444,9 @@ impl Llama {
) -> Result {
if let Some(ref quant_cfg) = &cfg.quantization_config {
tracing::info!(
- "Using {} quantization in {} bits.",
+ "Using {} quantization: {}.",
quant_cfg.quant_method.to_string(),
- quant_cfg.bits
+ quant_cfg.get_bits_name(&vb_m)
);
}
let mapper = normal_loading_metadata.mapper;
@@ -647,6 +664,23 @@ impl IsqModel for Llama {
uvb.to_safetensors()
}
+
+ fn imatrix_names(&self) -> candle_core::Result>> {
+ // NOTE: dependant on the exact implementation in get_layers!
+ let mut names = Vec::new();
+ // lm_head
+ names.push(None);
+ for i in 0..self.blocks.len() {
+ names.push(Some(format!("blk.{i}.attn_q.weight")));
+ names.push(Some(format!("blk.{i}.attn_k.weight")));
+ names.push(Some(format!("blk.{i}.attn_v.weight")));
+ names.push(Some(format!("blk.{i}.attn_output.weight")));
+ names.push(Some(format!("blk.{i}.ffn_gate.weight")));
+ names.push(Some(format!("blk.{i}.ffn_up.weight")));
+ names.push(Some(format!("blk.{i}.ffn_down.weight")));
+ }
+ Ok(names)
+ }
}
impl NormalModel for Llama {
@@ -689,6 +723,9 @@ impl NormalModel for Llama {
fn cache(&self) -> &crate::pipeline::EitherCache {
&self.kv_cache
}
+ fn cache_mut(&mut self) -> &mut crate::pipeline::EitherCache {
+ &mut self.kv_cache
+ }
fn device(&self) -> &Device {
&self.device
}
diff --git a/mistralrs-core/src/models/mistral.rs b/mistralrs-core/src/models/mistral.rs
index 7e14a9f158..968364ab1a 100644
--- a/mistralrs-core/src/models/mistral.rs
+++ b/mistralrs-core/src/models/mistral.rs
@@ -284,9 +284,8 @@ impl Attention {
}
let mut attn_output = match &self.paged_attn {
- Some(paged_attn) => {
- let ((key_cache, value_cache), input_metadata) = metadata.unwrap();
- paged_attn.forward(
+ Some(paged_attn) => match metadata {
+ Some(((key_cache, value_cache), input_metadata)) => paged_attn.forward(
&q,
&k,
&v,
@@ -295,8 +294,26 @@ impl Attention {
Some(value_cache),
input_metadata,
None,
- )?
- }
+ )?,
+ None => {
+ let mut input_metadata = PagedAttentionInputMetadata {
+ block_tables: None,
+ context_lens: None,
+ max_context_len: None,
+ slot_mappings: Tensor::new(&[0f32], q.device())?,
+ };
+ paged_attn.forward(
+ &q,
+ &k,
+ &v,
+ attention_mask,
+ None,
+ None,
+ &mut input_metadata,
+ None,
+ )?
+ }
+ },
None => {
let (k, v, attn_mask) =
kv_cache.append_sliding_window(&k, &v, attention_mask, self.sliding_window)?;
@@ -444,9 +461,9 @@ impl Model {
) -> Result {
if let Some(ref quant_cfg) = &cfg.quantization_config {
tracing::info!(
- "Using {} quantization in {} bits.",
+ "Using {} quantization: {}.",
quant_cfg.quant_method.to_string(),
- quant_cfg.bits
+ quant_cfg.get_bits_name(&vb_m)
);
}
let mapper = normal_loading_metadata.mapper;
@@ -674,6 +691,23 @@ impl IsqModel for Model {
uvb.to_safetensors()
}
+
+ fn imatrix_names(&self) -> candle_core::Result>> {
+ // NOTE: dependant on the exact implementation in get_layers!
+ let mut names = Vec::new();
+ // lm_head
+ names.push(None);
+ for i in 0..self.layers.len() {
+ names.push(Some(format!("blk.{i}.attn_q.weight")));
+ names.push(Some(format!("blk.{i}.attn_k.weight")));
+ names.push(Some(format!("blk.{i}.attn_v.weight")));
+ names.push(Some(format!("blk.{i}.attn_output.weight")));
+ names.push(Some(format!("blk.{i}.ffn_gate.weight")));
+ names.push(Some(format!("blk.{i}.ffn_up.weight")));
+ names.push(Some(format!("blk.{i}.ffn_down.weight")));
+ }
+ Ok(names)
+ }
}
impl NormalModel for Model {
@@ -716,6 +750,9 @@ impl NormalModel for Model {
fn cache(&self) -> &EitherCache {
&self.cache
}
+ fn cache_mut(&mut self) -> &mut EitherCache {
+ &mut self.cache
+ }
fn device(&self) -> &Device {
&self.device
}
diff --git a/mistralrs-core/src/models/mixtral.rs b/mistralrs-core/src/models/mixtral.rs
index b3fd89053a..732615341e 100644
--- a/mistralrs-core/src/models/mixtral.rs
+++ b/mistralrs-core/src/models/mixtral.rs
@@ -179,9 +179,8 @@ impl Attention {
}
let mut attn_output = match &self.paged_attn {
- Some(paged_attn) => {
- let ((key_cache, value_cache), input_metadata) = metadata.unwrap();
- paged_attn.forward(
+ Some(paged_attn) => match metadata {
+ Some(((key_cache, value_cache), input_metadata)) => paged_attn.forward(
&q,
&k,
&v,
@@ -190,8 +189,26 @@ impl Attention {
Some(value_cache),
input_metadata,
None,
- )?
- }
+ )?,
+ None => {
+ let mut input_metadata = PagedAttentionInputMetadata {
+ block_tables: None,
+ context_lens: None,
+ max_context_len: None,
+ slot_mappings: Tensor::new(&[0f32], q.device())?,
+ };
+ paged_attn.forward(
+ &q,
+ &k,
+ &v,
+ attention_mask,
+ None,
+ None,
+ &mut input_metadata,
+ None,
+ )?
+ }
+ },
None => {
let (k, v, attn_mask) =
kv_cache.append_sliding_window(&k, &v, attention_mask, self.sliding_window)?;
@@ -477,9 +494,9 @@ impl Model {
) -> Result {
if let Some(ref quant_cfg) = &cfg.quantization_config {
tracing::info!(
- "Using {} quantization in {} bits.",
+ "Using {} quantization: {}.",
quant_cfg.quant_method.to_string(),
- quant_cfg.bits
+ quant_cfg.get_bits_name(&vb)
);
}
let mapper = normal_loading_metadata.mapper;
@@ -720,6 +737,9 @@ impl NormalModel for Model {
fn cache(&self) -> &EitherCache {
&self.cache
}
+ fn cache_mut(&mut self) -> &mut EitherCache {
+ &mut self.cache
+ }
fn device(&self) -> &Device {
&self.device
}
diff --git a/mistralrs-core/src/models/phi2.rs b/mistralrs-core/src/models/phi2.rs
index ca751f6cf2..4c7b3f58d8 100644
--- a/mistralrs-core/src/models/phi2.rs
+++ b/mistralrs-core/src/models/phi2.rs
@@ -303,9 +303,8 @@ impl Attention {
}
let mut attn_output = match &self.paged_attn {
- Some(paged_attn) => {
- let ((key_cache, value_cache), input_metadata) = metadata.unwrap();
- paged_attn.forward(
+ Some(paged_attn) => match metadata {
+ Some(((key_cache, value_cache), input_metadata)) => paged_attn.forward(
&q,
&k,
&v,
@@ -314,8 +313,17 @@ impl Attention {
Some(value_cache),
input_metadata,
None,
- )?
- }
+ )?,
+ None => {
+ let mut input_metadata = PagedAttentionInputMetadata {
+ block_tables: None,
+ context_lens: None,
+ max_context_len: None,
+ slot_mappings: Tensor::new(&[0f32], q.device())?,
+ };
+ paged_attn.forward(&q, &k, &v, mask, None, None, &mut input_metadata, None)?
+ }
+ },
None => {
let (k, v) = kv_cache.append(&k, &v)?;
@@ -425,9 +433,9 @@ impl Model {
) -> Result {
if let Some(ref quant_cfg) = &cfg.quantization_config {
tracing::info!(
- "Using {} quantization in {} bits.",
+ "Using {} quantization: {}.",
quant_cfg.quant_method.to_string(),
- quant_cfg.bits
+ quant_cfg.get_bits_name(&vb)
);
}
let mapper = normal_loading_metadata.mapper;
@@ -657,6 +665,9 @@ impl NormalModel for Model {
fn cache(&self) -> &EitherCache {
&self.cache
}
+ fn cache_mut(&mut self) -> &mut EitherCache {
+ &mut self.cache
+ }
fn device(&self) -> &Device {
&self.device
}
diff --git a/mistralrs-core/src/models/phi3.rs b/mistralrs-core/src/models/phi3.rs
index 95c883ade0..179b8a215d 100644
--- a/mistralrs-core/src/models/phi3.rs
+++ b/mistralrs-core/src/models/phi3.rs
@@ -185,9 +185,8 @@ impl Attention {
.forward(&q, &k, seqlen_offsets, position_ids)?;
let mut attn_output = match &self.paged_attn {
- Some(paged_attn) => {
- let ((key_cache, value_cache), input_metadata) = metadata.unwrap();
- paged_attn.forward(
+ Some(paged_attn) => match metadata {
+ Some(((key_cache, value_cache), input_metadata)) => paged_attn.forward(
&q,
&k,
&v,
@@ -196,8 +195,26 @@ impl Attention {
Some(value_cache),
input_metadata,
None,
- )?
- }
+ )?,
+ None => {
+ let mut input_metadata = PagedAttentionInputMetadata {
+ block_tables: None,
+ context_lens: None,
+ max_context_len: None,
+ slot_mappings: Tensor::new(&[0f32], q.device())?,
+ };
+ paged_attn.forward(
+ &q,
+ &k,
+ &v,
+ attention_mask,
+ None,
+ None,
+ &mut input_metadata,
+ None,
+ )?
+ }
+ },
_ => {
let (k, v, attn_mask) =
kv_cache.append_sliding_window(&k, &v, attention_mask, self.sliding_window)?;
@@ -418,9 +435,9 @@ impl Model {
) -> Result {
if let Some(ref quant_cfg) = &cfg.quantization_config {
tracing::info!(
- "Using {} quantization in {} bits.",
+ "Using {} quantization: {}.",
quant_cfg.quant_method.to_string(),
- quant_cfg.bits
+ quant_cfg.get_bits_name(&vb)
);
}
let mapper = normal_loading_metadata.mapper;
@@ -612,6 +629,21 @@ impl IsqModel for Model {
uvb.to_safetensors()
}
+
+ fn imatrix_names(&self) -> candle_core::Result>> {
+ // NOTE: dependant on the exact implementation in get_layers!
+ let mut names = Vec::new();
+ // lm_head
+ names.push(None);
+ for i in 0..self.layers.len() {
+ names.push(Some(format!("blk.{i}.attn_qkv.weight")));
+ names.push(Some(format!("blk.{i}.attn_output.weight")));
+ names.push(Some(format!("blk.{i}.ffn_gate.weight")));
+ names.push(Some(format!("blk.{i}.ffn_up.weight")));
+ names.push(Some(format!("blk.{i}.ffn_down.weight")));
+ }
+ Ok(names)
+ }
}
impl NormalModel for Model {
@@ -654,6 +686,9 @@ impl NormalModel for Model {
fn cache(&self) -> &EitherCache {
&self.cache
}
+ fn cache_mut(&mut self) -> &mut EitherCache {
+ &mut self.cache
+ }
fn device(&self) -> &Device {
&self.device
}
diff --git a/mistralrs-core/src/models/phi3_5_moe.rs b/mistralrs-core/src/models/phi3_5_moe.rs
index 9ad8817475..d2d197f9cf 100644
--- a/mistralrs-core/src/models/phi3_5_moe.rs
+++ b/mistralrs-core/src/models/phi3_5_moe.rs
@@ -198,9 +198,8 @@ impl Attention {
.forward(&q, &k, seqlen_offsets, position_ids)?;
let mut attn_output = match &self.paged_attn {
- Some(paged_attn) => {
- let ((key_cache, value_cache), input_metadata) = metadata.unwrap();
- paged_attn.forward(
+ Some(paged_attn) => match metadata {
+ Some(((key_cache, value_cache), input_metadata)) => paged_attn.forward(
&q,
&k,
&v,
@@ -209,8 +208,26 @@ impl Attention {
Some(value_cache),
input_metadata,
None,
- )?
- }
+ )?,
+ None => {
+ let mut input_metadata = PagedAttentionInputMetadata {
+ block_tables: None,
+ context_lens: None,
+ max_context_len: None,
+ slot_mappings: Tensor::new(&[0f32], q.device())?,
+ };
+ paged_attn.forward(
+ &q,
+ &k,
+ &v,
+ attention_mask,
+ None,
+ None,
+ &mut input_metadata,
+ None,
+ )?
+ }
+ },
_ => {
let (k, v, attn_mask) =
kv_cache.append_sliding_window(&k, &v, attention_mask, self.sliding_window)?;
@@ -546,9 +563,9 @@ impl Model {
) -> Result {
if let Some(ref quant_cfg) = &cfg.quantization_config {
tracing::info!(
- "Using {} quantization in {} bits.",
+ "Using {} quantization: {}.",
quant_cfg.quant_method.to_string(),
- quant_cfg.bits
+ quant_cfg.get_bits_name(&vb)
);
}
let mapper = normal_loading_metadata.mapper;
@@ -816,6 +833,9 @@ impl NormalModel for Model {
fn cache(&self) -> &EitherCache {
&self.cache
}
+ fn cache_mut(&mut self) -> &mut EitherCache {
+ &mut self.cache
+ }
fn device(&self) -> &Device {
&self.device
}
diff --git a/mistralrs-core/src/models/qwen2.rs b/mistralrs-core/src/models/qwen2.rs
index 0264aa9aea..c694420f58 100644
--- a/mistralrs-core/src/models/qwen2.rs
+++ b/mistralrs-core/src/models/qwen2.rs
@@ -276,9 +276,8 @@ impl Attention {
}
let mut attn_output = match &self.paged_attn {
- Some(paged_attn) => {
- let ((key_cache, value_cache), input_metadata) = metadata.unwrap();
- paged_attn.forward(
+ Some(paged_attn) => match metadata {
+ Some(((key_cache, value_cache), input_metadata)) => paged_attn.forward(
&q,
&k,
&v,
@@ -287,8 +286,26 @@ impl Attention {
Some(value_cache),
input_metadata,
None,
- )?
- }
+ )?,
+ None => {
+ let mut input_metadata = PagedAttentionInputMetadata {
+ block_tables: None,
+ context_lens: None,
+ max_context_len: None,
+ slot_mappings: Tensor::new(&[0f32], q.device())?,
+ };
+ paged_attn.forward(
+ &q,
+ &k,
+ &v,
+ attention_mask,
+ None,
+ None,
+ &mut input_metadata,
+ None,
+ )?
+ }
+ },
None => {
let (k, v) = kv_cache.append(&k, &v)?;
@@ -415,9 +432,9 @@ impl Model {
) -> Result {
if let Some(ref quant_cfg) = &cfg.quantization_config {
tracing::info!(
- "Using {} quantization in {} bits.",
+ "Using {} quantization: {}.",
quant_cfg.quant_method.to_string(),
- quant_cfg.bits
+ quant_cfg.get_bits_name(&vb)
);
}
let mapper = normal_loading_metadata.mapper;
@@ -620,6 +637,23 @@ impl IsqModel for Model {
uvb.to_safetensors()
}
+
+ fn imatrix_names(&self) -> candle_core::Result>> {
+ // NOTE: dependant on the exact implementation in get_layers!
+ let mut names = Vec::new();
+ // lm_head
+ names.push(None);
+ for i in 0..self.layers.len() {
+ names.push(Some(format!("blk.{i}.attn_q.weight")));
+ names.push(Some(format!("blk.{i}.attn_k.weight")));
+ names.push(Some(format!("blk.{i}.attn_v.weight")));
+ names.push(Some(format!("blk.{i}.attn_output.weight")));
+ names.push(Some(format!("blk.{i}.ffn_gate.weight")));
+ names.push(Some(format!("blk.{i}.ffn_up.weight")));
+ names.push(Some(format!("blk.{i}.ffn_down.weight")));
+ }
+ Ok(names)
+ }
}
impl NormalModel for Model {
@@ -662,6 +696,9 @@ impl NormalModel for Model {
fn cache(&self) -> &EitherCache {
&self.cache
}
+ fn cache_mut(&mut self) -> &mut EitherCache {
+ &mut self.cache
+ }
fn device(&self) -> &Device {
&self.device
}
diff --git a/mistralrs-core/src/models/starcoder2.rs b/mistralrs-core/src/models/starcoder2.rs
index d47f6da2e5..8262fcccf3 100644
--- a/mistralrs-core/src/models/starcoder2.rs
+++ b/mistralrs-core/src/models/starcoder2.rs
@@ -269,9 +269,8 @@ impl Attention {
}
let mut attn_output = match &self.paged_attn {
- Some(paged_attn) => {
- let ((key_cache, value_cache), input_metadata) = metadata.unwrap();
- paged_attn.forward(
+ Some(paged_attn) => match metadata {
+ Some(((key_cache, value_cache), input_metadata)) => paged_attn.forward(
&q,
&k,
&v,
@@ -280,8 +279,26 @@ impl Attention {
Some(value_cache),
input_metadata,
None,
- )?
- }
+ )?,
+ None => {
+ let mut input_metadata = PagedAttentionInputMetadata {
+ block_tables: None,
+ context_lens: None,
+ max_context_len: None,
+ slot_mappings: Tensor::new(&[0f32], q.device())?,
+ };
+ paged_attn.forward(
+ &q,
+ &k,
+ &v,
+ attention_mask,
+ None,
+ None,
+ &mut input_metadata,
+ None,
+ )?
+ }
+ },
None => {
let (k, v, attn_mask) =
kv_cache.append_sliding_window(&k, &v, attention_mask, self.sliding_window)?;
@@ -409,9 +426,9 @@ impl Model {
) -> Result {
if let Some(ref quant_cfg) = &cfg.quantization_config {
tracing::info!(
- "Using {} quantization in {} bits.",
+ "Using {} quantization: {}.",
quant_cfg.quant_method.to_string(),
- quant_cfg.bits
+ quant_cfg.get_bits_name(&vb)
);
}
let mapper = normal_loading_metadata.mapper;
@@ -644,6 +661,9 @@ impl NormalModel for Model {
fn cache(&self) -> &EitherCache {
&self.cache
}
+ fn cache_mut(&mut self) -> &mut EitherCache {
+ &mut self.cache
+ }
fn device(&self) -> &Device {
&self.device
}
diff --git a/mistralrs-core/src/pipeline/amoe.rs b/mistralrs-core/src/pipeline/amoe.rs
index 51df4f1bc6..5fb9a1d6be 100644
--- a/mistralrs-core/src/pipeline/amoe.rs
+++ b/mistralrs-core/src/pipeline/amoe.rs
@@ -381,7 +381,7 @@ impl AnyMoePipelineMixin for AnyMoePipeline {
.map_err(candle_core::Error::msg)?;
let dummy_group = Arc::new(tokio::sync::Mutex::new(SequenceGroup::new(
- 1, false, false, 0,
+ 1, false, false, None,
)));
let mut latest_loss = vec![0.0; optimizers.len()];
@@ -583,7 +583,6 @@ fn new_dummy_seq(
None, // TODO incorrect for PagedAttention
None,
None,
- None,
SeqStepType::PromptAndDecode,
None,
None,
diff --git a/mistralrs-core/src/pipeline/cache_manager.rs b/mistralrs-core/src/pipeline/cache_manager.rs
index b8b4152ef7..fe1b0765bc 100644
--- a/mistralrs-core/src/pipeline/cache_manager.rs
+++ b/mistralrs-core/src/pipeline/cache_manager.rs
@@ -203,7 +203,7 @@ impl KvCache {
}
}
}
- Ok((k, v, None))
+ Ok((k, v, mask.cloned()))
}
pub fn append(&mut self, k: &Tensor, v: &Tensor) -> Result<(Tensor, Tensor)> {
@@ -511,7 +511,7 @@ impl Cache {
}
};
*cache = Some((k.clone(), v.clone()));
- Ok((k, v))
+ Ok((k.contiguous()?, v.contiguous()?))
}
/// Update the KV cache and return (k,v,attn_mask)
@@ -567,7 +567,7 @@ impl Cache {
}
};
*cache = Some((k.clone(), v.clone()));
- Ok((k, v, attention_mask))
+ Ok((k.contiguous()?, v.contiguous()?, attention_mask))
}
}
diff --git a/mistralrs-core/src/pipeline/diffusion.rs b/mistralrs-core/src/pipeline/diffusion.rs
index 847a0c1bcb..82f48733aa 100644
--- a/mistralrs-core/src/pipeline/diffusion.rs
+++ b/mistralrs-core/src/pipeline/diffusion.rs
@@ -216,7 +216,7 @@ impl Loader for DiffusionLoader {
model_id: self.model_id.clone(),
metadata: Arc::new(GeneralMetadata {
max_seq_len,
- tok_trie: None,
+ tok_env: None,
is_xlora: false,
num_hidden_layers: 1, // FIXME(EricLBuehler): we know this is only for caching, so its OK.
eos_tok: vec![],
diff --git a/mistralrs-core/src/pipeline/ggml.rs b/mistralrs-core/src/pipeline/ggml.rs
index 65f86beb7f..295aa8da2e 100644
--- a/mistralrs-core/src/pipeline/ggml.rs
+++ b/mistralrs-core/src/pipeline/ggml.rs
@@ -1,4 +1,5 @@
use super::cache_manager::FullCacheManager;
+use super::llg::build_tok_env;
use super::{
get_model_paths, get_xlora_paths, text_models_inputs_processor::ModelInputs, AdapterKind,
CacheManager, GeneralMetadata, Loader, ModelKind, ModelPaths, QuantizationKind, TokenSource,
@@ -8,8 +9,6 @@ use super::{
AdapterActivationMixin, AnyMoePipelineMixin, CacheManagerMixin, EitherCache,
ForwardInputsResult, IsqPipelineMixin, MetadataMixin, ModelCategory, PreProcessingMixin,
};
-use crate::aici::bintokens::build_tok_trie;
-use crate::aici::toktree::TokTrie;
use crate::lora::Ordering;
use crate::pipeline::chat_template::{calculate_eos_tokens, GenerationConfig};
use crate::pipeline::get_chat_template;
@@ -347,9 +346,10 @@ impl Loader for GGMLLoader {
};
let tokenizer = get_tokenizer(paths.get_tokenizer_filename(), None)?;
- let gen_conf: Option = paths
- .get_gen_conf_filename()
- .map(|f| serde_json::from_str(&fs::read_to_string(f).unwrap()).unwrap());
+ let gen_conf: Option = paths.get_gen_conf_filename().map(|f| {
+ serde_json::from_str(&fs::read_to_string(f).unwrap())
+ .expect("bos_token_id/eos_token_id missing in generation_config.json")
+ });
let chat_template = get_chat_template(
paths,
&paths
@@ -365,7 +365,7 @@ impl Loader for GGMLLoader {
Model::Llama(ref l) => l.max_seq_len,
Model::XLoraLlama(ref xl) => xl.max_seq_len,
};
- let tok_trie: Arc = build_tok_trie(tokenizer.clone()).into();
+ let tok_env = build_tok_env(tokenizer.clone());
let num_hidden_layers = match model {
Model::Llama(ref model) => model.cache.normal().0.len(),
Model::XLoraLlama(ref model) => model.cache.full().lock().len(),
@@ -385,7 +385,7 @@ impl Loader for GGMLLoader {
}),
metadata: Arc::new(GeneralMetadata {
max_seq_len,
- tok_trie: Some(tok_trie),
+ tok_env: Some(tok_env),
has_no_kv_cache: self.no_kv_cache,
num_hidden_layers,
eos_tok: eos,
diff --git a/mistralrs-core/src/pipeline/gguf.rs b/mistralrs-core/src/pipeline/gguf.rs
index 465344a39f..e8b875c859 100644
--- a/mistralrs-core/src/pipeline/gguf.rs
+++ b/mistralrs-core/src/pipeline/gguf.rs
@@ -1,4 +1,5 @@
use super::cache_manager::{FullCacheManager, NormalCacheManager};
+use super::llg::build_tok_env;
use super::{
get_model_paths, get_xlora_paths, text_models_inputs_processor::ModelInputs, AdapterKind,
CacheManager, GeneralMetadata, Loader, ModelKind, ModelPaths, PrettyName, QuantizationKind,
@@ -8,8 +9,6 @@ use super::{
AdapterActivationMixin, AnyMoePipelineMixin, CacheManagerMixin, EitherCache,
ForwardInputsResult, IsqPipelineMixin, MetadataMixin, ModelCategory, PreProcessingMixin,
};
-use crate::aici::bintokens::build_tok_trie;
-use crate::aici::toktree::TokTrie;
use crate::gguf::{
get_gguf_chat_template, {convert_gguf_to_hf_tokenizer, GgufTokenizerConversion},
};
@@ -470,9 +469,10 @@ impl Loader for GGUFLoader {
(None, None)
};
- let gen_conf: Option = paths
- .get_gen_conf_filename()
- .map(|f| serde_json::from_str(&fs::read_to_string(f).unwrap()).unwrap());
+ let gen_conf: Option = paths.get_gen_conf_filename().map(|f| {
+ serde_json::from_str(&fs::read_to_string(f).unwrap())
+ .expect("bos_token_id/eos_token_id missing in generation_config.json")
+ });
let mut chat_template = get_chat_template(
paths,
&paths
@@ -493,7 +493,7 @@ impl Loader for GGUFLoader {
Model::Starcoder2(ref p) => p.max_seq_len,
Model::Qwen2(ref p) => p.max_seq_len,
};
- let tok_trie: Arc = build_tok_trie(tokenizer.clone()).into();
+ let tok_env = build_tok_env(tokenizer.clone());
let num_hidden_layers = match model {
Model::Llama(ref model) => model.cache.normal().0.len(),
Model::Phi2(ref model) => model.cache.normal().0.len(),
@@ -532,7 +532,7 @@ impl Loader for GGUFLoader {
}),
metadata: Arc::new(GeneralMetadata {
max_seq_len,
- tok_trie: Some(tok_trie),
+ tok_env: Some(tok_env),
has_no_kv_cache: self.no_kv_cache,
num_hidden_layers,
eos_tok: eos,
diff --git a/mistralrs-core/src/pipeline/inputs_processor.rs b/mistralrs-core/src/pipeline/inputs_processor.rs
index e7db4a92ed..c54d23b1a3 100644
--- a/mistralrs-core/src/pipeline/inputs_processor.rs
+++ b/mistralrs-core/src/pipeline/inputs_processor.rs
@@ -120,10 +120,10 @@ pub mod text_models_inputs_processor {
// chunk_offset_toks is the number of tokens by which the tokens are offset,
// chunk_offset_toks / prompt_batchsize = number of batches
- fn make_prompt_chunk(
+ pub fn make_prompt_chunk(
chunk_offset_toks: usize,
toks: Vec>,
- input_seqs: &[&Sequence],
+ seq_ids: &[usize],
device: &Device,
last_n_context_len: Option<(usize, usize)>,
return_raw_logits: bool,
@@ -145,7 +145,7 @@ pub mod text_models_inputs_processor {
let mut paged_attn_context_lens = Vec::new();
let mut seqlens_q = vec![0];
let mut seqlens_k = vec![0];
- for (seq, mut ctxt) in input_seqs.iter().zip(toks) {
+ for (seq_id, mut ctxt) in seq_ids.iter().zip(toks) {
let prompt_len = ctxt.len();
let offset = last_n_context_len.unwrap_or_default();
seqlen_offsets.push(offset.1 + chunk_offset_toks);
@@ -172,7 +172,7 @@ pub mod text_models_inputs_processor {
seqs_tensors.push(Tensor::new(ctxt, device).unwrap().unsqueeze(0).unwrap());
if let Some(paged_attn_metadata) = &mut paged_attn_metadata {
- let table = paged_attn_metadata.block_engine.block_tables.get(seq.id());
+ let table = paged_attn_metadata.block_engine.block_tables.get(seq_id);
if table.is_none() {
// Will be None during profiling.
@@ -510,7 +510,10 @@ pub mod text_models_inputs_processor {
make_prompt_chunk(
i * prompt_batchsize,
toks,
- &seq_ns.iter().map(|i| &*input_seqs[*i]).collect::>(),
+ &seq_ns
+ .iter()
+ .map(|i| *input_seqs[*i].id())
+ .collect::>(),
device,
last_n_context_len,
return_raw_logits,
@@ -534,7 +537,7 @@ pub mod text_models_inputs_processor {
make_prompt_chunk(
0,
toks,
- &input_seqs.iter().map(|s| &**s).collect::>(),
+ &input_seqs.iter().map(|s| *s.id()).collect::>(),
device,
last_n_context_len,
return_raw_logits,
diff --git a/mistralrs-core/src/pipeline/isq.rs b/mistralrs-core/src/pipeline/isq.rs
index 3fc20876ab..4950ae7708 100644
--- a/mistralrs-core/src/pipeline/isq.rs
+++ b/mistralrs-core/src/pipeline/isq.rs
@@ -9,8 +9,9 @@ use std::{
};
use anyhow::Result;
-use candle_core::{Context, Device, Tensor};
+use candle_core::{quantized, Context, Device, Tensor};
use indicatif::{ParallelProgressIterator, ProgressBar, ProgressStyle};
+use itertools::Itertools;
use mistralrs_quant::{
FP8Linear, GgufMatMul, HqqLayer, IsqType, QuantMethod, QuantizedSerde, QuantizedSerdeType,
UnquantLinear,
@@ -124,6 +125,11 @@ pub struct UqffFullSer<'a> {
pub preprocessor_filename: &'a Option,
}
+pub enum ImatrixDataSource<'a> {
+ File(&'a PathBuf),
+ Collected,
+}
+
pub trait IsqModel {
/// Corresponds to `IsqOrganization::Default`
#[allow(clippy::type_complexity)]
@@ -134,6 +140,36 @@ pub trait IsqModel {
&dyn DeviceMapper,
);
+ /// This is used for imatrix generation internally. Begin stats tracking.
+ fn begin_track_stats(&mut self) -> anyhow::Result<()> {
+ let layers = self
+ .get_layers()
+ .0
+ .into_iter()
+ .map(|(layer, _)| layer)
+ .collect::>();
+ for layer in layers {
+ Arc::get_mut(layer).unwrap().begin_track_stats()?;
+ }
+ Ok(())
+ }
+
+ /// End stats tracking and return the imatrix data
+ fn extract_imatrix_data(&mut self) -> candle_core::Result>>> {
+ let layers = self
+ .get_layers()
+ .0
+ .into_iter()
+ .enumerate()
+ .map(|(i, (layer, _))| (i, layer))
+ .collect::>();
+ let mut data = HashMap::new();
+ for (i, layer) in layers {
+ data.insert(i, Some(layer.end_track_stats()?.to_vec1::()?));
+ }
+ Ok(data)
+ }
+
/// Corresponds to `IsqOrganization::MoeExpertsOnly`
/// https://arxiv.org/abs/2310.02410
#[allow(clippy::type_complexity)]
@@ -146,6 +182,51 @@ pub trait IsqModel {
self.get_layers()
}
+ /// Corresponds to `IsqOrganization::MoeExpertsOnly`
+ /// This is used for imatrix generation internally. Begin stats tracking.
+ fn begin_track_stats_moe_experts_only(&mut self) -> anyhow::Result<()> {
+ let layers = self
+ .get_layers()
+ .0
+ .into_iter()
+ .map(|(layer, _)| layer)
+ .collect::>();
+ for layer in layers {
+ Arc::get_mut(layer).unwrap().begin_track_stats()?;
+ }
+ Ok(())
+ }
+
+ /// Corresponds to `IsqOrganization::MoeExpertsOnly`
+ /// End stats tracking and return the imatrix data
+ fn extract_imatrix_data_moe_experts_only(
+ &mut self,
+ ) -> candle_core::Result>>> {
+ let layers = self
+ .get_layers()
+ .0
+ .into_iter()
+ .enumerate()
+ .map(|(i, (layer, _))| (i, layer))
+ .collect::>();
+ let mut data = HashMap::new();
+ for (i, layer) in layers {
+ data.insert(i, Some(layer.end_track_stats()?.to_vec1::()?));
+ }
+ Ok(data)
+ }
+
+ /// Corresponding to the specific order the model produces ISQ layers (None means
+ /// do not search for in the imatrix file). This is used to pair ISQ layers with the
+ /// corresponding imatrix weights.
+ ///
+ /// - This is only for loading from a llama.cpp imatrix file.
+ /// - Corresponds to `IsqOrganization::Default`
+ fn imatrix_names(&self) -> candle_core::Result>> {
+ // TODO: make this required.
+ candle_core::bail!("This model does not support quantizing with an imatrix.");
+ }
+
/// Residual tensors for generating a UQFF file. Counterpart to [`get_layers`].
fn residual_tensors(&self) -> Vec<(String, Tensor)>;
@@ -165,16 +246,77 @@ pub trait IsqModel {
device: Device,
topology: Option<&Topology>,
silent: bool,
+ imatrix_source: Option>,
organization: IsqOrganization,
write_artifacts: Option<&PathBuf>,
full_ser: UqffFullSer<'_>,
) -> candle_core::Result<()> {
{
+ let imatrix_to_weight = match imatrix_source {
+ Some(ImatrixDataSource::File(imatrix)) => {
+ let mut imatrix_data = quantized::imatrix_file::load_imatrix(imatrix.clone())?;
+ let imatrix_mapping = self
+ .imatrix_names()?
+ .into_iter()
+ .enumerate()
+ .collect::>();
+
+ let layer_to_weight = imatrix_mapping
+ .into_iter()
+ .map(|(i, name)| {
+ if let Some(name) = name {
+ (i, Some(imatrix_data.remove(&name).unwrap()))
+ } else {
+ (i, None)
+ }
+ })
+ .collect::>();
+ info!(
+ "Quantizing with imatrix file `{}`, {} imatrix weights",
+ imatrix.display(),
+ layer_to_weight.iter().filter(|(_, x)| x.is_some()).count()
+ );
+ Some(layer_to_weight)
+ }
+ Some(ImatrixDataSource::Collected) => {
+ let data = match organization {
+ IsqOrganization::Default => self.extract_imatrix_data()?,
+ IsqOrganization::MoeExpertsOnly => {
+ self.extract_imatrix_data_moe_experts_only()?
+ }
+ };
+ info!(
+ "Quantizing with collected imatrix data, {} imatrix weights",
+ data.iter().filter(|(_, x)| x.is_some()).count()
+ );
+ Some(data)
+ }
+ None => {
+ // Dummy, just for zip
+ None
+ }
+ };
+
let (mut tensors, mapper) = match organization {
IsqOrganization::Default => self.get_layers(),
IsqOrganization::MoeExpertsOnly => self.get_layers_moe_experts_only(),
};
+ let imatrix_to_weight: Vec