sin

Kava: from ethnology to pharmacology / edited by Yadhu N. Singh

Online Resource




sin

Unit Operation in Downstream Processing / Husnul Azan Tajarudin, Mardiana Idayu Ahmad & Mohd Nazri Ismail

Online Resource




sin

Psychoactive medicinal plants and fungal neurotoxins Amritpal Singh Saroya, Jaswinder Singh

Online Resource




sin

The missing analysis in JavaScript "Real" Mixins

I love hacks and unusual patterns! As logical consequence, I loved this post about "Real" Mixins!!!
The only hitch about that post is that I believe there are few points closer to a "gonna sell you my idea" discussion than a non disillusioned one.
Let's start this counter analysis remembering what are actually classes in latest JavaScript standard, so that we can move on explaining what's missing in there.

JavaScript embraces prototypal inheritance

It doesn't matter if ES6 made the previously reserved class keyword usable; at the end of the day we're dealing with a special syntactical shortcut to enrich a generic prototype object.

// class in ES2015
class A {
constructor() {}
method() {}
get accessor() {}
set accessor(value) {}
}

// where are those methods and properties defined?
console.log(
Object.getOwnPropertyNames(A.prototype)
// ["constructor", "method", "accessor"]
);
Accordingly, declaring a generic class consists in bypassing the following procedure:

function A() {}
Object.defineProperties(
A.prototype,
{
// constructor is implicitly defined
method: {
configurable: true,
writable: true,
value: function method() {}
},
accessor: {
configurable: true,
get: function get() {},
set: function set(value) {}
}
}
);
If you don't trust me, trust what a transpiler would do, summarized in the following code:

var A = (function () {
// the constructor
function A() {
_classCallCheck(this, _temporalAssertDefined(A, "A", _temporalUndefined) && A);
}
// the enriched prototype
_createClass(_temporalAssertDefined(A, "A", _temporalUndefined) && A, [{
key: "method",
value: function method() {}
}, {
key: "accessor",
get: function get() {},
set: function set(value) {}
}]);

return _temporalAssertDefined(A, "A", _temporalUndefined) && A;
})();
If there is some public static property in the definition, its assignment to the constructor would be the second bypassed part.

The super case

The extra bit in terms of syntax that makes ES6 special is the special keyword super. Being multiple inheritance not possible in JavaScript, we could think about super as the static reference to the directly extended prototype. In case of the previous B class, which extends A, we can think about super variable like if it was defined as such:

// used within the constructor
let super = (...args) => A.apply(this, arguments);

// used within any other method
super.method = (...args) => A.prototype.method.apply(this, args);

// used as accessor
Object.defineProperty(super, 'accessor', {
get: () => Object.getOwnPropertyDescriptor(
A.prototype, 'accessor'
).get.call(this),
set: (value) => Object.getOwnPropertyDescriptor(
A.prototype, 'accessor'
).set.call(this, value)
});
Now that we have a decent understanding on how inheritance works in JavaScript and what it means to declare a class, let's talk about few misleading points sold as pros or cons in the mentioned article.

Prototypes are always modified anyway!

We've just seen that defining a class technically means enriching its prototype object. This already invalidates somehow Justin point but there's more to consider.
When Justin exposes his idea on why current solutions are bad, he says that:
When using mixin libraries against prototype objects, the prototypes are directly mutated. This is a problem if the prototype is used anywhere else that the mixed-in properties are not wanted.
The way Justin describes this issue is quite misleading because mutating prototypes at runtime is a well known bad practice.
Indeed, I believe every single library he mentioned in that post, and he also forgot mine, is not designed to mutate classes prototypes at runtime ... like: not at all!
Every single mixin proposal that is capable of implementing mixins via classes is indeed designed to define these classes at definition time, not at runtime!
Moreover, whatever solution Justin proposed will not guard any class from being modified at runtime later on!
The same way he's defining his final classes during their definitions, mixins-for-classes oriented libraries have exactly the same goal: you define your class and its mixins during the class definition time!
The fact mixins add properties to a prototype is a completely hidden matter that at class definition time is everything but bad.
Also, no property is modified in place, because mixins are there to enrich, not to modify ... and having a prototype enriched means also that it's easier to spot name clashing and methods or properties conflicts ... but I'll come back to that later ...

super actually should NOT work!

