This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
(defn lazy-seq* [reducible] | |
(let [c (chan) | |
NIL (Object.) | |
encode-nil #(if (nil? %) NIL %) | |
decode-nil #(if (identical? NIL %) nil %) | |
reduce-fn (fn [r v] (>!! c (encode-nil v)))] | |
(thread | |
(reduce reduce-fn nil reducible) | |
(close! c)) | |
(->> #(<!! c) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
;; machine: amd64 Linux 2.6.32-48-server 16 cpu(s) | |
;; Java HotSpot(TM) 64-Bit Server VM 23.25-b01 | |
;; | |
;; == without lazy seq realization | |
;; regex split: 258.567183 ms | |
;; parallelized regex split: 65.053176 ms - lazy seqs are not realized! | |
;; correct reduce: 623.541446 ms | |
;; correct fold: 252.817020 ms | |
;; | |
;; == lazy seq realization with (into [] %) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
// original | |
int CheckExtension (char *filename, char *ext) | |
{ | |
char *s; | |
if (!filename) return(0); | |
if (strlen(filename) == 0) return(0); | |
s = strrchr(filename,'.'); | |
if (!s) return(0); | |
if (!strcmp(s,ext)) return(1); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
(require '[clojure.java.io :as jio]) | |
(deftype Slurp [filename] | |
clojure.core.protocols/CollReduce | |
(coll-reduce [this f1] | |
(clojure.core.protocols/coll-reduce this f1 (f1))) | |
(coll-reduce [_ f1 init] | |
(with-open [#^java.io.Reader r | |
(apply jio/reader filename nil)] | |
(loop [ret init |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Type Error (user:1:5) Polymorphic function clojure.core/merge could not be applied to arguments: | |
Polymorphic Variables: | |
k36143 | |
v36144 | |
Domains: | |
nil * | |
(clojure.lang.IPersistentMap k v) (clojure.lang.IPersistentMap k v) * | |
(Option (clojure.lang.IPersistentMap k v)) * |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
;; AOT before loading (e.g. with :aot :all in project.clj) | |
;; $ lein deps :tree | |
;; [clojure-complete "0.2.3" :exclusions [[org.clojure/clojure]]] | |
;; [org.clojure/clojure "1.5.1"] | |
;; [org.clojure/tools.nrepl "0.2.3" :exclusions [[org.clojure/clojure]]] | |
(ns ccc.core | |
(:gen-class)) | |
(defprotocol P) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
(ns foo.bar | |
(:use [quil.core]) | |
(:require [clojure.string :as s])) | |
(defn setup [] | |
(frame-rate 1) | |
(background 255)) | |
(def *scale* 2) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
(defprotocol IMutable | |
(-cas! [o oldval newval] | |
"Sets the value to newval if and only if the current value | |
is identical to oldval. Returns true if set happened, | |
otherwse returns false. Mutates `o`.") | |
(-alter! [o f] [o f x] [o f x y] [o f x y z] [o f x y z args] | |
"Changes referenced value with (apply f val args). | |
Returns new value. Mutates `o`.") | |
(-reset! [o val] | |
"Resets the referenced value to `val`. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
(defn update-in* | |
[m [k & ks] f & args] | |
(let [k (if (and (instance? clojure.lang.Indexed m) | |
(integer? k) | |
(neg? k)) | |
(+ (count m) k) | |
k)] | |
(if ks | |
(assoc m k (apply update-in* (get m k) ks f args)) | |
(assoc m k (apply f (get m k) args))))) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
;; Input vector of bytes | |
(def vec (into (vector-of :byte) | |
(repeatedly 1000000 #(rand-int 128)))) | |
;; Output file | |
(def out (java.io.FileOutputStream. "out.bin")) | |
;; Classic reduction -> 3835 ms | |
(let [write-fn (fn [r w] (.write out w))] | |
(time (reduce write-fn nil (map dec vec)))) |
OlderNewer