The main bummer about the article is that it starts in a very reasonable way, describing mixins and classes, and also analyzing their role in a program.
The real, and only, difference between a mixin and normal subclass is that a normal subclass has a fixed superclass, while a mixin definition doesn't yet have a superclass.
Justin started right at the very beginning, and then degenerated with all sort of contradictions such:
Then finally he's back to Sanity Village with the following sentence:
super calls can be a little unintuitive for those new to mixins because the superclass isn't known at mixin definition, and sometimes developers expect super to point to the declared superclass (the parameter to the mixin), not the mixin application.
And on top of that, Justin talks about constructors too:
Constructors are a potential source of confusion with mixins. They essentially behave like methods, except that overriden methods tend to have the same signature, while constructors in a inheritance hierarchy often have different signatures.
In case you're not convinced yet how much messed up could be the situation, I'd like to add extra examples to the plate.
Let's consider the word area and its multiple meanings:
  • any particular extent of space or surface
  • a geographical region
  • any section reserved for a specific function
  • extent, range, or scope
  • field of study, or a branch of a field of study
  • a piece of unoccupied ground; an open space
  • the space or site on which a building stands
Now you really have to tell me in case you implement a basic Shape mixin with an area() method what the hack would you expect when invoking super. Moreoever, you should tell me if for every single method you are going to write within a mixin, you are also going to blindly invoke super with arbitrary amount of arguments in there ...

So here my quick advice about calling blindly a super: NO, followed by DON'T and eventually NEVER!

Oversold super ability

No kidding, and I can't stress this enough ... I've never ever in my life wrote a single mixin that was blindly trusting on a super call. That would be eventually an application based on mixins but that's a completely different story.
My feeling is that Justin tried to combine at all cost different concepts, probably mislead by his Dart background, since mentioned as reference, where composition in Dart was indeed classes based and the lang itself exposes native mixins as classes ... but here again we are in JavaScript!

instanceof what?

Another oversold point in Justin's article is that instanceof works.
This one was easy to spot ... I mean, if you create a class at runtime everytime the mixin is invoked, what exactly are you capable of "instanceoffing" and why would that benefit anyone about anything?
I'm writing down his very same examples here that will obviously all fail:

// a new anonymous class is created each time
// who's gonna benefit about the instanceof?
let MyMixin = (superclass) => class extends superclass {
foo() {
console.log('foo from MyMixin');
}
};

// let's try this class
class MyClass extends MyMixin(MyBaseClass) {
/* ... */
}

// Justin says it's cool that instanceof works ...
(new MyClass) instanceof MyMixin; // false
// false ... really, it can't be an instance of
// an arrow function prototype, isn't it?!
Accordingly, and unless I've misunderstood Justin point in which case I apologies in advance, I'm not sure what's the exact point in having instanceof working. Yes, sure the intermediate class is there, but every time the mixin is used it will create a different class so there's absolutely no advantage in having instanceof working there ... am I right?

Improving **Objects** Composition

In his Improving the Syntax paragraph, Justin exposes a very nice API summarized as such:

let mix = (superclass) => new MixinBuilder(superclass);

class MixinBuilder {
constructor(superclass) {
this.superclass = superclass;
}

with(...mixins) {
return mixins.reduce((c, mixin) => mixin(c), this.superclass);
}
}
Well, this was actually the part I've liked the most about his article, it's a very simple and semantic API, and it also doesn't need classes at all to be implemented for any kind of JS object!
How? Well, simply creating objects from objects instead:

let mix = (object) => ({
with: (...mixins) => mixins.reduce(
(c, mixin) => Object.create(
c, Object.getOwnPropertyDescriptors(mixin)
), object)
});
It could surely be improved in order to deal with classes too but you get the idea:

let a = {a: 'a'};
let b = {b: 'b'};
let c = {c: 'c'};
let d = mix(c).with(a, b);
console.log(d);
Since the main trick in Justin proposal is to place an intermediate class in the inheritance chain, defining at runtime each time the same class and its prototype, I've done something different here that doesn't need to create a new class with its own prototype or object each time, while preserving original functionalities without affecting them.

Less RAM to use, a hopefully coming soon native Object.getOwnPropertyDescriptors that should land in ES7 and make extraction faster, and the ability to use the pattern with pretty much everything out there, modern or old.
The gist is here, feel free to reuse.

As Summary ...

Wrapping up this post, with latter proposal we can actually achieve whatever Justin did with his intermediate classes approach but following different goals:
  1. Mixins are added to the prototype chain.
  2. Mixins are applied without modifying existing objects.
  3. Mixins do no magic, and don't define new semantics on top of the core language.
  4. super.foo property access won't hopefully work within mixins but it will with subclasses methods.
  5. super() calls won't hopefully work in mixins constructors because you've no idea what kind of arguments you are going to receive. Subclasses still work as expected.
  6. Mixins are able to extend other mixins.
  7. instanceof has no reason to be even considered in this scenario since we are composing objects.
  8. Mixin definitions do not require library support - they can be written in a universal style and be compatible with non classes based engines too.
  9. bonus: less memory consumption overall, there's no runtime duplication for the same logic each time
I still want to thanks Justin because he made it quite clear that still not everyone fully understands mixins but there's surely a real-world need, or better demand, in the current JavaScript community.

Let's hope the next version of ECMAScript will let all of us compose in a standard way that doesn't include a footgun like super through intermediate classes definition could do.
Thanks for your patience reading through this!




sin

Hyperspectral remote sensing: fundamentals and practices / Ruiliang Pu

Online Resource




sin

Integrating scale in remote sensing and GIS / [edited by] Dale A. Quattrochi, Elizabeth A. Wentz, Nina Siu-Ngan Lam, Charles W. Emerson

Rotch Library - G70.212.I565 2017




sin

Sustainable tourism on a finite planet: environmental, business and policy solutions / Megan Epler Wood

Dewey Library - G156.5.S87 E64 2017




sin

Comprehensive remote sensing / editor in chief: Shunlin Liang

Online Resource




sin

Spatial Techniques for Soil Erosion Estimation: Remote Sensing and GIS Approach / by Rupesh Jayaram Patil

Online Resource




sin

Geo-Spatial Knowledge and Intelligence: 5th International Conference, GSKI 2017, Chiang Mai, Thailand, December 8-10, 2017, Revised Selected Papers. / edited by Hanning Yuan, Jing Geng, Chuanlu Liu, Fuling Bian, Tisinee Surapunt

Online Resource




sin

QGIS in remote sensing set / edited by Nicolas Baghdadi, Clément Mallet, Mehrez Zribi

Rotch Library - G70.212.Q45 2018




sin

Geo-Spatial Knowledge and Intelligence: 5th International Conference, GSKI 2017, Chiang Mai, Thailand, December 8-10, 2017, Revised Selected Papers. / edited by Hanning Yuan, Jing Geng, Chuanlu Liu, Fuling Bian, Tisinee Surapunt

Online Resource




sin

Remote sensing and cognition: human factors in image interpretation / edited by Raechel A. White, Arzu Coltekin, and Robert R. Hoffman

Online Resource




sin

High spatial resolution remote sensing: data, analysis, and applications / edited by Yuhong He and Qihao Weng

Online Resource




sin

Lidar remote sensing and applications / Pinliang Dong and Qi Chen

Online Resource




sin

LiDAR remote sensing and applications / Pinliang Dong and Qi Chen

Rotch Library - G70.4.D66 2018




sin

Geospatial technologies in land resources mapping, monitoring and management / G.P. Obi Reddy, S.K. Singh, editors

Online Resource




sin

Proceedings of the Tiangong-2 remote sensing application conference: technology, method and application / editors, Yidong Gu, Ming Gao and Guangheng Zhao

Online Resource




sin

Advances in Remote Sensing and Geo Informatics Applications: Proceedings of the 1st Springer Conference of the Arabian Journal of Geosciences (CAJG-1), Tunisia 2018 / Hesham M. El-Askary, Saro Lee, Essam Heggy, Biswajeet Pradhan, editors

Online Resource




sin

Big data analytics for satellite image processing and remote sensing / P. Swarnalatha, VIT University, India, Prabu Sevugan, VIT University, India

Rotch Library - GA102.4.E4 B54 2018




sin

Remote Sensing Image Classification in R.

Online Resource




sin

Satellite remote sensing and the management of natural resources / Nathalie Pettorelli

Barker Library - G70.4.P48 2019




sin

Interpreting remote sensing imagery: human factors / edited by Robert R. Hoffman, Arthur B. Markman

Online Resource




sin

Earth observations and geospatial science in service of sustainable development goals: 12th International Conference of the African Association of Remote Sensing and the Environment / Souleye Wade, editor

Online Resource




sin

Infrared remote sensing and instrumentation XXIV: 29-30 August 2015, San Diego, California, United States / Marija Strojnik, editor ; sponsored by SPIE

Online Resource




sin

Algorithms and Technologies for Multispectral, Hyperspectral, and Ultraspectral Imagery XXII: 18-21 April 2016, Baltimore, Maryland, United States / Miguel Velez-Reyes, David W. Messinger, editors ; sponsored and published by SPIE

Online Resource




sin

Encyclopedia of business and professional ethics / editors, Deborah C. Poff, Alex C. Michalos

Online Resource




sin

It's the manager: Gallup finds the quality of managers and team leaders is the single biggest factor in your organization's long-term success / Jim Clifton ; Jim Harter

Dewey Library - HD38.2.C55 2019




sin

Shared space and the new nonprofit workplace / China Brotsky, Sarah Mendelson Eisinger, Diane Vinokur-Kaplan

Dewey Library - HD62.6.B7534 2019




sin

The business of platforms: strategy in the age of digital competition, innovation, and power / Michael A. Cusumano, Annabelle Gawer, David B. Yoffie

Dewey Library - HD45.C87 2019




sin

The Palgrave handbook of learning and teaching international business and management / Maria Alejandra Gonzalez-Perez, Karen Lynden, Vas Taras, editors

Online Resource




sin

Logistics management: strategies and instruments for digitalizing and decarbonizing supply chains - proceedings of the German Academic Association for Business Research, Halle 2019 / Christian Bierwirth, Thomas Kirschstein, Dirk Sackmann, editors

Online Resource




sin

Managing Chinese-African business interactions: growing intercultural competence in organizations / Claude-Hélène Mayer, Lynette Louw, Christian Martin Boness, editors

Online Resource




sin

Real-time business intelligence and analytics: International Workshops, BIRTE 2015, Kohala Coast, HI, USA, August 31, 2015, BIRTE 2016, New Delhi, India, September 5, 2016, BIRTE 2017, Munich, Germany, August 28, 2017, Revised Selected Papers / Malu Caste

Online Resource




sin

The lean strategy: using lean to create competitive advantage, unleash innovation, and deliver sustainable growth / Michael Ballé, Daniel Jones, Jacques Chaize, Orest Fiume

Dewey Library - HD58.9.B35 2017




sin

Knowledge-driven profit improvement: implementing assessment feedback using PDKAction theory / Monte Lee Matthews

Online Resource




sin

Advances in human factors, business management and leadership: proceedings of the AHFE 2019 International Conference on Human Factors, Business Management and Society, and the AHFE International Conference on Human Factors in Management and Leadership, Ju

Online Resource




sin

The Inside Track to Excelling As a Business Analyst: Soft Skills That Can Accelerate Your Career / Roni Lubwama

Online Resource




sin

Responsible innovation: business opportunities and strategies for implementation / Katharina Jarmai, editor

Online Resource




sin

The next phase of business ethics: celebrating 20 years of REIO / edited by Michael Schwartz, Howard Harris ; review editor, Debra R. Comer

Dewey Library - HF5387.N49 2019




sin

Sino-German intercultural management: self-organization, communication and conflict resolution in a digital age / Joanne Huang

Online Resource




sin

Business and social crisis in Africa / Antoinette Handley, University of Toronto

Dewey Library - HD60.5.A35 H36 2019




sin

Corporate social responsibility in developing and emerging markets: institutions, actors and sustainable development / edited by Onyeka Osuji, University of Essex Law School, Franklin N. Ngwu, Lagos Business School, Pan-Atlantic University (Nigeria), Dima

Dewey Library - HD60.5.D44 C674 2020




sin

Business ethics from antiquity to the 19th century: an economist's view / David George Surdam

Online Resource




sin

Business ethics from the 19th century to today: an economist's view / David George Surdam

Online Resource




sin

Sustainable business performance and risk management: risk assessment tools in the context of business risk levels related to threats and opportunities / Ruxandra Maria Bejinariu

Online Resource




sin

Fundamentals of software startups: essential engineering and business aspects / Anh Nguyen-Duc, Jürgen Münch, Rafael Prikladnicki, Xiaofeng Wang, Pekka Abrahamsson, editors

Online Resource




sin

Family Businesses' Growth: Unpacking the Black Box / by Laura K.C. Seibold

Online Resource




sin

Return on investment in corporate responsibility: measuring the social, economic, and environmental value of sustainable business / by Cesar Sáenz

Dewey Library - HD60.S223 2018




sin

Sustainability, stakeholder governance, and corporate social responsibility / edited by Sinziana Dorobantu (New York University, USA), Ruth V. Aguilera (Northeastern University, USA), Jiao Luo (University of Minnesota, USA), Frances J. Milliken (New York

Dewey Library - HD60.S88465 2018